Skip to content

Commit

Permalink
Fix for BC break doctrine#7366 when calling EM::find() with LockMode:…
Browse files Browse the repository at this point in the history
…:OPTIMISTIC outside of a TX
  • Loading branch information
timdev authored and Majkl578 committed Sep 23, 2018
1 parent 2f52024 commit 8cec92a
Show file tree
Hide file tree
Showing 2 changed files with 78 additions and 1 deletion.
2 changes: 1 addition & 1 deletion lib/Doctrine/ORM/EntityManager.php
Original file line number Diff line number Diff line change
Expand Up @@ -904,7 +904,7 @@ private function checkLockRequirements(int $lockMode, ClassMetadata $class) : vo
if (! $class->isVersioned()) {
throw OptimisticLockException::notVersioned($class->getClassName());
}
// Intentional fallthrough
break;
case LockMode::PESSIMISTIC_READ:
case LockMode::PESSIMISTIC_WRITE:
if (! $this->getConnection()->isTransactionActive()) {
Expand Down
77 changes: 77 additions & 0 deletions tests/Doctrine/Tests/ORM/Functional/Ticket/GH7366Test.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,77 @@
<?php

declare(strict_types=1);

namespace Doctrine\Tests\ORM\Functional\Ticket;

use Doctrine\DBAL\LockMode;
use Doctrine\ORM\TransactionRequiredException;
use Doctrine\Tests\OrmFunctionalTestCase;

final class GH7366Test extends OrmFunctionalTestCase
{
/**
* {@inheritDoc}
*/
protected function setUp() : void
{
parent::setUp();

$this->setUpEntitySchema(
[
GH7366Entity::class,
]
);

$this->_em->persist(new GH7366Entity('baz'));
$this->_em->flush();
$this->_em->clear();
}

public function testOptimisticLockNoExceptionOnFind() : void
{
try {
$entity = $this->_em->find(GH7366Entity::class, 1, LockMode::OPTIMISTIC);
} catch (TransactionRequiredException $e) {
self::fail('EntityManager::find() threw TransactionRequiredException with LockMode::OPTIMISTIC');
}
self::assertEquals('baz', $entity->getName());
}
}

/**
* @Entity
*/
class GH7366Entity
{
/**
* @Id
* @Column(type="integer")
* @GeneratedValue
* @var int
*/
public $id;

/**
* @Column(type="integer")
* @Version
*/
protected $lockVersion = 1;

/**
* @Column(length=32)
* @var string
*/
protected $name;


public function __construct(string $name)
{
$this->name = $name;
}

public function getName() : string
{
return $this->name;
}
}

0 comments on commit 8cec92a

Please sign in to comment.