|
23 | 23 | use Zenstruck\Foundry\Tests\Fixture\DoctrineCascadeRelationship\ChangesEntityRelationshipCascadePersist;
|
24 | 24 | use Zenstruck\Foundry\Tests\Fixture\DoctrineCascadeRelationship\UsingRelationships;
|
25 | 25 | use Zenstruck\Foundry\Tests\Fixture\Entity\EdgeCases\IndexedOneToMany;
|
| 26 | +use Zenstruck\Foundry\Tests\Fixture\Entity\EdgeCases\InversedOneToOneWithManyToOne; |
26 | 27 | use Zenstruck\Foundry\Tests\Fixture\Entity\EdgeCases\InversedOneToOneWithNonNullableOwning;
|
27 | 28 | use Zenstruck\Foundry\Tests\Fixture\Entity\EdgeCases\InversedOneToOneWithOneToMany;
|
28 | 29 | use Zenstruck\Foundry\Tests\Fixture\Entity\EdgeCases\InversedOneToOneWithSetter;
|
@@ -160,6 +161,34 @@ public function indexed_one_to_many(): void
|
160 | 161 | self::assertNotNull($parent->getItems()->get('en')); // @phpstan-ignore argument.type
|
161 | 162 | }
|
162 | 163 |
|
| 164 | + /** @test */ |
| 165 | + #[Test] |
| 166 | + #[DataProvider('provideCascadeRelationshipsCombinations')] |
| 167 | + #[UsingRelationships(InversedOneToOneWithManyToOne\InverseSide::class, ['owningSide', 'item'])] |
| 168 | + #[RequiresPhpunit('>=11.4')] |
| 169 | + public function inversed_one_to_one_can_be_used_after_other_relationship(): void |
| 170 | + { |
| 171 | + $inverseSideFactory = persistent_factory(InversedOneToOneWithManyToOne\InverseSide::class); |
| 172 | + $owningSideFactory = persistent_factory(InversedOneToOneWithManyToOne\OwningSide::class); |
| 173 | + $itemFactory = persistent_factory(InversedOneToOneWithManyToOne\Item::class); |
| 174 | + |
| 175 | + $inverseSide = $inverseSideFactory->create( |
| 176 | + [ |
| 177 | + 'mandatoryField' => 'foo', |
| 178 | + 'owningSide' => $owningSideFactory, |
| 179 | + 'item' => $itemFactory, |
| 180 | + ] |
| 181 | + ); |
| 182 | + |
| 183 | + $inverseSideFactory::assert()->count(1); |
| 184 | + $owningSideFactory::assert()->count(1); |
| 185 | + $itemFactory::assert()->count(1); |
| 186 | + |
| 187 | + self::assertNotNull($inverseSide->owningSide); |
| 188 | + self::assertSame($inverseSide, $inverseSide->owningSide->inverseSide); |
| 189 | + self::assertNotNull($inverseSide->item); |
| 190 | + } |
| 191 | + |
163 | 192 | /** @test */
|
164 | 193 | #[Test]
|
165 | 194 | public function object_with_union_type(): void
|
|
0 commit comments