Files
archived-orm/tests/Tests/ORM/Repository/DefaultRepositoryFactoryTest.php
Grégoire Paris 9d5f112c7e Migrate to willReturn()
self::returnValue() and self::onConsecutiveCalls() has been deprecated.
2025-08-21 13:39:48 +02:00

130 lines
4.4 KiB
PHP

<?php
declare(strict_types=1);
namespace Doctrine\Tests\ORM\Repository;
use Doctrine\ORM\Configuration;
use Doctrine\ORM\EntityManagerInterface;
use Doctrine\ORM\Mapping\ClassMetadata;
use Doctrine\ORM\Repository\DefaultRepositoryFactory;
use Doctrine\Tests\Models\DDC753\DDC753DefaultRepository;
use Doctrine\Tests\Models\DDC753\DDC753EntityWithDefaultCustomRepository;
use Doctrine\Tests\Models\DDC869\DDC869PaymentRepository;
use PHPUnit\Framework\Attributes\CoversClass;
use PHPUnit\Framework\MockObject\MockObject;
use PHPUnit\Framework\TestCase;
/**
* Tests for {@see \Doctrine\ORM\Repository\DefaultRepositoryFactory}
*/
#[CoversClass(DefaultRepositoryFactory::class)]
class DefaultRepositoryFactoryTest extends TestCase
{
private EntityManagerInterface&MockObject $entityManager;
private Configuration&MockObject $configuration;
private DefaultRepositoryFactory $repositoryFactory;
protected function setUp(): void
{
$this->configuration = $this->createMock(Configuration::class);
$this->entityManager = $this->createEntityManager();
$this->repositoryFactory = new DefaultRepositoryFactory();
$this->configuration
->expects(self::any())
->method('getDefaultRepositoryClassName')
->willReturn(DDC869PaymentRepository::class);
}
public function testCreatesRepositoryFromDefaultRepositoryClass(): void
{
$this->entityManager
->expects(self::any())
->method('getClassMetadata')
->willReturnCallback($this->buildClassMetadata(...));
self::assertInstanceOf(
DDC869PaymentRepository::class,
$this->repositoryFactory->getRepository($this->entityManager, self::class),
);
}
public function testCreatedRepositoriesAreCached(): void
{
$this->entityManager
->expects(self::any())
->method('getClassMetadata')
->willReturnCallback($this->buildClassMetadata(...));
self::assertSame(
$this->repositoryFactory->getRepository($this->entityManager, self::class),
$this->repositoryFactory->getRepository($this->entityManager, self::class),
);
}
public function testCreatesRepositoryFromCustomClassMetadata(): void
{
$customMetadata = $this->buildClassMetadata(DDC753EntityWithDefaultCustomRepository::class);
$customMetadata->customRepositoryClassName = DDC753DefaultRepository::class;
$this->entityManager
->expects(self::any())
->method('getClassMetadata')
->willReturn($customMetadata);
self::assertInstanceOf(
DDC753DefaultRepository::class,
$this->repositoryFactory->getRepository($this->entityManager, self::class),
);
}
public function testCachesDistinctRepositoriesPerDistinctEntityManager(): void
{
$em1 = $this->createEntityManager();
$em2 = $this->createEntityManager();
$em1->expects(self::any())
->method('getClassMetadata')
->willReturnCallback($this->buildClassMetadata(...));
$em2->expects(self::any())
->method('getClassMetadata')
->willReturnCallback($this->buildClassMetadata(...));
$repo1 = $this->repositoryFactory->getRepository($em1, self::class);
$repo2 = $this->repositoryFactory->getRepository($em2, self::class);
self::assertSame($repo1, $this->repositoryFactory->getRepository($em1, self::class));
self::assertSame($repo2, $this->repositoryFactory->getRepository($em2, self::class));
self::assertNotSame($repo1, $repo2);
}
/**
* @param class-string<TEntity> $className
*
* @return ClassMetadata<TEntity>&MockObject
*
* @template TEntity of object
*/
private function buildClassMetadata(string $className): ClassMetadata&MockObject
{
$metadata = $this->createMock(ClassMetadata::class);
$metadata->method('getName')->willReturn($className);
$metadata->name = $className;
$metadata->customRepositoryClassName = null;
return $metadata;
}
private function createEntityManager(): EntityManagerInterface&MockObject
{
$entityManager = $this->createMock(EntityManagerInterface::class);
$entityManager->method('getConfiguration')->willReturn($this->configuration);
return $entityManager;
}
}