From 42a0cbe8c31ad29fd2be254f81a5141e79e391f6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gr=C3=A9goire=20Paris?= Date: Fri, 29 Nov 2024 09:01:12 +0100 Subject: [PATCH 1/2] Use proper namespace --- tests/Purger/ORMPurgerFactoryTest.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/Purger/ORMPurgerFactoryTest.php b/tests/Purger/ORMPurgerFactoryTest.php index 7f4b9c4..e14885b 100644 --- a/tests/Purger/ORMPurgerFactoryTest.php +++ b/tests/Purger/ORMPurgerFactoryTest.php @@ -2,7 +2,7 @@ declare(strict_types=1); -namespace Purger; +namespace Doctrine\Bundle\FixturesBundle\Tests\Purger; use Doctrine\Bundle\FixturesBundle\Purger\ORMPurgerFactory; use Doctrine\Common\DataFixtures\Purger\ORMPurger; From cccda85e7af89ea619f4bd97c0f9ac1a6a4d4dcc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gr=C3=A9goire=20Paris?= Date: Thu, 28 Nov 2024 13:51:09 +0100 Subject: [PATCH 2/2] Make PurgerFactory generic This allows us to remove assertions and natively provide the right type information. --- phpstan-baseline.neon | 2 +- src/Command/LoadDataFixturesDoctrineCommand.php | 5 ++--- src/Purger/ORMPurgerFactory.php | 1 + src/Purger/PurgerFactory.php | 7 ++++++- tests/Purger/ORMPurgerFactoryTest.php | 8 -------- 5 files changed, 10 insertions(+), 13 deletions(-) diff --git a/phpstan-baseline.neon b/phpstan-baseline.neon index 5d69bf4..3c8e28b 100644 --- a/phpstan-baseline.neon +++ b/phpstan-baseline.neon @@ -1,7 +1,7 @@ parameters: ignoreErrors: - - message: "#^Method class@anonymous/src/Command/LoadDataFixturesDoctrineCommand\\.php\\:121\\:\\:log\\(\\) has parameter \\$message with no type specified\\.$#" + message: "#^Method class@anonymous/src/Command/LoadDataFixturesDoctrineCommand\\.php\\:120\\:\\:log\\(\\) has parameter \\$message with no type specified\\.$#" count: 1 path: src/Command/LoadDataFixturesDoctrineCommand.php diff --git a/src/Command/LoadDataFixturesDoctrineCommand.php b/src/Command/LoadDataFixturesDoctrineCommand.php index 9744621..ee07bdc 100644 --- a/src/Command/LoadDataFixturesDoctrineCommand.php +++ b/src/Command/LoadDataFixturesDoctrineCommand.php @@ -10,7 +10,6 @@ use Doctrine\Bundle\FixturesBundle\Purger\ORMPurgerFactory; use Doctrine\Bundle\FixturesBundle\Purger\PurgerFactory; use Doctrine\Common\DataFixtures\Executor\ORMExecutor; -use Doctrine\Common\DataFixtures\Purger\ORMPurgerInterface; use Doctrine\ORM\EntityManagerInterface; use Doctrine\Persistence\ManagerRegistry; use Psr\Log\AbstractLogger; @@ -32,6 +31,7 @@ class LoadDataFixturesDoctrineCommand extends DoctrineCommand public function __construct( private SymfonyFixturesLoader $fixturesLoader, ManagerRegistry $doctrine, + /** @var array $purgerFactories */ private array $purgerFactories = [], ) { parent::__construct($doctrine); @@ -110,13 +110,12 @@ protected function execute(InputInterface $input, OutputInterface $output): int $factory = $this->purgerFactories[$input->getOption('purger')]; } - $purger = $factory->createForEntityManager( + $purger = $factory->createForEntityManager( $input->getOption('em'), $em, $input->getOption('purge-exclusions'), $input->getOption('purge-with-truncate'), ); - assert($purger instanceof ORMPurgerInterface); $executor = new ORMExecutor($em, $purger); $executor->setLogger(new class ($ui) extends AbstractLogger { public function __construct(private SymfonyStyle $ui) diff --git a/src/Purger/ORMPurgerFactory.php b/src/Purger/ORMPurgerFactory.php index 70f064d..bae9164 100644 --- a/src/Purger/ORMPurgerFactory.php +++ b/src/Purger/ORMPurgerFactory.php @@ -7,6 +7,7 @@ use Doctrine\Common\DataFixtures\Purger\ORMPurger; use Doctrine\ORM\EntityManagerInterface; +/** @template-implements PurgerFactory */ final class ORMPurgerFactory implements PurgerFactory { /** diff --git a/src/Purger/PurgerFactory.php b/src/Purger/PurgerFactory.php index 86410e5..c6b96e4 100644 --- a/src/Purger/PurgerFactory.php +++ b/src/Purger/PurgerFactory.php @@ -7,9 +7,14 @@ use Doctrine\Common\DataFixtures\Purger\PurgerInterface; use Doctrine\ORM\EntityManagerInterface; +/** @template T of PurgerInterface */ interface PurgerFactory { - /** @phpstan-param list $excluded */ + /** + * @phpstan-param list $excluded + * + * @return T + */ public function createForEntityManager( string|null $emName, EntityManagerInterface $em, diff --git a/tests/Purger/ORMPurgerFactoryTest.php b/tests/Purger/ORMPurgerFactoryTest.php index e14885b..fea0995 100644 --- a/tests/Purger/ORMPurgerFactoryTest.php +++ b/tests/Purger/ORMPurgerFactoryTest.php @@ -10,8 +10,6 @@ use PHPUnit\Framework\MockObject\MockObject; use PHPUnit\Framework\TestCase; -use function assert; - class ORMPurgerFactoryTest extends TestCase { private ORMPurgerFactory $factory; @@ -28,9 +26,7 @@ protected function setUp(): void public function testCreateDefault(): void { $purger = $this->factory->createForEntityManager(null, $this->em); - assert($purger instanceof ORMPurger); - self::assertInstanceOf(ORMPurger::class, $purger); self::assertSame(ORMPurger::PURGE_MODE_DELETE, $purger->getPurgeMode()); self::assertSame([], (function () { return $this->excluded; @@ -40,9 +36,7 @@ public function testCreateDefault(): void public function testCreateWithExclusions(): void { $purger = $this->factory->createForEntityManager(null, $this->em, ['tableName']); - assert($purger instanceof ORMPurger); - self::assertInstanceOf(ORMPurger::class, $purger); self::assertSame(ORMPurger::PURGE_MODE_DELETE, $purger->getPurgeMode()); self::assertSame(['tableName'], (function () { return $this->excluded; @@ -52,9 +46,7 @@ public function testCreateWithExclusions(): void public function testCreateWithTruncate(): void { $purger = $this->factory->createForEntityManager(null, $this->em, [], true); - assert($purger instanceof ORMPurger); - self::assertInstanceOf(ORMPurger::class, $purger); self::assertSame(ORMPurger::PURGE_MODE_TRUNCATE, $purger->getPurgeMode()); self::assertSame([], (function () { return $this->excluded;