From 22e32b9952e911d5a11da029f66e50cfb5aac51a Mon Sep 17 00:00:00 2001 From: thomasowow <45201651+thomasowow@users.noreply.github.com> Date: Thu, 27 Jan 2022 19:25:36 +0100 Subject: [PATCH] [8.x] Added class and method to create cross joined sequences for factories (#40542) * Added class to create matrix sequences for factories * Fix for php7.3 support * Rename MatrixSequence to CrossJoinSequence. Add crossJoinSequence method to Factory. * Fix import order lint failure. --- .../Eloquent/Factories/CrossJoinSequence.php | 26 ++++++++++++ .../Database/Eloquent/Factories/Factory.php | 11 +++++ .../Database/DatabaseEloquentFactoryTest.php | 40 +++++++++++++++++++ 3 files changed, 77 insertions(+) create mode 100644 src/Illuminate/Database/Eloquent/Factories/CrossJoinSequence.php diff --git a/src/Illuminate/Database/Eloquent/Factories/CrossJoinSequence.php b/src/Illuminate/Database/Eloquent/Factories/CrossJoinSequence.php new file mode 100644 index 000000000000..b0efbd0c805b --- /dev/null +++ b/src/Illuminate/Database/Eloquent/Factories/CrossJoinSequence.php @@ -0,0 +1,26 @@ +state(new Sequence(...$sequence)); } + /** + * Add a new cross joined sequenced state transformation to the model definition. + * + * @param array $sequence + * @return static + */ + public function crossJoinSequence(...$sequence) + { + return $this->state(new CrossJoinSequence(...$sequence)); + } + /** * Define a child relationship for the model. * diff --git a/tests/Database/DatabaseEloquentFactoryTest.php b/tests/Database/DatabaseEloquentFactoryTest.php index f30276d06ffd..3b7e28217b49 100644 --- a/tests/Database/DatabaseEloquentFactoryTest.php +++ b/tests/Database/DatabaseEloquentFactoryTest.php @@ -7,6 +7,7 @@ use Illuminate\Contracts\Foundation\Application; use Illuminate\Database\Capsule\Manager as DB; use Illuminate\Database\Eloquent\Collection; +use Illuminate\Database\Eloquent\Factories\CrossJoinSequence; use Illuminate\Database\Eloquent\Factories\Factory; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Factories\Sequence; @@ -413,6 +414,45 @@ public function test_sequences() $this->assertSame('index: 1', $users[1]->name); } + public function test_cross_join_sequences() + { + $assert = function ($users) { + $assertions = [ + ['first_name' => 'Thomas', 'last_name' => 'Anderson'], + ['first_name' => 'Thomas', 'last_name' => 'Smith'], + ['first_name' => 'Agent', 'last_name' => 'Anderson'], + ['first_name' => 'Agent', 'last_name' => 'Smith'], + ]; + + foreach ($assertions as $key => $assertion) { + $this->assertSame( + $assertion, + $users[$key]->only('first_name', 'last_name'), + ); + } + }; + + $usersByClass = FactoryTestUserFactory::times(4) + ->state( + new CrossJoinSequence( + [['first_name' => 'Thomas'], ['first_name' => 'Agent']], + [['last_name' => 'Anderson'], ['last_name' => 'Smith']], + ), + ) + ->make(); + + $assert($usersByClass); + + $usersByMethod = FactoryTestUserFactory::times(4) + ->crossJoinSequence( + [['first_name' => 'Thomas'], ['first_name' => 'Agent']], + [['last_name' => 'Anderson'], ['last_name' => 'Smith']], + ) + ->make(); + + $assert($usersByMethod); + } + public function test_resolve_nested_model_factories() { Factory::useNamespace('Factories\\');