diff --git a/.github/workflows/test-application.yaml b/.github/workflows/test-application.yaml index 036e636..ed9fb0d 100644 --- a/.github/workflows/test-application.yaml +++ b/.github/workflows/test-application.yaml @@ -20,24 +20,23 @@ jobs: strategy: fail-fast: false matrix: - symfony-version: - - '*' include: - - php-version: '7.1' + - php-version: '7.2' dependencies: 'lowest' - symfony-version: '^3.4' + symfony-version: '^5.4' symfony-deprecation-helper: 'weak' - - - php-version: '7.2' - php-version: '7.3' + symfony-version: '*' - php-version: '7.4' - symfony-version: '^4.4' - - php-version: '7.4' - symfony-version: '5.0.*' - - php-version: '8.0' + symfony-version: '^5.4' - php-version: '8.0' symfony-version: '6.0.*' - + - php-version: '8.1' + symfony-version: '^6.4' + - php-version: '8.2' + symfony-version: '*' + - php-version: '8.3' + symfony-version: '*' steps: - name: Checkout project uses: actions/checkout@v2 diff --git a/CHANGELOG.md b/CHANGELOG.md index e5fcb3e..c9ecca6 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,10 +4,11 @@ Changelog 4.x === -4.4.3 +4.5.0 ----- * Support phpcr-bundle 3. +* Drop support for Symfony < 5.4 4.4.2 ----- diff --git a/composer.json b/composer.json index f910041..3052bd5 100644 --- a/composer.json +++ b/composer.json @@ -9,22 +9,26 @@ } ], "require": { - "php": "^7.1|^8.0", + "php": "^7.2|^8.0", "doctrine/data-fixtures": "^1.2", - "symfony/browser-kit": "^3.4.26 || ^4.3.8 || ^5.0 || ^6.0" + "symfony/browser-kit": "^5.4 || ^6.0 || ^7.0" }, "require-dev": { "doctrine/doctrine-bundle": "^1.8 || ^2.0", "doctrine/phpcr-bundle": "^1.3 || ^2.0 || ^3.0", - "symfony/console": "^3.4.26 || ^4.3.8 || ^5.0 || ^6.0", - "symfony/dependency-injection": "^3.4.26 || ^4.3.8 || ^5.0 || ^6.0", - "symfony/doctrine-bridge": "^3.4.26 || ^4.3.8 || ^5.0 || ^6.0", - "symfony/framework-bundle": "^3.4.26 || ^4.3.8 || ^5.0 || ^6.0", - "symfony/http-kernel": "^3.4.26 || ^4.3.8 || ^5.0 || ^6.0", + "symfony/console": "^5.4 || ^6.0 || ^7.0", + "symfony/dependency-injection": "^5.4 || ^6.0 || ^7.0", + "symfony/doctrine-bridge": "^5.4 || ^6.0 || ^7.0", + "symfony/framework-bundle": "^5.4 || ^6.0 || ^7.0", + "symfony/http-kernel": "^5.4 || ^6.0 || ^7.0", "symfony/monolog-bundle": "^3.5", - "symfony/security-bundle": "^3.4.26 || ^4.3.8 || ^5.0 || ^6.0", - "symfony/twig-bundle": "^3.4.26 || ^4.3.8 || ^5.0 || ^6.0", - "symfony/phpunit-bridge": "^5.4" + "symfony/security-bundle": "^5.4 || ^6.0 || ^7.0", + "symfony/twig-bundle": "^5.4 || ^6.0 || ^7.0", + "symfony/phpunit-bridge": "^7.0.6", + "symfony/yaml": "^5.4 || ^6.0 || ^7.0" + }, + "conflict": { + "symfony/framework-bundle": "<5.4" }, "autoload": { "psr-4": { diff --git a/resources/config/dist/framework.php b/resources/config/dist/framework.php index e1a05e4..c3a9588 100644 --- a/resources/config/dist/framework.php +++ b/resources/config/dist/framework.php @@ -16,7 +16,7 @@ $config = [ 'secret' => 'test', - 'test' => null, + 'test' => true, 'form' => true, 'validation' => [ 'enabled' => true, diff --git a/src/Functional/BaseTestCase.php b/src/Functional/BaseTestCase.php index 9733efa..845ba68 100644 --- a/src/Functional/BaseTestCase.php +++ b/src/Functional/BaseTestCase.php @@ -18,7 +18,6 @@ use Symfony\Cmf\Component\Testing\Functional\DbManager\ORM; use Symfony\Cmf\Component\Testing\Functional\DbManager\PHPCR; use Symfony\Cmf\Component\Testing\Functional\DbManager\PhpcrDecorator; -use Symfony\Component\DependencyInjection\ContainerInterface; use Symfony\Component\HttpFoundation\Response; use Symfony\Component\HttpKernel\KernelInterface; @@ -80,18 +79,6 @@ protected static function bootKernel(array $options = []): KernelInterface return parent::bootKernel(static::getKernelConfiguration()); } - /** - * BC with Symfony < 5.3 - when minimum version raises to ^5.3, we can remove this method. - */ - protected static function getContainer(): ContainerInterface - { - if (method_exists(KernelTestCase::class, 'getContainer')) { - return parent::getContainer(); - } - - return self::getKernel()->getContainer(); - } - protected static function getKernel(): KernelInterface { if (null === static::$kernel) { @@ -100,9 +87,7 @@ protected static function getKernel(): KernelInterface if (static::$kernel instanceof KernelInterface) { $kernelEnvironment = static::$kernel->getEnvironment(); - $expectedEnvironment = isset(static::getKernelConfiguration()['environment']) - ? static::getKernelConfiguration()['environment'] - : 'phpcr'; + $expectedEnvironment = static::getKernelConfiguration()['environment'] ?? 'phpcr'; if ($kernelEnvironment !== $expectedEnvironment) { var_dump($kernelEnvironment, $expectedEnvironment); static::bootKernel(); diff --git a/src/HttpKernel/TestKernel.php b/src/HttpKernel/TestKernel.php index 16ba132..8092d5b 100644 --- a/src/HttpKernel/TestKernel.php +++ b/src/HttpKernel/TestKernel.php @@ -214,7 +214,7 @@ protected function registerConfiguredBundles() } } - protected function build(ContainerBuilder $container) + protected function build(ContainerBuilder $container): void { parent::build($container); if (\in_array($this->getEnvironment(), ['test', 'phpcr']) && file_exists($this->getKernelDir().'/config/public_services.php')) { diff --git a/tests/Functional/BaseTestCaseTest.php b/tests/Functional/BaseTestCaseTest.php index 5983b30..22f0b1b 100644 --- a/tests/Functional/BaseTestCaseTest.php +++ b/tests/Functional/BaseTestCaseTest.php @@ -12,6 +12,7 @@ namespace Symfony\Cmf\Component\Testing\Tests\Functional; use Doctrine\Bundle\PHPCRBundle\Initializer\InitializerManager; +use Doctrine\Bundle\PHPCRBundle\ManagerRegistry; use Doctrine\Bundle\PHPCRBundle\ManagerRegistryInterface; use Doctrine\Bundle\PHPCRBundle\Test\RepositoryManager; use PHPUnit\Framework\MockObject\MockObject; @@ -21,7 +22,9 @@ use Symfony\Cmf\Component\Testing\Functional\BaseTestCase; use Symfony\Cmf\Component\Testing\Functional\DbManager\PHPCR; use Symfony\Cmf\Component\Testing\Tests\Fixtures\TestTestCase; +use Symfony\Component\DependencyInjection\Container; use Symfony\Component\DependencyInjection\ContainerInterface; +use Symfony\Component\HttpKernel\Kernel; use Symfony\Component\HttpKernel\KernelInterface; class BaseTestCaseTest extends TestCase @@ -48,13 +51,18 @@ class BaseTestCaseTest extends TestCase protected function setUp(): void { - $this->container = $this->createMock(ContainerInterface::class); + $managerRegistry = interface_exists(ManagerRegistryInterface::class) + ? $this->createMock(ManagerRegistryInterface::class) + : $this->createMock(ManagerRegistry::class) + ; + $this->container = Kernel::MAJOR_VERSION >= 7 ? $this->createMock(Container::class) : $this->createMock(ContainerInterface::class); $this->container ->method('get') - ->willReturnCallback(function ($name) { + ->willReturnCallback(function ($name) use ($managerRegistry) { $dic = [ 'test.client' => $this->client, - 'doctrine_phpcr' => $this->createMock(ManagerRegistryInterface::class), + 'test.service_container' => $this->container, + 'doctrine_phpcr' => $managerRegistry, 'doctrine_phpcr.initializer_manager' => $this->createMock(InitializerManager::class), ]; @@ -85,15 +93,6 @@ protected function setUp(): void ->willReturn($this->container); } - public function testGetContainer() - { - $class = new \ReflectionClass(BaseTestCase::class); - $method = $class->getMethod('getContainer'); - $method->setAccessible(true); - - $this->assertEquals($this->container, $method->invoke(null)); - } - public function testGetKernel() { $class = new \ReflectionClass(BaseTestCase::class); @@ -128,8 +127,6 @@ public function provideTestDb() /** * @dataProvider provideTestDb - * - * @depends testGetContainer */ public function testDb($dbName, $expected) {