mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-09-26 07:15:41 +00:00
Update test code.
This commit is contained in:
@@ -179,7 +179,15 @@ class AttachmentRepository implements AttachmentRepositoryInterface
|
|||||||
$attachment->filename = $data['filename'];
|
$attachment->filename = $data['filename'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// update model (move attachment)
|
||||||
|
// should be validated already:
|
||||||
|
if (array_key_exists('attachable_type', $data) && array_key_exists('attachable_id', $data)) {
|
||||||
|
$attachment->attachable_id = (int)$data['attachable_id'];
|
||||||
|
$attachment->attachable_type = sprintf('FireflyIII\\Models\\%s', $data['attachable_type']);
|
||||||
|
}
|
||||||
|
|
||||||
$attachment->save();
|
$attachment->save();
|
||||||
|
$attachment->refresh();
|
||||||
if (array_key_exists('notes', $data)) {
|
if (array_key_exists('notes', $data)) {
|
||||||
$this->updateNote($attachment, (string)$data['notes']);
|
$this->updateNote($attachment, (string)$data['notes']);
|
||||||
}
|
}
|
||||||
|
@@ -36,7 +36,7 @@
|
|||||||
</coverage>
|
</coverage>
|
||||||
<testsuites>
|
<testsuites>
|
||||||
<testsuite name="Api">
|
<testsuite name="Api">
|
||||||
<directory suffix="Test.php">./tests/Api/Models/Account</directory>
|
<directory suffix="Test.php">./tests/Api/Models/Attachment</directory>
|
||||||
</testsuite>
|
</testsuite>
|
||||||
</testsuites>
|
</testsuites>
|
||||||
<php>
|
<php>
|
||||||
|
@@ -29,7 +29,6 @@ use Tests\Objects\FieldSet;
|
|||||||
use Tests\Objects\TestConfiguration;
|
use Tests\Objects\TestConfiguration;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -37,7 +36,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class StoreControllerTest extends TestCase
|
class StoreControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
@@ -58,27 +57,6 @@ class StoreControllerTest extends TestCase
|
|||||||
Log::info(sprintf('Now in %s.', get_class($this)));
|
Log::info(sprintf('Now in %s.', get_class($this)));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @param array $submission
|
|
||||||
*
|
|
||||||
* storeDataProvider / emptyDataProvider
|
|
||||||
*
|
|
||||||
* @dataProvider emptyDataProvider
|
|
||||||
*/
|
|
||||||
public function testStore(array $submission): void
|
|
||||||
{
|
|
||||||
if ([] === $submission) {
|
|
||||||
$this->markTestSkipped('Empty provider.');
|
|
||||||
}
|
|
||||||
Log::debug('testStoreUpdated()');
|
|
||||||
Log::debug('submission :', $submission['submission']);
|
|
||||||
Log::debug('expected :', $submission['expected']);
|
|
||||||
Log::debug('ignore :', $submission['ignore']);
|
|
||||||
// run account store with a minimal data set:
|
|
||||||
$address = route('api.v1.accounts.store');
|
|
||||||
$this->updatedStoreAndCompare($address, $submission);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
*/
|
*/
|
||||||
@@ -217,4 +195,25 @@ class StoreControllerTest extends TestCase
|
|||||||
return $final;
|
return $final;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array $submission
|
||||||
|
*
|
||||||
|
* storeDataProvider / emptyDataProvider
|
||||||
|
*
|
||||||
|
* @dataProvider emptyDataProvider
|
||||||
|
*/
|
||||||
|
public function testStore(array $submission): void
|
||||||
|
{
|
||||||
|
if ([] === $submission) {
|
||||||
|
$this->markTestSkipped('Empty provider.');
|
||||||
|
}
|
||||||
|
Log::debug('testStoreUpdated()');
|
||||||
|
Log::debug('submission :', $submission['submission']);
|
||||||
|
Log::debug('expected :', $submission['expected']);
|
||||||
|
Log::debug('ignore :', $submission['ignore']);
|
||||||
|
// run account store with a minimal data set:
|
||||||
|
$address = route('api.v1.accounts.store');
|
||||||
|
$this->assertPOST($address, $submission);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
@@ -29,7 +29,6 @@ use Tests\Objects\FieldSet;
|
|||||||
use Tests\Objects\TestConfiguration;
|
use Tests\Objects\TestConfiguration;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
|
|
||||||
@@ -38,39 +37,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class UpdateControllerTest extends TestCase
|
class UpdateControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public function setUp(): void
|
|
||||||
{
|
|
||||||
parent::setUp();
|
|
||||||
Passport::actingAs($this->user());
|
|
||||||
Log::info(sprintf('Now in %s.', get_class($this)));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param array $submission
|
|
||||||
*
|
|
||||||
* newStoreDataProvider / emptyDataProvider
|
|
||||||
*
|
|
||||||
* @dataProvider newUpdateDataProvider
|
|
||||||
*/
|
|
||||||
public function testUpdate(array $submission): void
|
|
||||||
{
|
|
||||||
if ([] === $submission) {
|
|
||||||
$this->markTestSkipped('Empty provider.');
|
|
||||||
}
|
|
||||||
Log::debug('testStoreUpdated()');
|
|
||||||
Log::debug('submission :', $submission['submission']);
|
|
||||||
Log::debug('expected :', $submission['expected']);
|
|
||||||
Log::debug('ignore :', $submission['ignore']);
|
|
||||||
Log::debug('parameters :', $submission['parameters']);
|
|
||||||
|
|
||||||
$route = route('api.v1.accounts.update', $submission['parameters']);
|
|
||||||
$this->updatedUpdateAndCompare($route, $submission);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Only create optional sets.
|
* Only create optional sets.
|
||||||
@@ -157,28 +124,28 @@ class UpdateControllerTest extends TestCase
|
|||||||
$fieldSet->addField(Field::createBasic('notes', 'uuid'));
|
$fieldSet->addField(Field::createBasic('notes', 'uuid'));
|
||||||
$configuration->addOptionalFieldSet('notes', $fieldSet);
|
$configuration->addOptionalFieldSet('notes', $fieldSet);
|
||||||
|
|
||||||
$fieldSet = new FieldSet;
|
$fieldSet = new FieldSet;
|
||||||
$fieldSet->parameters = [1];
|
$fieldSet->parameters = [1];
|
||||||
$fieldSet->addField(Field::createBasic('latitude', 'latitude'));
|
$fieldSet->addField(Field::createBasic('latitude', 'latitude'));
|
||||||
$fieldSet->addField(Field::createBasic('longitude', 'longitude'));
|
$fieldSet->addField(Field::createBasic('longitude', 'longitude'));
|
||||||
$fieldSet->addField(Field::createBasic('zoom_level', 'random-zoom_level'));
|
$fieldSet->addField(Field::createBasic('zoom_level', 'random-zoom_level'));
|
||||||
$configuration->addOptionalFieldSet('notes', $fieldSet);
|
$configuration->addOptionalFieldSet('notes', $fieldSet);
|
||||||
|
|
||||||
$fieldSet = new FieldSet;
|
$fieldSet = new FieldSet;
|
||||||
$fieldSet->parameters = [1];
|
$fieldSet->parameters = [1];
|
||||||
$fieldSet->addField(Field::createBasic('opening_balance', 'random-amount'));
|
$fieldSet->addField(Field::createBasic('opening_balance', 'random-amount'));
|
||||||
$fieldSet->addField(Field::createBasic('opening_balance_date', 'random-past-date'));
|
$fieldSet->addField(Field::createBasic('opening_balance_date', 'random-past-date'));
|
||||||
$configuration->addOptionalFieldSet('ob', $fieldSet);
|
$configuration->addOptionalFieldSet('ob', $fieldSet);
|
||||||
|
|
||||||
$fieldSet = new FieldSet;
|
$fieldSet = new FieldSet;
|
||||||
$fieldSet->parameters = [7];
|
$fieldSet->parameters = [7];
|
||||||
$fieldSet->addField(Field::createBasic('account_role', 'static-ccAsset'));
|
$fieldSet->addField(Field::createBasic('account_role', 'static-ccAsset'));
|
||||||
$fieldSet->addField(Field::createBasic('credit_card_type', 'static-monthlyFull'));
|
$fieldSet->addField(Field::createBasic('credit_card_type', 'static-monthlyFull'));
|
||||||
$fieldSet->addField(Field::createBasic('monthly_payment_date', 'random-past-date'));
|
$fieldSet->addField(Field::createBasic('monthly_payment_date', 'random-past-date'));
|
||||||
$configuration->addOptionalFieldSet('cc1', $fieldSet);
|
$configuration->addOptionalFieldSet('cc1', $fieldSet);
|
||||||
|
|
||||||
$fieldSet = new FieldSet;
|
$fieldSet = new FieldSet;
|
||||||
$fieldSet->parameters = [13];
|
$fieldSet->parameters = [13];
|
||||||
$field = new Field;
|
$field = new Field;
|
||||||
$field->fieldTitle = 'liability_type';
|
$field->fieldTitle = 'liability_type';
|
||||||
$field->fieldType = 'random-liability-type';
|
$field->fieldType = 'random-liability-type';
|
||||||
@@ -190,7 +157,7 @@ class UpdateControllerTest extends TestCase
|
|||||||
$fieldSet->addField(Field::createBasic('monthly_payment_date', 'null'));
|
$fieldSet->addField(Field::createBasic('monthly_payment_date', 'null'));
|
||||||
$configuration->addOptionalFieldSet('liability-1', $fieldSet);
|
$configuration->addOptionalFieldSet('liability-1', $fieldSet);
|
||||||
|
|
||||||
$fieldSet = new FieldSet;
|
$fieldSet = new FieldSet;
|
||||||
$fieldSet->parameters = [13];
|
$fieldSet->parameters = [13];
|
||||||
$fieldSet->addField(Field::createBasic('interest', 'random-percentage'));
|
$fieldSet->addField(Field::createBasic('interest', 'random-percentage'));
|
||||||
$field = new Field;
|
$field = new Field;
|
||||||
@@ -223,4 +190,36 @@ class UpdateControllerTest extends TestCase
|
|||||||
|
|
||||||
return $final;
|
return $final;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public function setUp(): void
|
||||||
|
{
|
||||||
|
parent::setUp();
|
||||||
|
Passport::actingAs($this->user());
|
||||||
|
Log::info(sprintf('Now in %s.', get_class($this)));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param array $submission
|
||||||
|
*
|
||||||
|
* newStoreDataProvider / emptyDataProvider
|
||||||
|
*
|
||||||
|
* @dataProvider newUpdateDataProvider
|
||||||
|
*/
|
||||||
|
public function testUpdate(array $submission): void
|
||||||
|
{
|
||||||
|
if ([] === $submission) {
|
||||||
|
$this->markTestSkipped('Empty provider.');
|
||||||
|
}
|
||||||
|
Log::debug('testStoreUpdated()');
|
||||||
|
Log::debug('submission :', $submission['submission']);
|
||||||
|
Log::debug('expected :', $submission['expected']);
|
||||||
|
Log::debug('ignore :', $submission['ignore']);
|
||||||
|
Log::debug('parameters :', $submission['parameters']);
|
||||||
|
|
||||||
|
$route = route('api.v1.accounts.update', $submission['parameters']);
|
||||||
|
$this->assertPUT($route, $submission);
|
||||||
|
}
|
||||||
}
|
}
|
@@ -22,12 +22,13 @@
|
|||||||
namespace Tests\Api\Models\Attachment;
|
namespace Tests\Api\Models\Attachment;
|
||||||
|
|
||||||
|
|
||||||
use Faker\Factory;
|
|
||||||
use Laravel\Passport\Passport;
|
use Laravel\Passport\Passport;
|
||||||
use Log;
|
use Log;
|
||||||
|
use Tests\Objects\Field;
|
||||||
|
use Tests\Objects\FieldSet;
|
||||||
|
use Tests\Objects\TestConfiguration;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +36,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class StoreControllerTest extends TestCase
|
class StoreControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
@@ -56,67 +57,6 @@ class StoreControllerTest extends TestCase
|
|||||||
Log::info(sprintf('Now in %s.', get_class($this)));
|
Log::info(sprintf('Now in %s.', get_class($this)));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
public function storeDataProvider(): array
|
|
||||||
{
|
|
||||||
$minimalSets = $this->minimalSets();
|
|
||||||
$optionalSets = $this->optionalSets();
|
|
||||||
$regenConfig = [];
|
|
||||||
|
|
||||||
return $this->genericDataProvider($minimalSets, $optionalSets, $regenConfig);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
private function minimalSets(): array
|
|
||||||
{
|
|
||||||
$faker = Factory::create();
|
|
||||||
$types = [
|
|
||||||
'Account',
|
|
||||||
'Budget',
|
|
||||||
'Bill',
|
|
||||||
'TransactionJournal',
|
|
||||||
'PiggyBank',
|
|
||||||
'Tag',
|
|
||||||
];
|
|
||||||
$type = $types[rand(0, count($types) - 1)];
|
|
||||||
|
|
||||||
return [
|
|
||||||
'default_file' => [
|
|
||||||
'parameters' => [],
|
|
||||||
'fields' => [
|
|
||||||
'filename' => join(' ', $faker->words(3)),
|
|
||||||
'attachable_type' => $type,
|
|
||||||
'attachable_id' => '1',
|
|
||||||
],
|
|
||||||
],
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return \array[][]
|
|
||||||
*/
|
|
||||||
private function optionalSets(): array
|
|
||||||
{
|
|
||||||
$faker = Factory::create();
|
|
||||||
|
|
||||||
return [
|
|
||||||
'title' => [
|
|
||||||
'fields' => [
|
|
||||||
'title' => $faker->uuid,
|
|
||||||
],
|
|
||||||
],
|
|
||||||
'notes' => [
|
|
||||||
'fields' => [
|
|
||||||
'notes' => join(' ', $faker->words(5)),
|
|
||||||
],
|
|
||||||
],
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param array $submission
|
* @param array $submission
|
||||||
*
|
*
|
||||||
@@ -127,10 +67,57 @@ class StoreControllerTest extends TestCase
|
|||||||
public function testStore(array $submission): void
|
public function testStore(array $submission): void
|
||||||
{
|
{
|
||||||
if ([] === $submission) {
|
if ([] === $submission) {
|
||||||
$this->markTestSkipped('Empty data provider');
|
$this->markTestSkipped('Empty provider.');
|
||||||
}
|
}
|
||||||
|
Log::debug('testStoreUpdated()');
|
||||||
|
Log::debug('submission :', $submission['submission']);
|
||||||
|
Log::debug('expected :', $submission['expected']);
|
||||||
|
Log::debug('ignore :', $submission['ignore']);
|
||||||
// run account store with a minimal data set:
|
// run account store with a minimal data set:
|
||||||
$route = 'api.v1.attachments.store';
|
$address = route('api.v1.attachments.store');
|
||||||
$this->storeAndCompare($route, $submission);
|
$this->assertPOST($address, $submission);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function storeDataProvider(): array
|
||||||
|
{
|
||||||
|
// some test configs:
|
||||||
|
$configuration = new TestConfiguration;
|
||||||
|
|
||||||
|
// default asset account test set:
|
||||||
|
$defaultAssetSet = new FieldSet();
|
||||||
|
$defaultAssetSet->title = 'default_file';
|
||||||
|
$defaultAssetSet->addField(Field::createBasic('filename', 'uuid'));
|
||||||
|
$defaultAssetSet->addField(Field::createBasic('attachable_type', 'random-attachment-type'));
|
||||||
|
$defaultAssetSet->addField(Field::createBasic('attachable_id', 'static-one'));
|
||||||
|
$configuration->addMandatoryFieldSet($defaultAssetSet);
|
||||||
|
|
||||||
|
$fieldSet = new FieldSet;
|
||||||
|
$fieldSet->addField(Field::createBasic('title', 'uuid'));
|
||||||
|
$configuration->addOptionalFieldSet('title', $fieldSet);
|
||||||
|
|
||||||
|
$fieldSet = new FieldSet;
|
||||||
|
$fieldSet->addField(Field::createBasic('notes', 'uuid'));
|
||||||
|
$configuration->addOptionalFieldSet('notes', $fieldSet);
|
||||||
|
|
||||||
|
|
||||||
|
// generate submissions
|
||||||
|
$array = $configuration->generateSubmissions();
|
||||||
|
$expected = $configuration->generateExpected($array);
|
||||||
|
$ignored = $configuration->ignores;
|
||||||
|
|
||||||
|
// now create a combination for each submission and associated data:
|
||||||
|
$final = [];
|
||||||
|
foreach ($array as $index => $submission) {
|
||||||
|
$final[] = [[
|
||||||
|
'submission' => $submission,
|
||||||
|
'expected' => $expected[$index],
|
||||||
|
'ignore' => $ignored[$index],
|
||||||
|
]];
|
||||||
|
}
|
||||||
|
|
||||||
|
return $final;
|
||||||
}
|
}
|
||||||
}
|
}
|
@@ -25,9 +25,11 @@ namespace Tests\Api\Models\Attachment;
|
|||||||
use Faker\Factory;
|
use Faker\Factory;
|
||||||
use Laravel\Passport\Passport;
|
use Laravel\Passport\Passport;
|
||||||
use Log;
|
use Log;
|
||||||
|
use Tests\Objects\Field;
|
||||||
|
use Tests\Objects\FieldSet;
|
||||||
|
use Tests\Objects\TestConfiguration;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +37,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class UpdateControllerTest extends TestCase
|
class UpdateControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
@@ -53,13 +55,17 @@ class UpdateControllerTest extends TestCase
|
|||||||
*/
|
*/
|
||||||
public function testUpdate(array $submission): void
|
public function testUpdate(array $submission): void
|
||||||
{
|
{
|
||||||
$ignore = [
|
if ([] === $submission) {
|
||||||
'created_at',
|
$this->markTestSkipped('Empty provider.');
|
||||||
'updated_at',
|
}
|
||||||
];
|
Log::debug('testStoreUpdated()');
|
||||||
$route = route('api.v1.attachments.update', [$submission['id']]);
|
Log::debug('submission :', $submission['submission']);
|
||||||
|
Log::debug('expected :', $submission['expected']);
|
||||||
|
Log::debug('ignore :', $submission['ignore']);
|
||||||
|
Log::debug('parameters :', $submission['parameters']);
|
||||||
|
|
||||||
$this->updateAndCompare($route, $submission, $ignore);
|
$route = route('api.v1.attachments.update', $submission['parameters']);
|
||||||
|
$this->assertPUT($route, $submission);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -68,13 +74,48 @@ class UpdateControllerTest extends TestCase
|
|||||||
*/
|
*/
|
||||||
public function updateDataProvider(): array
|
public function updateDataProvider(): array
|
||||||
{
|
{
|
||||||
$submissions = [];
|
$configuration = new TestConfiguration;
|
||||||
$all = $this->updateDataSet();
|
|
||||||
foreach ($all as $name => $data) {
|
// optional field sets (for all test configs)
|
||||||
$submissions[] = [$data];
|
$fieldSet = new FieldSet;
|
||||||
|
$fieldSet->parameters = [1];
|
||||||
|
$fieldSet->addField(Field::createBasic('filename', 'uuid'));
|
||||||
|
$configuration->addOptionalFieldSet('filename', $fieldSet);
|
||||||
|
|
||||||
|
$fieldSet = new FieldSet;
|
||||||
|
$fieldSet->parameters = [1];
|
||||||
|
$fieldSet->addField(Field::createBasic('title', 'uuid'));
|
||||||
|
$configuration->addOptionalFieldSet('title', $fieldSet);
|
||||||
|
|
||||||
|
$fieldSet = new FieldSet;
|
||||||
|
$fieldSet->parameters = [1];
|
||||||
|
$fieldSet->addField(Field::createBasic('notes', 'uuid'));
|
||||||
|
$configuration->addOptionalFieldSet('notes', $fieldSet);
|
||||||
|
|
||||||
|
$fieldSet = new FieldSet;
|
||||||
|
$fieldSet->parameters = [1];
|
||||||
|
$fieldSet->addField(Field::createBasic('attachable_type', 'static-journal-type'));
|
||||||
|
$fieldSet->addField(Field::createBasic('attachable_id', 'random-journal-id'));
|
||||||
|
$configuration->addOptionalFieldSet('attachable_type', $fieldSet);
|
||||||
|
|
||||||
|
// generate submissions
|
||||||
|
$array = $configuration->generateSubmissions();
|
||||||
|
$expected = $configuration->generateExpected($array);
|
||||||
|
$parameters = $configuration->parameters;
|
||||||
|
$ignored = $configuration->ignores;
|
||||||
|
|
||||||
|
// now create a combination for each submission and associated data:
|
||||||
|
$final = [];
|
||||||
|
foreach ($array as $index => $submission) {
|
||||||
|
$final[] = [[
|
||||||
|
'submission' => $submission,
|
||||||
|
'expected' => $expected[$index],
|
||||||
|
'ignore' => $ignored[$index] ?? [],
|
||||||
|
'parameters' => $parameters[$index],
|
||||||
|
]];
|
||||||
}
|
}
|
||||||
|
|
||||||
return $submissions;
|
return $final;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class StoreControllerTest extends TestCase
|
class StoreControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class UpdateControllerTest extends TestCase
|
class UpdateControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class StoreControllerTest extends TestCase
|
class StoreControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class UpdateControllerTest extends TestCase
|
class UpdateControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class StoreControllerTest extends TestCase
|
class StoreControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class UpdateControllerTest extends TestCase
|
class UpdateControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class StoreControllerTest extends TestCase
|
class StoreControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class UpdateControllerTest extends TestCase
|
class UpdateControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class StoreControllerTest extends TestCase
|
class StoreControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class UpdateControllerTest extends TestCase
|
class UpdateControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class UpdateControllerTest extends TestCase
|
class UpdateControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class StoreControllerTest extends TestCase
|
class StoreControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class UpdateControllerTest extends TestCase
|
class UpdateControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class StoreControllerTest extends TestCase
|
class StoreControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class UpdateControllerTest extends TestCase
|
class UpdateControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class StoreControllerTest extends TestCase
|
class StoreControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class StoreControllerTest extends TestCase
|
class StoreControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class UpdateControllerTest extends TestCase
|
class UpdateControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class StoreControllerTest extends TestCase
|
class StoreControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class UpdateControllerTest extends TestCase
|
class UpdateControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@@ -28,7 +28,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -36,7 +36,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class StoreControllerTest extends TestCase
|
class StoreControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class StoreControllerTest extends TestCase
|
class StoreControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class UpdateControllerTest extends TestCase
|
class UpdateControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class StoreControllerTest extends TestCase
|
class StoreControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class UpdateControllerTest extends TestCase
|
class UpdateControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class StoreControllerTest extends TestCase
|
class StoreControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class UpdateControllerTest extends TestCase
|
class UpdateControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class StoreControllerTest extends TestCase
|
class StoreControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return array
|
* @return array
|
||||||
|
@@ -27,7 +27,7 @@ use Laravel\Passport\Passport;
|
|||||||
use Log;
|
use Log;
|
||||||
use Tests\TestCase;
|
use Tests\TestCase;
|
||||||
use Tests\Traits\CollectsValues;
|
use Tests\Traits\CollectsValues;
|
||||||
use Tests\Traits\RandomValues;
|
|
||||||
use Tests\Traits\TestHelpers;
|
use Tests\Traits\TestHelpers;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -35,7 +35,7 @@ use Tests\Traits\TestHelpers;
|
|||||||
*/
|
*/
|
||||||
class UpdateControllerTest extends TestCase
|
class UpdateControllerTest extends TestCase
|
||||||
{
|
{
|
||||||
use RandomValues, TestHelpers, CollectsValues;
|
use TestHelpers, CollectsValues;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
|
@@ -376,8 +376,14 @@ class TestConfiguration
|
|||||||
return 'ccAsset';
|
return 'ccAsset';
|
||||||
case 'static-monthlyFull':
|
case 'static-monthlyFull':
|
||||||
return 'monthlyFull';
|
return 'monthlyFull';
|
||||||
|
case 'static-one':
|
||||||
|
return 1;
|
||||||
|
case 'static-journal-type':
|
||||||
|
return 'TransactionJournal';
|
||||||
case 'random-liability-type':
|
case 'random-liability-type':
|
||||||
return $faker->randomElement(['loan', 'debt', 'mortgage']);
|
return $faker->randomElement(['loan', 'debt', 'mortgage']);
|
||||||
|
case 'random-journal-id':
|
||||||
|
return $faker->numberBetween(1,25);
|
||||||
case 'random-amount':
|
case 'random-amount':
|
||||||
return number_format($faker->randomFloat(2, 10, 100), 2);
|
return number_format($faker->randomFloat(2, 10, 100), 2);
|
||||||
case 'random-percentage':
|
case 'random-percentage':
|
||||||
@@ -411,6 +417,8 @@ class TestConfiguration
|
|||||||
return $faker->numberBetween(1, 12);
|
return $faker->numberBetween(1, 12);
|
||||||
case 'null':
|
case 'null':
|
||||||
return null;
|
return null;
|
||||||
|
case 'random-attachment-type':
|
||||||
|
return $faker->randomElement(['Account', 'Budget', 'Bill', 'TransactionJournal', 'PiggyBank','Tag',]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -38,208 +38,4 @@ trait CollectsValues
|
|||||||
{
|
{
|
||||||
return User::where('email', 'james@firefly')->first();
|
return User::where('email', 'james@firefly')->first();
|
||||||
}
|
}
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @return User
|
|
||||||
// */
|
|
||||||
// public function nonAdminUser(): User
|
|
||||||
// {
|
|
||||||
// return User::where('email', 'no_admin@firefly')->first();
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @return Budget
|
|
||||||
// */
|
|
||||||
// public function getRandomBudget(): Budget
|
|
||||||
// {
|
|
||||||
// return $this->user()->budgets()->inRandomOrder()->first();
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @return Category
|
|
||||||
// */
|
|
||||||
// public function getRandomCategory(): Category
|
|
||||||
// {
|
|
||||||
// return $this->user()->categories()->inRandomOrder()->first();
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @return Bill
|
|
||||||
// */
|
|
||||||
// public function getRandomBill(): Bill
|
|
||||||
// {
|
|
||||||
// return $this->user()->bills()->inRandomOrder()->first();
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @return PiggyBank
|
|
||||||
// */
|
|
||||||
// public function getRandomPiggyBank(): PiggyBank
|
|
||||||
// {
|
|
||||||
// return $this->user()->piggyBanks()->inRandomOrder()->first();
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @return Tag
|
|
||||||
// */
|
|
||||||
// public function getRandomTag(): Tag
|
|
||||||
// {
|
|
||||||
// return $this->user()->tags()->inRandomOrder()->first();
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @return TransactionJournal
|
|
||||||
// */
|
|
||||||
// public function getRandomWithdrawal(): TransactionJournal
|
|
||||||
// {
|
|
||||||
// return $this->getRandomJournal(TransactionType::WITHDRAWAL);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @return TransactionJournal
|
|
||||||
// */
|
|
||||||
// public function getRandomTransfer(): TransactionJournal
|
|
||||||
// {
|
|
||||||
// return $this->getRandomJournal(TransactionType::TRANSFER);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @return TransactionJournal
|
|
||||||
// */
|
|
||||||
// public function getRandomDeposit(): TransactionJournal
|
|
||||||
// {
|
|
||||||
// return $this->getRandomJournal(TransactionType::DEPOSIT);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @param string $type
|
|
||||||
// *
|
|
||||||
// * @return TransactionJournal
|
|
||||||
// * @throws FireflyException
|
|
||||||
// */
|
|
||||||
// private function getRandomJournal(string $type): TransactionJournal
|
|
||||||
// {
|
|
||||||
// $query = DB::table('transactions')
|
|
||||||
// ->leftJoin('transaction_journals', 'transaction_journals.id', '=', 'transactions.transaction_journal_id')
|
|
||||||
// ->leftJoin('transaction_types', 'transaction_types.id', '=', 'transaction_journals.transaction_type_id')
|
|
||||||
// ->where('transaction_journals.user_id', $this->user()->id)
|
|
||||||
// ->whereNull('transaction_journals.deleted_at')
|
|
||||||
// ->whereNull('transactions.deleted_at')
|
|
||||||
// ->where('transaction_types.type', $type)
|
|
||||||
// ->groupBy('transactions.transaction_journal_id')
|
|
||||||
// ->having('ct', '=', 2)
|
|
||||||
// ->inRandomOrder()->take(1);
|
|
||||||
// $result = $query->get(
|
|
||||||
// [
|
|
||||||
// 'transactions.transaction_journal_id',
|
|
||||||
// 'transaction_journals.transaction_type_id',
|
|
||||||
// DB::raw('COUNT(transaction_journal_id) as ct'),
|
|
||||||
// ]
|
|
||||||
// )->first();
|
|
||||||
// if (null === $result) {
|
|
||||||
// throw new FireflyException(sprintf('Cannot find suitable journal "%s" to use.', $type));
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// return TransactionJournal::find((int)$result->transaction_journal_id);
|
|
||||||
//
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @return TransactionCurrency
|
|
||||||
// */
|
|
||||||
// public function getEuro(): TransactionCurrency
|
|
||||||
// {
|
|
||||||
// return TransactionCurrency::whereCode('EUR')->first();
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @return TransactionCurrency
|
|
||||||
// */
|
|
||||||
// public function getRandomCurrency(): TransactionCurrency
|
|
||||||
// {
|
|
||||||
// return TransactionCurrency::where('code', '!=', 'EUR')->inRandomOrder()->first();
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @return TransactionCurrency
|
|
||||||
// */
|
|
||||||
// public function getDollar(): TransactionCurrency
|
|
||||||
// {
|
|
||||||
// return TransactionCurrency::whereCode('USD')->first();
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @param int|null $except
|
|
||||||
// *
|
|
||||||
// * @return Account
|
|
||||||
// */
|
|
||||||
// public function getRandomAsset(?int $except = null): Account
|
|
||||||
// {
|
|
||||||
// return $this->getRandomAccount(AccountType::ASSET, $except);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @param int|null $except
|
|
||||||
// *
|
|
||||||
// * @return Account
|
|
||||||
// */
|
|
||||||
// public function getRandomDebt(?int $except = null): Account
|
|
||||||
// {
|
|
||||||
// return $this->getRandomAccount(AccountType::DEBT, $except);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @param int|null $except
|
|
||||||
// *
|
|
||||||
// * @return Account
|
|
||||||
// */
|
|
||||||
// public function getRandomLoan(?int $except = null): Account
|
|
||||||
// {
|
|
||||||
// return $this->getRandomAccount(AccountType::LOAN, $except);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @param int|null $except
|
|
||||||
// *
|
|
||||||
// * @return Account
|
|
||||||
// */
|
|
||||||
// public function getRandomRevenue(?int $except = null): Account
|
|
||||||
// {
|
|
||||||
// return $this->getRandomAccount(AccountType::REVENUE, $except);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @param int|null $except
|
|
||||||
// *
|
|
||||||
// * @return Account
|
|
||||||
// */
|
|
||||||
// public function getRandomExpense(?int $except = null): Account
|
|
||||||
// {
|
|
||||||
// return $this->getRandomAccount(AccountType::EXPENSE, $except);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// /**
|
|
||||||
// * @param string $type
|
|
||||||
// *
|
|
||||||
// * @param int|null $except
|
|
||||||
// *
|
|
||||||
// * @return Account
|
|
||||||
// */
|
|
||||||
// private function getRandomAccount(string $type, ?int $except): Account
|
|
||||||
// {
|
|
||||||
// $query = Account::
|
|
||||||
// leftJoin('account_types', 'account_types.id', '=', 'accounts.account_type_id')
|
|
||||||
// ->whereNull('accounts.deleted_at')
|
|
||||||
// ->where('accounts.user_id', $this->user()->id)
|
|
||||||
// ->where('account_types.type', $type)
|
|
||||||
// ->inRandomOrder()->take(1);
|
|
||||||
// if (null !== $except) {
|
|
||||||
// $query->where('accounts.id', '!=', $except);
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// return $query->first(['accounts.*']);
|
|
||||||
// }
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -1,34 +0,0 @@
|
|||||||
<?php
|
|
||||||
/*
|
|
||||||
* FakeValues.php
|
|
||||||
* Copyright (c) 2021 james@firefly-iii.org
|
|
||||||
*
|
|
||||||
* This file is part of Firefly III (https://github.com/firefly-iii).
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU Affero General Public License as
|
|
||||||
* published by the Free Software Foundation, either version 3 of the
|
|
||||||
* License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU Affero General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Affero General Public License
|
|
||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
namespace Tests\Traits;
|
|
||||||
|
|
||||||
|
|
||||||
trait FakeValues
|
|
||||||
{
|
|
||||||
// /**
|
|
||||||
// * @return string
|
|
||||||
// */
|
|
||||||
// protected function fakeName(): string {
|
|
||||||
// return '';
|
|
||||||
// }
|
|
||||||
|
|
||||||
}
|
|
@@ -1,44 +0,0 @@
|
|||||||
<?php
|
|
||||||
/*
|
|
||||||
* MocksDefaultValues.php
|
|
||||||
* Copyright (c) 2020 james@firefly-iii.org
|
|
||||||
*
|
|
||||||
* This file is part of Firefly III (https://github.com/firefly-iii).
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU Affero General Public License as
|
|
||||||
* published by the Free Software Foundation, either version 3 of the
|
|
||||||
* License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU Affero General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Affero General Public License
|
|
||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
declare(strict_types=1);
|
|
||||||
|
|
||||||
namespace Tests\Traits;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Trait MocksDefaultValues
|
|
||||||
*/
|
|
||||||
trait MocksDefaultValues
|
|
||||||
{
|
|
||||||
// public function mockDefaultConfiguration(): void
|
|
||||||
// {
|
|
||||||
//
|
|
||||||
// $falseConfig = new Configuration;
|
|
||||||
// $falseConfig->data = false;
|
|
||||||
//
|
|
||||||
// $idConfig = new Configuration;
|
|
||||||
// $idConfig->data = 'abc';
|
|
||||||
//
|
|
||||||
// FireflyConfig::shouldReceive('get')->withArgs(['is_demo_site', false])->andReturn($falseConfig);
|
|
||||||
// FireflyConfig::shouldReceive('get')->withArgs(['installation_id', null])->andReturn($idConfig);
|
|
||||||
// }
|
|
||||||
|
|
||||||
}
|
|
@@ -1,125 +0,0 @@
|
|||||||
<?php
|
|
||||||
/*
|
|
||||||
* RandomValues.php
|
|
||||||
* Copyright (c) 2021 james@firefly-iii.org
|
|
||||||
*
|
|
||||||
* This file is part of Firefly III (https://github.com/firefly-iii).
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU Affero General Public License as
|
|
||||||
* published by the Free Software Foundation, either version 3 of the
|
|
||||||
* License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU Affero General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Affero General Public License
|
|
||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
namespace Tests\Traits;
|
|
||||||
|
|
||||||
|
|
||||||
use Carbon\Carbon;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Trait RandomValues
|
|
||||||
*/
|
|
||||||
trait RandomValues
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* @param $k
|
|
||||||
* @param $xs
|
|
||||||
*
|
|
||||||
* @return array|array[]
|
|
||||||
*/
|
|
||||||
protected function combinationsOf($k, $xs): array
|
|
||||||
{
|
|
||||||
if ($k === 0) {
|
|
||||||
return [[]];
|
|
||||||
}
|
|
||||||
if (count($xs) === 0) {
|
|
||||||
return [];
|
|
||||||
}
|
|
||||||
$x = $xs[0];
|
|
||||||
$xs1 = array_slice($xs, 1, count($xs) - 1);
|
|
||||||
$res1 = $this->combinationsOf($k - 1, $xs1);
|
|
||||||
for ($i = 0; $i < count($res1); $i++) {
|
|
||||||
array_splice($res1[$i], 0, 0, $x);
|
|
||||||
}
|
|
||||||
$res2 = $this->combinationsOf($k, $xs1);
|
|
||||||
|
|
||||||
return array_merge($res1, $res2);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
protected function getRandomAmount(): string
|
|
||||||
{
|
|
||||||
return number_format(rand(1000, 100000) / 100, '2', '.');
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
protected function getRandomCurrencyCode(): string
|
|
||||||
{
|
|
||||||
return $this->randomFromArray(['EUR', 'USD', 'GBP']);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
protected function getRandomDateString(): string
|
|
||||||
{
|
|
||||||
$date = Carbon::now();
|
|
||||||
$date->subDays(rand(10, 100));
|
|
||||||
|
|
||||||
return $date->format('Y-m-d');
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
protected function getRandomInterestPeriod(): string
|
|
||||||
{
|
|
||||||
return $this->randomFromArray(['daily', 'monthly', 'yearly']);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
protected function getRandomPercentage(): string
|
|
||||||
{
|
|
||||||
return rand(1, 10000) / 100;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
protected function randomAccountRole(): string
|
|
||||||
{
|
|
||||||
return $this->randomFromArray(['defaultAsset', 'sharedAsset', 'savingAsset']);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param array $array
|
|
||||||
*
|
|
||||||
* @return mixed
|
|
||||||
*/
|
|
||||||
private function randomFromArray(array $array)
|
|
||||||
{
|
|
||||||
return $array[rand(0, count($array) - 1)];
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return string
|
|
||||||
*/
|
|
||||||
protected function randomLiabilityType(): string
|
|
||||||
{
|
|
||||||
return $this->randomFromArray(['loan', 'debt', 'mortgage']);
|
|
||||||
}
|
|
||||||
}
|
|
@@ -23,136 +23,16 @@ declare(strict_types=1);
|
|||||||
|
|
||||||
namespace Tests\Traits;
|
namespace Tests\Traits;
|
||||||
|
|
||||||
use Exception;
|
|
||||||
use JsonException;
|
|
||||||
use Log;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Trait TestHelpers
|
* Trait TestHelpers
|
||||||
*/
|
*/
|
||||||
trait TestHelpers
|
trait TestHelpers
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* @return int
|
|
||||||
*/
|
|
||||||
public function randomInt(): int
|
|
||||||
{
|
|
||||||
$result = 4;
|
|
||||||
try {
|
|
||||||
$result = random_int(1, 100000);
|
|
||||||
} catch (Exception $e) {
|
|
||||||
Log::debug(sprintf('Could not generate random number: %s', $e->getMessage()));
|
|
||||||
}
|
|
||||||
|
|
||||||
return $result;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param array $minimalSets
|
|
||||||
* @param array $startOptionalSets
|
|
||||||
* @param array $regenConfig
|
|
||||||
*
|
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
protected function genericDataProvider(array $minimalSets, array $startOptionalSets, array $regenConfig): array
|
|
||||||
{
|
|
||||||
$submissions = [];
|
|
||||||
/**
|
|
||||||
* @var string $i
|
|
||||||
* @var array $set
|
|
||||||
*/
|
|
||||||
foreach ($minimalSets as $i => $set) {
|
|
||||||
$body = [];
|
|
||||||
foreach ($set['fields'] as $ii => $value) {
|
|
||||||
$body[$ii] = $value;
|
|
||||||
}
|
|
||||||
// minimal set is part of all submissions:
|
|
||||||
$submissions[] = [[
|
|
||||||
'fields' => $body,
|
|
||||||
'parameters' => $set['parameters'] ?? [],
|
|
||||||
'ignore' => $set['ignore'] ?? [],
|
|
||||||
]];
|
|
||||||
|
|
||||||
// then loop and add fields:
|
|
||||||
$optionalSets = $startOptionalSets;
|
|
||||||
$keys = array_keys($optionalSets);
|
|
||||||
$count = count($keys) > self::MAX_ITERATIONS ? self::MAX_ITERATIONS : count($keys);
|
|
||||||
for ($iii = 1; $iii <= $count; $iii++) {
|
|
||||||
$combinations = $this->combinationsOf($iii, $keys);
|
|
||||||
// expand body with N extra fields:
|
|
||||||
foreach ($combinations as $iv => $extraFields) {
|
|
||||||
$second = $body;
|
|
||||||
$ignore = $set['ignore'] ?? []; // unused atm.
|
|
||||||
foreach ($extraFields as $v => $extraField) {
|
|
||||||
// now loop optional sets on $extraField and add whatever the config is:
|
|
||||||
foreach ($optionalSets[$extraField]['fields'] as $vi => $newValue) {
|
|
||||||
// if the newValue is an array, we must merge it with whatever may
|
|
||||||
// or may not already be there. Its the optional field for one of the
|
|
||||||
// (maybe existing?) fields:
|
|
||||||
if (is_array($newValue) && array_key_exists($vi, $second) && is_array($second[$vi])) {
|
|
||||||
// loop $second[$vi] and merge it with whatever is in $newValue[$someIndex]
|
|
||||||
foreach ($second[$vi] as $vii => $iiValue) {
|
|
||||||
$second[$vi][$vii] = $iiValue + $newValue[$vii];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!is_array($newValue)) {
|
|
||||||
$second[$vi] = $newValue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (array_key_exists('remove_fields', $optionalSets[$extraField])) {
|
|
||||||
foreach ($optionalSets[$extraField]['remove_fields'] as $removed) {
|
|
||||||
unset($second[$removed]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$second = $this->regenerateValues($second, $regenConfig);
|
|
||||||
$submissions[] = [[
|
|
||||||
'fields' => $second,
|
|
||||||
'parameters' => $set['parameters'] ?? [],
|
|
||||||
'ignore' => $ignore,
|
|
||||||
]];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
unset($second);
|
|
||||||
}
|
|
||||||
|
|
||||||
return $submissions;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param $set
|
|
||||||
* @param $opts
|
|
||||||
*
|
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
protected function regenerateValues($set, $opts): array
|
|
||||||
{
|
|
||||||
foreach ($opts as $i => $func) {
|
|
||||||
if (array_key_exists($i, $set)) {
|
|
||||||
if (!is_array($set[$i])) {
|
|
||||||
$set[$i] = $func();
|
|
||||||
}
|
|
||||||
if (is_array($set[$i])) {
|
|
||||||
foreach ($set[$i] as $ii => $lines) {
|
|
||||||
foreach ($lines as $iii => $value) {
|
|
||||||
if (isset($opts[$i][$ii][$iii])) {
|
|
||||||
$set[$i][$ii][$iii] = $opts[$i][$ii][$iii]();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return $set;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $route
|
* @param string $route
|
||||||
* @param array $content
|
* @param array $content
|
||||||
*/
|
*/
|
||||||
protected function updatedStoreAndCompare(string $route, array $content): void
|
protected function assertPOST(string $route, array $content): void
|
||||||
{
|
{
|
||||||
$submission = $content['submission'];
|
$submission = $content['submission'];
|
||||||
$expected = $content['expected'];
|
$expected = $content['expected'];
|
||||||
@@ -168,7 +48,7 @@ trait TestHelpers
|
|||||||
|
|
||||||
// get return and compare each field
|
// get return and compare each field
|
||||||
$responseAttributes = $responseJson['data']['attributes'];
|
$responseAttributes = $responseJson['data']['attributes'];
|
||||||
$this->updatedCompareStorageArray($submission, $responseAttributes, $expected, $ignore);
|
$this->comparePOSTArray($submission, $responseAttributes, $expected, $ignore);
|
||||||
|
|
||||||
// ignore fields too!
|
// ignore fields too!
|
||||||
}
|
}
|
||||||
@@ -179,11 +59,11 @@ trait TestHelpers
|
|||||||
* @param array $expected
|
* @param array $expected
|
||||||
* @param array $ignore
|
* @param array $ignore
|
||||||
*/
|
*/
|
||||||
protected function updatedCompareStorageArray(array $submission, array $response, array $expected, array $ignore): void
|
private function comparePOSTArray(array $submission, array $response, array $expected, array $ignore): void
|
||||||
{
|
{
|
||||||
foreach ($response as $key => $value) {
|
foreach ($response as $key => $value) {
|
||||||
if (is_array($value) && array_key_exists($key, $expected) && is_array($expected[$key])) {
|
if (is_array($value) && array_key_exists($key, $expected) && is_array($expected[$key])) {
|
||||||
$this->updatedCompareStorageArray($submission, $value, $expected[$key], $ignore[$key] ?? []);
|
$this->comparePOSTArray($submission, $value, $expected[$key], $ignore[$key] ?? []);
|
||||||
}
|
}
|
||||||
if (isset($expected[$key])) {
|
if (isset($expected[$key])) {
|
||||||
if (in_array($key, $ignore, true)) {
|
if (in_array($key, $ignore, true)) {
|
||||||
@@ -202,13 +82,6 @@ trait TestHelpers
|
|||||||
|
|
||||||
$this->assertEquals($value, $expected[$key], $message);
|
$this->assertEquals($value, $expected[$key], $message);
|
||||||
}
|
}
|
||||||
|
|
||||||
// if($value !== $expected[$key]) {
|
|
||||||
// }
|
|
||||||
// var_dump($key);
|
|
||||||
// var_dump($value);
|
|
||||||
// var_dump($expected[$key]);
|
|
||||||
// exit;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -219,47 +92,7 @@ trait TestHelpers
|
|||||||
* @param string $route
|
* @param string $route
|
||||||
* @param array $content
|
* @param array $content
|
||||||
*/
|
*/
|
||||||
protected function storeAndCompare(string $route, array $content): void
|
protected function assertPUT(string $route, array $content): void
|
||||||
{
|
|
||||||
$submission = $content['fields'];
|
|
||||||
$parameters = $content['parameters'];
|
|
||||||
$ignore = $content['ignore'];
|
|
||||||
$response = $this->post(route($route, $parameters), $submission, ['Accept' => 'application/json']);
|
|
||||||
$responseBody = $response->content();
|
|
||||||
$responseJson = json_decode($responseBody, true);
|
|
||||||
$status = $response->getStatusCode();
|
|
||||||
$this->assertEquals($status, 200, sprintf("Submission:\n%s\nResponse: %s", json_encode($submission), $responseBody));
|
|
||||||
|
|
||||||
$response->assertHeader('Content-Type', 'application/vnd.api+json');
|
|
||||||
|
|
||||||
// compare results:
|
|
||||||
foreach ($responseJson['data']['attributes'] as $returnName => $returnValue) {
|
|
||||||
if (array_key_exists($returnName, $submission) && !in_array($returnName, $ignore, true)) {
|
|
||||||
// TODO still based on account routine:
|
|
||||||
if ($this->ignoreCombination($route, $submission['type'] ?? 'blank', $returnName)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
// check if is array, if so we need something smart:
|
|
||||||
if (is_array($returnValue) && is_array($submission[$returnName])) {
|
|
||||||
$this->compareArray($submission, $returnName, $submission[$returnName], $returnValue);
|
|
||||||
}
|
|
||||||
if (!is_array($returnValue) && !is_array($submission[$returnName])) {
|
|
||||||
$message = sprintf(
|
|
||||||
"Main: Return value '%s' of key '%s' does not match submitted value '%s'.\n%s\n%s", $returnValue, $returnName, $submission[$returnName],
|
|
||||||
json_encode($submission), $responseBody
|
|
||||||
);
|
|
||||||
$this->assertEquals($returnValue, $submission[$returnName], $message);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param string $route
|
|
||||||
* @param array $content
|
|
||||||
*/
|
|
||||||
protected function updatedUpdateAndCompare(string $route, array $content): void
|
|
||||||
{
|
{
|
||||||
$submission = $content['submission'];
|
$submission = $content['submission'];
|
||||||
$ignore = $content['ignore'];
|
$ignore = $content['ignore'];
|
||||||
@@ -272,21 +105,21 @@ trait TestHelpers
|
|||||||
|
|
||||||
// get return and compare each field
|
// get return and compare each field
|
||||||
$responseAttributes = $responseJson['data']['attributes'];
|
$responseAttributes = $responseJson['data']['attributes'];
|
||||||
$this->updatedCompareUpdatedArray($route, $submission, $responseAttributes, $ignore);
|
$this->comparePUTArray($route, $submission, $responseAttributes, $ignore);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $url
|
* @param string $url
|
||||||
* @param array $submission
|
* @param array $submission
|
||||||
* @param array $response
|
* @param array $response
|
||||||
* @param array $ignore
|
* @param array $ignore
|
||||||
*/
|
*/
|
||||||
private function updatedCompareUpdatedArray(string $url, array $submission, array $response, array $ignore): void
|
private function comparePUTArray(string $url, array $submission, array $response, array $ignore): void
|
||||||
{
|
{
|
||||||
|
|
||||||
foreach ($response as $key => $value) {
|
foreach ($response as $key => $value) {
|
||||||
if (is_array($value) && array_key_exists($key, $submission) && is_array($submission[$key])) {
|
if (is_array($value) && array_key_exists($key, $submission) && is_array($submission[$key])) {
|
||||||
$this->updatedCompareUpdatedArray($url, $submission[$key], $value, $ignore[$key] ?? []);
|
$this->comparePUTArray($url, $submission[$key], $value, $ignore[$key] ?? []);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($submission[$key])) {
|
if (isset($submission[$key])) {
|
||||||
@@ -310,162 +143,4 @@ trait TestHelpers
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Some specials:
|
|
||||||
*
|
|
||||||
* @param string $area
|
|
||||||
* @param string $left
|
|
||||||
* @param string $right
|
|
||||||
*
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
protected function ignoreCombination(string $area, string $left, string $right): bool
|
|
||||||
{
|
|
||||||
if ('api.v1.accounts.store' === $area) {
|
|
||||||
if ('expense' === $left
|
|
||||||
&& in_array($right, ['order', 'virtual_balance', 'opening_balance', 'opening_balance_date'])) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param string $route
|
|
||||||
* @param array $submission
|
|
||||||
*
|
|
||||||
* @throws JsonException
|
|
||||||
*/
|
|
||||||
protected function updateAndCompare(string $route, array $submission, array $ignored): void
|
|
||||||
{
|
|
||||||
// get original values:
|
|
||||||
$response = $this->get($route, ['Accept' => 'application/json']);
|
|
||||||
$status = $response->getStatusCode();
|
|
||||||
$this->assertEquals($status, 200, sprintf(sprintf('%s failed with 404.', $route)));
|
|
||||||
$response->assertStatus(200);
|
|
||||||
$originalString = $response->content();
|
|
||||||
$originalArray = json_decode($originalString, true, 512, JSON_THROW_ON_ERROR);
|
|
||||||
$originalAttributes = $originalArray['data']['attributes'];
|
|
||||||
// submit whatever is in submission:
|
|
||||||
// loop the fields we will update in Firefly III:
|
|
||||||
$submissionArray = [];
|
|
||||||
$fieldsToUpdate = array_keys($submission['fields']);
|
|
||||||
foreach ($fieldsToUpdate as $currentFieldName) {
|
|
||||||
$submissionArray[$currentFieldName] = $submission['fields'][$currentFieldName]['test_value'];
|
|
||||||
}
|
|
||||||
|
|
||||||
Log::debug(sprintf('Will PUT %s to %s', json_encode($submissionArray), $route));
|
|
||||||
|
|
||||||
$response = $this->put($route, $submissionArray, ['Accept' => 'application/json']);
|
|
||||||
$responseString = $response->content();
|
|
||||||
$status = $response->getStatusCode();
|
|
||||||
$this->assertEquals($status, 200, sprintf("Submission: %s\nResponse: %s", json_encode($submissionArray), $responseString));
|
|
||||||
//$response->assertStatus(200);
|
|
||||||
$responseArray = json_decode($responseString, true, 512, JSON_THROW_ON_ERROR);
|
|
||||||
$responseAttributes = $responseArray['data']['attributes'] ?? [];
|
|
||||||
|
|
||||||
Log::debug(sprintf('Before: %s', json_encode($originalAttributes)));
|
|
||||||
Log::debug(sprintf('AFTER : %s', json_encode($responseAttributes)));
|
|
||||||
|
|
||||||
// loop it and compare:
|
|
||||||
foreach ($responseAttributes as $rKey => $rValue) {
|
|
||||||
// field should be ignored?
|
|
||||||
if (in_array($rKey, $ignored) || in_array($rKey, $submission['extra_ignore'])) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
// field in response was also in body:
|
|
||||||
if (array_key_exists($rKey, $submissionArray)) {
|
|
||||||
// comparison must be on array:
|
|
||||||
if (is_array($submissionArray[$rKey]) && is_array($rValue)) {
|
|
||||||
$this->compareArray($submissionArray, $rKey, $submissionArray[$rKey], $rValue);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!is_array($submissionArray[$rKey]) && !is_array($rValue)) {
|
|
||||||
if ($submissionArray[$rKey] !== $rValue) {
|
|
||||||
|
|
||||||
$message = sprintf(
|
|
||||||
"Expected field '%s' to be %s but its %s\nOriginal: %s\nSubmission: %s\nResult: %s",
|
|
||||||
$rKey,
|
|
||||||
var_export($submissionArray[$rKey], true),
|
|
||||||
var_export($rValue, true),
|
|
||||||
$originalString,
|
|
||||||
json_encode($submissionArray),
|
|
||||||
$responseString
|
|
||||||
);
|
|
||||||
$this->assertTrue(false, $message);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
// field in response was not in body, but should be the same:
|
|
||||||
if (!array_key_exists($rKey, $submissionArray)) {
|
|
||||||
// original has this key too:
|
|
||||||
if (array_key_exists($rKey, $originalAttributes)) {
|
|
||||||
// but we can ignore it!
|
|
||||||
if (in_array($rKey, $submission['extra_ignore'])) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
// but it is different?
|
|
||||||
if ($originalAttributes[$rKey] !== $rValue) {
|
|
||||||
$message = sprintf(
|
|
||||||
"Untouched field '%s' should still be %s but changed to %s\nOriginal: %s\nSubmission: %s\nResult: %s",
|
|
||||||
$rKey,
|
|
||||||
var_export($originalAttributes[$rKey], true),
|
|
||||||
var_export($rValue, true),
|
|
||||||
$originalString,
|
|
||||||
json_encode($submissionArray),
|
|
||||||
$responseString
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
$this->assertTrue(false, $message);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param array $fullOriginal
|
|
||||||
* @param string $key
|
|
||||||
* @param array $original
|
|
||||||
* @param array $returned
|
|
||||||
*/
|
|
||||||
protected function compareArray(array $fullOriginal, string $key, array $original, array $returned)
|
|
||||||
{
|
|
||||||
// TODO this should be configurable but OK
|
|
||||||
if (in_array($key, ['transactions', 'repetitions'], true) && 0 === count($original) && 0 !== count($returned)) {
|
|
||||||
// accept this.
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
$ignore = ['id', 'created_at', 'updated_at'];
|
|
||||||
foreach ($returned as $objectKey => $object) {
|
|
||||||
// each object is a transaction, a rule trigger, a rule action, whatever.
|
|
||||||
// assume the original also contains this key:
|
|
||||||
if (!array_key_exists($objectKey, $original)) {
|
|
||||||
$message = sprintf('Sub: Original array "%s" does not have returned key %d.', $key, $objectKey);
|
|
||||||
$this->assertTrue(false, $message);
|
|
||||||
}
|
|
||||||
|
|
||||||
foreach ($object as $returnKey => $returnValue) {
|
|
||||||
if (in_array($returnKey, $ignore, true)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (array_key_exists($returnKey, $original[$objectKey])) {
|
|
||||||
$message = sprintf(
|
|
||||||
"Sub-array '%s' returned value %s does not match sent value %s.\n%s\n%s",
|
|
||||||
$key, var_export($returnValue, true), var_export($original[$objectKey][$returnKey], true),
|
|
||||||
json_encode($fullOriginal),
|
|
||||||
json_encode($returned),
|
|
||||||
);
|
|
||||||
$this->assertEquals($original[$objectKey][$returnKey], $returnValue, $message);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user