From ee4b03aa788840d090a915c83029b1d8f7d75d62 Mon Sep 17 00:00:00 2001 From: "Alexander M. Turek" Date: Tue, 21 May 2024 12:30:16 +0200 Subject: [PATCH 1/2] Backport test for Query::setLockMode() (#11463) --- tests/Tests/ORM/Query/QueryTest.php | 30 +++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/tests/Tests/ORM/Query/QueryTest.php b/tests/Tests/ORM/Query/QueryTest.php index 7a1ffa0d702..b1c72f4ad14 100644 --- a/tests/Tests/ORM/Query/QueryTest.php +++ b/tests/Tests/ORM/Query/QueryTest.php @@ -13,10 +13,13 @@ use Doctrine\DBAL\ArrayParameterType; use Doctrine\DBAL\Cache\QueryCacheProfile; use Doctrine\DBAL\Connection; +use Doctrine\DBAL\LockMode; use Doctrine\DBAL\ParameterType; use Doctrine\DBAL\Types\Types; use Doctrine\Deprecations\PHPUnit\VerifyDeprecations; +use Doctrine\ORM\EntityManagerInterface; use Doctrine\ORM\Internal\Hydration\IterableResult; +use Doctrine\ORM\Query; use Doctrine\ORM\Query\Parameter; use Doctrine\ORM\Query\QueryException; use Doctrine\ORM\UnitOfWork; @@ -88,6 +91,33 @@ public function testSetParameters(): void self::assertEquals($parameters, $query->getParameters()); } + /** + * @psalm-param LockMode::* $lockMode + * + * @dataProvider provideLockModes + */ + public function testSetLockMode(int $lockMode): void + { + $query = $this->entityManager->wrapInTransaction(static function (EntityManagerInterface $em) use ($lockMode): Query { + $query = $em->createQuery('select u from Doctrine\Tests\Models\CMS\CmsUser u where u.username = ?1'); + $query->setLockMode($lockMode); + + return $query; + }); + + self::assertSame($lockMode, $query->getLockMode()); + self::assertSame($lockMode, $query->getHint(Query::HINT_LOCK_MODE)); + } + + /** @psalm-return list */ + public static function provideLockModes(): array + { + return [ + [LockMode::PESSIMISTIC_READ], + [LockMode::PESSIMISTIC_WRITE], + ]; + } + public function testFree(): void { $query = $this->entityManager->createQuery('select u from Doctrine\Tests\Models\CMS\CmsUser u where u.username = ?1'); From 552eae37a3bada11e5262e9dc860167c95e9b1b1 Mon Sep 17 00:00:00 2001 From: "Alexander M. Turek" Date: Tue, 21 May 2024 12:30:36 +0200 Subject: [PATCH 2/2] Test with actual lock modes (#11465) --- .../Entity/EntityPersisterTestCase.php | 21 +++++++++++++------ 1 file changed, 15 insertions(+), 6 deletions(-) diff --git a/tests/Tests/ORM/Cache/Persister/Entity/EntityPersisterTestCase.php b/tests/Tests/ORM/Cache/Persister/Entity/EntityPersisterTestCase.php index 6b5ea40a589..9294df28e15 100644 --- a/tests/Tests/ORM/Cache/Persister/Entity/EntityPersisterTestCase.php +++ b/tests/Tests/ORM/Cache/Persister/Entity/EntityPersisterTestCase.php @@ -6,6 +6,7 @@ use Doctrine\Common\Collections\ArrayCollection; use Doctrine\Common\Collections\Criteria; +use Doctrine\DBAL\LockMode; use Doctrine\ORM\Cache\Persister\CachedPersister; use Doctrine\ORM\Cache\Persister\Entity\AbstractEntityPersister; use Doctrine\ORM\Cache\Persister\Entity\CachedEntityPersister; @@ -99,7 +100,7 @@ public function testInvokeGetSelectSQL(): void ->with( self::identicalTo(['name' => 'Foo']), self::identicalTo([0]), - self::identicalTo(1), + self::identicalTo(LockMode::OPTIMISTIC), self::identicalTo(2), self::identicalTo(3), self::identicalTo([4]) @@ -109,7 +110,7 @@ public function testInvokeGetSelectSQL(): void self::assertSame('SELECT * FROM foo WERE name = ?', $persister->getSelectSQL( ['name' => 'Foo'], [0], - 1, + LockMode::OPTIMISTIC, 2, 3, [4] @@ -228,13 +229,21 @@ public function testInvokeLoad(): void self::identicalTo($entity), self::identicalTo([0]), self::identicalTo([1]), - self::identicalTo(2), + self::identicalTo(LockMode::PESSIMISTIC_READ), self::identicalTo(3), self::identicalTo([4]) ) ->willReturn($entity); - self::assertSame($entity, $persister->load(['id' => 1], $entity, [0], [1], 2, 3, [4])); + self::assertSame($entity, $persister->load( + ['id' => 1], + $entity, + [0], + [1], + LockMode::PESSIMISTIC_READ, + 3, + [4] + )); } public function testInvokeLoadAll(): void @@ -391,9 +400,9 @@ public function testInvokeLock(): void $this->entityPersister->expects(self::once()) ->method('lock') - ->with(self::identicalTo($identifier), self::identicalTo(1)); + ->with(self::identicalTo($identifier), self::identicalTo(LockMode::OPTIMISTIC)); - $persister->lock($identifier, 1); + $persister->lock($identifier, LockMode::OPTIMISTIC); } public function testInvokeExists(): void