. */ namespace Tests\Api\Models\BudgetLimit; use Faker\Factory; use Laravel\Passport\Passport; use Log; use Tests\TestCase; use Tests\Traits\CollectsValues; use Tests\Traits\RandomValues; use Tests\Traits\TestHelpers; /** * Class UpdateControllerTest */ class UpdateControllerTest extends TestCase { use RandomValues, TestHelpers, CollectsValues; /** * */ public function setUp(): void { parent::setUp(); Passport::actingAs($this->user()); Log::info(sprintf('Now in %s.', get_class($this))); } /** * @dataProvider updateDataProvider */ public function testUpdate(array $submission): void { $ignore = [ 'created_at', 'updated_at', ]; $route = route('api.v1.budgets.limits.update', [$submission['id'], $submission['bl_id']]); $this->updateAndCompare($route, $submission, $ignore); } /** * @return array */ public function updateDataProvider(): array { $submissions = []; $all = $this->updateDataSet(); foreach ($all as $name => $data) { $submissions[] = [$data]; } return $submissions; } /** * @return array */ public function updateDataSet(): array { $faker = Factory::create(); $currencies = [ 1 => 'EUR', 2 => 'HUF', 3 => 'GBP', 4 => 'UAH', ]; $repeatFreqs = ['yearly', 'weekly', 'monthly']; $repeatFreq = $repeatFreqs[rand(0, count($repeatFreqs) - 1)]; $objectGroupId = $faker->numberBetween(1, 2); $objectGroupName = sprintf('Object group %d', $objectGroupId); $rand = rand(1, 4); $autoBudgetTypes = ['reset', 'rollover']; $autoBudgetType = $autoBudgetTypes[rand(0, count($autoBudgetTypes) - 1)]; $set = [ 'currency_id' => [ 'id' => 1, 'bl_id' => 1, 'fields' => [ 'currency_id' => ['test_value' => (string)$rand], ], 'extra_ignore' => ['currency_code','currency_name','currency_symbol'], ], 'currency_code' => [ 'id' => 1, 'bl_id' => 1, 'fields' => [ 'currency_code' => ['test_value' => $currencies[$rand]], ], 'extra_ignore' => ['currency_id','currency_name','currency_symbol'], ], 'start' => [ 'id' => 1, 'bl_id' => 1, 'fields' => [ 'start' => ['test_value' => $faker->dateTimeBetween('-2 year', '-1 year')->format('Y-m-d')], ], 'extra_ignore' => [], ], 'end' => [ 'id' => 1, 'bl_id' => 1, 'fields' => [ 'end' => ['test_value' => $faker->dateTimeBetween('-1 year', 'now')->format('Y-m-d')], ], 'extra_ignore' => [], ], 'amount' => [ 'id' => 1, 'bl_id' => 1, 'fields' => [ 'amount' => ['test_value' => number_format($faker->randomFloat(2, 10, 100), 2)], ], 'extra_ignore' => [], ], ]; return $set; } }