From 6a359ff0e445693c4c2ea7878005b9f026234254 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lo=C3=AFc=20Fr=C3=A9mont?= Date: Mon, 12 Oct 2020 18:04:02 +0200 Subject: [PATCH 1/7] Remove rest dependencies --- .travis.yml | 4 ++ composer.json | 13 ++-- src/Bundle/Controller/ResourceController.php | 68 ++++++++++--------- .../Driver/AbstractDriver.php | 5 +- .../Resources/config/services/controller.xml | 2 +- src/Bundle/test/app/AppKernel.php | 26 ++++--- src/Bundle/test/app/config/config.yml | 11 --- src/Bundle/test/app/config/config_dev.yml | 13 ++++ src/Bundle/test/app/config/config_prod.yml | 2 + src/Bundle/test/app/config/config_test.yml | 2 + src/Bundle/test/app/console | 3 +- 11 files changed, 89 insertions(+), 60 deletions(-) create mode 100644 src/Bundle/test/app/config/config_dev.yml create mode 100644 src/Bundle/test/app/config/config_prod.yml create mode 100644 src/Bundle/test/app/config/config_test.yml diff --git a/.travis.yml b/.travis.yml index 2f59ada8b..cae539ddf 100644 --- a/.travis.yml +++ b/.travis.yml @@ -62,3 +62,7 @@ script: - (cd src/Component && vendor/bin/phpspec run) - vendor/bin/phpunit + + - composer require doctrine/orm:^2.5 --no-update --no-scripts --prefer-dist + - composer update --no-dev --prefer-dist + - (cd src/Bundle/test && app/console cache:clear --env=prod) diff --git a/composer.json b/composer.json index 7127acd3f..f2c6f9804 100644 --- a/composer.json +++ b/composer.json @@ -29,8 +29,6 @@ "babdev/pagerfanta-bundle": "^2.0", "doctrine/doctrine-bundle": "^1.12 || ^2.0", "doctrine/persistence": "^1.3", - "friendsofsymfony/rest-bundle": "^3.0", - "jms/serializer-bundle": "^3.5", "stof/doctrine-extensions-bundle": "^1.2", "sylius/registry": "^1.2", "symfony/config": "^4.4 || ^5.0", @@ -43,18 +41,22 @@ "symfony/validator": "^4.4 || ^5.0", "symfony/yaml": "^4.4 || ^5.0", "webmozart/assert": "^1.8", - "willdurand/hateoas-bundle": "^2.0", "winzou/state-machine-bundle": "^0.3.2 || ^0.4.3 || ^0.5" }, "replace": { "sylius/resource": "self.version" }, "conflict": { - "amphp/amp": "^2.4.3" + "amphp/amp": "^2.4.3", + "friendsofsymfony/rest-bundle": "<3.0", + "jms/serializer-bundle": "<3.5", + "willdurand/hateoas-bundle": "<2.0" }, "require-dev": { "doctrine/orm": "^2.5", + "friendsofsymfony/rest-bundle": "^3.0", "gedmo/doctrine-extensions": "^2.4", + "jms/serializer-bundle": "^3.5", "lchrusciel/api-test-case": "^5.0", "matthiasnoback/symfony-dependency-injection-test": "^4.0", "pamil/phpspec-skip-example-extension": "^4.1", @@ -68,7 +70,8 @@ "sylius/grid-bundle": "^1.2", "symfony/dependency-injection": "^4.4 || ^5.0", "twig/twig": "^2.12 || ^3.0", - "vimeo/psalm": "3.16" + "vimeo/psalm": "3.16", + "willdurand/hateoas-bundle": "^2.0" }, "suggest": { "doctrine/orm": "^2.5", diff --git a/src/Bundle/Controller/ResourceController.php b/src/Bundle/Controller/ResourceController.php index ec8f15795..7bb4afad4 100644 --- a/src/Bundle/Controller/ResourceController.php +++ b/src/Bundle/Controller/ResourceController.php @@ -39,7 +39,7 @@ class ResourceController extends AbstractController /** @var RequestConfigurationFactoryInterface */ protected $requestConfigurationFactory; - /** @var ViewHandlerInterface */ + /** @var ViewHandlerInterface|null */ protected $viewHandler; /** @var RepositoryInterface */ @@ -87,7 +87,7 @@ class ResourceController extends AbstractController public function __construct( MetadataInterface $metadata, RequestConfigurationFactoryInterface $requestConfigurationFactory, - ViewHandlerInterface $viewHandler, + ?ViewHandlerInterface $viewHandler, RepositoryInterface $repository, FactoryInterface $factory, NewResourceFactoryInterface $newResourceFactory, @@ -140,9 +140,7 @@ public function showAction(Request $request): Response ]); } - $view = View::create($resource); - - return $this->viewHandler->handle($configuration, $view); + return $this->createRestView($configuration, $resource); } public function indexAction(Request $request): Response @@ -163,9 +161,7 @@ public function indexAction(Request $request): Response ]); } - $view = View::create($resources); - - return $this->viewHandler->handle($configuration, $view); + return $this->createRestView($configuration, $resources); } public function createAction(Request $request): Response @@ -210,7 +206,7 @@ public function createAction(Request $request): Response $postEvent = $this->eventDispatcher->dispatchPostEvent(ResourceActions::CREATE, $configuration, $newResource); if (!$configuration->isHtmlRequest()) { - return $this->viewHandler->handle($configuration, View::create($newResource, Response::HTTP_CREATED)); + return $this->createRestView($configuration, $newResource, Response::HTTP_CREATED); } $postEventResponse = $postEvent->getResponse(); @@ -222,7 +218,7 @@ public function createAction(Request $request): Response } if (!$configuration->isHtmlRequest()) { - return $this->viewHandler->handle($configuration, View::create($form, Response::HTTP_BAD_REQUEST)); + return $this->createRestView($configuration, $form, Response::HTTP_BAD_REQUEST); } $initializeEvent = $this->eventDispatcher->dispatchInitializeEvent(ResourceActions::CREATE, $configuration, $newResource); @@ -278,10 +274,7 @@ public function updateAction(Request $request): Response $this->resourceUpdateHandler->handle($resource, $configuration, $this->manager); } catch (UpdateHandlingException $exception) { if (!$configuration->isHtmlRequest()) { - return $this->viewHandler->handle( - $configuration, - View::create($form, $exception->getApiResponseCode()) - ); + return $this->createRestView($configuration, $form, $exception->getApiResponseCode()); } $this->flashHelper->addErrorFlash($configuration, $exception->getFlash()); @@ -296,9 +289,11 @@ public function updateAction(Request $request): Response $postEvent = $this->eventDispatcher->dispatchPostEvent(ResourceActions::UPDATE, $configuration, $resource); if (!$configuration->isHtmlRequest()) { - $view = $configuration->getParameters()->get('return_content', false) ? View::create($resource, Response::HTTP_OK) : View::create(null, Response::HTTP_NO_CONTENT); + if ($configuration->getParameters()->get('return_content', false)) { + return $this->createRestView($configuration, $resource, Response::HTTP_OK); + } - return $this->viewHandler->handle($configuration, $view); + return $this->createRestView($configuration, null, Response::HTTP_NO_CONTENT); } $postEventResponse = $postEvent->getResponse(); @@ -310,7 +305,7 @@ public function updateAction(Request $request): Response } if (!$configuration->isHtmlRequest()) { - return $this->viewHandler->handle($configuration, View::create($form, Response::HTTP_BAD_REQUEST)); + return $this->createRestView($configuration, $form, Response::HTTP_BAD_REQUEST); } $initializeEvent = $this->eventDispatcher->dispatchInitializeEvent(ResourceActions::UPDATE, $configuration, $resource); @@ -359,10 +354,7 @@ public function deleteAction(Request $request): Response $this->resourceDeleteHandler->handle($resource, $this->repository); } catch (DeleteHandlingException $exception) { if (!$configuration->isHtmlRequest()) { - return $this->viewHandler->handle( - $configuration, - View::create(null, $exception->getApiResponseCode()) - ); + return $this->createRestView($configuration, null, $exception->getApiResponseCode()); } $this->flashHelper->addErrorFlash($configuration, $exception->getFlash()); @@ -377,7 +369,7 @@ public function deleteAction(Request $request): Response $postEvent = $this->eventDispatcher->dispatchPostEvent(ResourceActions::DELETE, $configuration, $resource); if (!$configuration->isHtmlRequest()) { - return $this->viewHandler->handle($configuration, View::create(null, Response::HTTP_NO_CONTENT)); + return $this->createRestView($configuration, null, Response::HTTP_NO_CONTENT); } $postEventResponse = $postEvent->getResponse(); @@ -425,10 +417,7 @@ public function bulkDeleteAction(Request $request): Response $this->resourceDeleteHandler->handle($resource, $this->repository); } catch (DeleteHandlingException $exception) { if (!$configuration->isHtmlRequest()) { - return $this->viewHandler->handle( - $configuration, - View::create(null, $exception->getApiResponseCode()) - ); + return $this->createRestView($configuration, null, $exception->getApiResponseCode()); } $this->flashHelper->addErrorFlash($configuration, $exception->getFlash()); @@ -440,7 +429,7 @@ public function bulkDeleteAction(Request $request): Response } if (!$configuration->isHtmlRequest()) { - return $this->viewHandler->handle($configuration, View::create(null, Response::HTTP_NO_CONTENT)); + return $this->createRestView($configuration, null, Response::HTTP_NO_CONTENT); } $this->flashHelper->addSuccessFlash($configuration, ResourceActions::BULK_DELETE); @@ -490,10 +479,7 @@ public function applyStateMachineTransitionAction(Request $request): Response $this->resourceUpdateHandler->handle($resource, $configuration, $this->manager); } catch (UpdateHandlingException $exception) { if (!$configuration->isHtmlRequest()) { - return $this->viewHandler->handle( - $configuration, - View::create($resource, $exception->getApiResponseCode()) - ); + return $this->createRestView($configuration, $resource, $exception->getApiResponseCode()); } $this->flashHelper->addErrorFlash($configuration, $exception->getFlash()); @@ -508,9 +494,11 @@ public function applyStateMachineTransitionAction(Request $request): Response $postEvent = $this->eventDispatcher->dispatchPostEvent(ResourceActions::UPDATE, $configuration, $resource); if (!$configuration->isHtmlRequest()) { - $view = $configuration->getParameters()->get('return_content', true) ? View::create($resource, Response::HTTP_OK) : View::create(null, Response::HTTP_NO_CONTENT); + if ($configuration->getParameters()->get('return_content', true)) { + return $this->createRestView($configuration, $resource, Response::HTTP_OK); + } - return $this->viewHandler->handle($configuration, $view); + return $this->createRestView($configuration, null, Response::HTTP_NO_CONTENT); } $postEventResponse = $postEvent->getResponse(); @@ -548,4 +536,18 @@ protected function findOr404(RequestConfiguration $configuration): ResourceInter return $resource; } + + /** + * @param mixed $data + */ + protected function createRestView(RequestConfiguration $configuration, $data, int $statusCode = null): Response + { + if (null === $this->viewHandler) { + throw new \LogicException('You can not use the "non-html" request if FriendsOfSymfony Rest Bundle is not available. Try running "composer require friendsofsymfony/rest-bundle".'); + } + + $view = View::create($data, $statusCode); + + return $this->viewHandler->handle($configuration, $view); + } } diff --git a/src/Bundle/DependencyInjection/Driver/AbstractDriver.php b/src/Bundle/DependencyInjection/Driver/AbstractDriver.php index dc679faa1..b6ba561bc 100644 --- a/src/Bundle/DependencyInjection/Driver/AbstractDriver.php +++ b/src/Bundle/DependencyInjection/Driver/AbstractDriver.php @@ -13,6 +13,7 @@ namespace Sylius\Bundle\ResourceBundle\DependencyInjection\Driver; +use FOS\RestBundle\FOSRestBundle; use Sylius\Component\Resource\Factory\Factory; use Sylius\Component\Resource\Factory\TranslatableFactoryInterface; use Sylius\Component\Resource\Metadata\Metadata; @@ -60,13 +61,15 @@ protected function setClassesParameters(ContainerBuilder $container, MetadataInt protected function addController(ContainerBuilder $container, MetadataInterface $metadata): void { + $viewHandler = new Reference('sylius.resource_controller.view_handler', ContainerInterface::NULL_ON_INVALID_REFERENCE); + $definition = new Definition($metadata->getClass('controller')); $definition ->setPublic(true) ->setArguments([ $this->getMetadataDefinition($metadata), new Reference('sylius.resource_controller.request_configuration_factory'), - new Reference('sylius.resource_controller.view_handler'), + $viewHandler, new Reference($metadata->getServiceId('repository')), new Reference($metadata->getServiceId('factory')), new Reference('sylius.resource_controller.new_resource_factory'), diff --git a/src/Bundle/Resources/config/services/controller.xml b/src/Bundle/Resources/config/services/controller.xml index 031572fad..971840962 100644 --- a/src/Bundle/Resources/config/services/controller.xml +++ b/src/Bundle/Resources/config/services/controller.xml @@ -48,7 +48,7 @@ - + diff --git a/src/Bundle/test/app/AppKernel.php b/src/Bundle/test/app/AppKernel.php index fb4fec68d..914bf60be 100644 --- a/src/Bundle/test/app/AppKernel.php +++ b/src/Bundle/test/app/AppKernel.php @@ -22,21 +22,31 @@ class AppKernel extends Kernel */ public function registerBundles() { - return [ + if ('prod' === $this->getEnvironment()) { + $loader = require __DIR__ . '/../../../../vendor/autoload.php'; + $loader->addPsr4('AppBundle\\', __DIR__ . '/../src/AppBundle/'); + } + + $bundles = [ new Symfony\Bundle\FrameworkBundle\FrameworkBundle(), - new FOS\RestBundle\FOSRestBundle(), - new JMS\SerializerBundle\JMSSerializerBundle(), new Doctrine\Bundle\DoctrineBundle\DoctrineBundle(), new Sylius\Bundle\ResourceBundle\SyliusResourceBundle(), new BabDev\PagerfantaBundle\BabDevPagerfantaBundle(), - new Bazinga\Bundle\HateoasBundle\BazingaHateoasBundle(), new Symfony\Bundle\TwigBundle\TwigBundle(), - new \winzou\Bundle\StateMachineBundle\winzouStateMachineBundle(), + new winzou\Bundle\StateMachineBundle\winzouStateMachineBundle(), new Stof\DoctrineExtensionsBundle\StofDoctrineExtensionsBundle(), - new Fidry\AliceDataFixtures\Bridge\Symfony\FidryAliceDataFixturesBundle(), - new Nelmio\Alice\Bridge\Symfony\NelmioAliceBundle(), new AppBundle\AppBundle(), ]; + + if (in_array($this->getEnvironment(), ['dev', 'test'])) { + $bundles[] = new FOS\RestBundle\FOSRestBundle(); + $bundles[] = new JMS\SerializerBundle\JMSSerializerBundle(); + $bundles[] = new Bazinga\Bundle\HateoasBundle\BazingaHateoasBundle(); + $bundles[] = new Fidry\AliceDataFixtures\Bridge\Symfony\FidryAliceDataFixturesBundle(); + $bundles[] = new Nelmio\Alice\Bridge\Symfony\NelmioAliceBundle(); + } + + return $bundles; } /** @@ -44,7 +54,7 @@ public function registerBundles() */ public function registerContainerConfiguration(LoaderInterface $loader) { - $loader->load(__DIR__ . '/config/config.yml'); + $loader->load(__DIR__ . '/config/config_' . $this->getEnvironment() . '.yml'); } /** diff --git a/src/Bundle/test/app/config/config.yml b/src/Bundle/test/app/config/config.yml index 630353b8a..bff3a77a9 100644 --- a/src/Bundle/test/app/config/config.yml +++ b/src/Bundle/test/app/config/config.yml @@ -31,17 +31,6 @@ doctrine: default: auto_mapping: true -fos_rest: - view: - formats: - json: true - empty_content: 204 - format_listener: - rules: - - { path: '^/', priorities: ['json'], fallback_format: json, prefer_extension: true } - exception: - enabled: false - stof_doctrine_extensions: default_locale: "%locale%" orm: diff --git a/src/Bundle/test/app/config/config_dev.yml b/src/Bundle/test/app/config/config_dev.yml new file mode 100644 index 000000000..fda294dc3 --- /dev/null +++ b/src/Bundle/test/app/config/config_dev.yml @@ -0,0 +1,13 @@ +imports: + - { resource: config.yml } + +fos_rest: + view: + formats: + json: true + empty_content: 204 + format_listener: + rules: + - { path: '^/', priorities: ['json'], fallback_format: json, prefer_extension: true } + exception: + enabled: false diff --git a/src/Bundle/test/app/config/config_prod.yml b/src/Bundle/test/app/config/config_prod.yml new file mode 100644 index 000000000..8e0b6ff02 --- /dev/null +++ b/src/Bundle/test/app/config/config_prod.yml @@ -0,0 +1,2 @@ +imports: + - { resource: config.yml } diff --git a/src/Bundle/test/app/config/config_test.yml b/src/Bundle/test/app/config/config_test.yml new file mode 100644 index 000000000..a3b2db43c --- /dev/null +++ b/src/Bundle/test/app/config/config_test.yml @@ -0,0 +1,2 @@ +imports: + - { resource: config_dev.yml } diff --git a/src/Bundle/test/app/console b/src/Bundle/test/app/console index 66798294b..c6b192f78 100755 --- a/src/Bundle/test/app/console +++ b/src/Bundle/test/app/console @@ -19,6 +19,7 @@ use Symfony\Bundle\FrameworkBundle\Console\Application; use Symfony\Component\Console\Input\ArgvInput; $input = new ArgvInput(); +$env = $input->getParameterOption(array('--env', '-e'), getenv('SYMFONY_ENV') ?: 'test'); -$application = new Application(new AppKernel('test', true)); +$application = new Application(new AppKernel($env, true)); $application->run($input); From d4b20a82bf3fd73d700e26ad45914b8f1941b921 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lo=C3=AFc=20Fr=C3=A9mont?= Date: Mon, 12 Oct 2020 21:26:02 +0200 Subject: [PATCH 2/7] Fix abstract driver --- src/Bundle/DependencyInjection/Driver/AbstractDriver.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Bundle/DependencyInjection/Driver/AbstractDriver.php b/src/Bundle/DependencyInjection/Driver/AbstractDriver.php index b6ba561bc..6b9bd9547 100644 --- a/src/Bundle/DependencyInjection/Driver/AbstractDriver.php +++ b/src/Bundle/DependencyInjection/Driver/AbstractDriver.php @@ -13,12 +13,12 @@ namespace Sylius\Bundle\ResourceBundle\DependencyInjection\Driver; -use FOS\RestBundle\FOSRestBundle; use Sylius\Component\Resource\Factory\Factory; use Sylius\Component\Resource\Factory\TranslatableFactoryInterface; use Sylius\Component\Resource\Metadata\Metadata; use Sylius\Component\Resource\Metadata\MetadataInterface; use Symfony\Component\DependencyInjection\ContainerBuilder; +use Symfony\Component\DependencyInjection\ContainerInterface; use Symfony\Component\DependencyInjection\Definition; use Symfony\Component\DependencyInjection\Reference; From 09fc0fa2bcd1bd651b82bbc32c3eb93b81bb2440 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lo=C3=AFc=20Fr=C3=A9mont?= Date: Tue, 13 Oct 2020 12:00:41 +0200 Subject: [PATCH 3/7] Update src/Bundle/DependencyInjection/Driver/AbstractDriver.php Co-authored-by: Kamil Kokot --- src/Bundle/DependencyInjection/Driver/AbstractDriver.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Bundle/DependencyInjection/Driver/AbstractDriver.php b/src/Bundle/DependencyInjection/Driver/AbstractDriver.php index 6b9bd9547..927f8aebd 100644 --- a/src/Bundle/DependencyInjection/Driver/AbstractDriver.php +++ b/src/Bundle/DependencyInjection/Driver/AbstractDriver.php @@ -69,7 +69,7 @@ protected function addController(ContainerBuilder $container, MetadataInterface ->setArguments([ $this->getMetadataDefinition($metadata), new Reference('sylius.resource_controller.request_configuration_factory'), - $viewHandler, + new Reference('sylius.resource_controller.view_handler', ContainerInterface::NULL_ON_INVALID_REFERENCE), new Reference($metadata->getServiceId('repository')), new Reference($metadata->getServiceId('factory')), new Reference('sylius.resource_controller.new_resource_factory'), From 3dfe0c31beb8adf0a7f868e30573ad9e21fc1e47 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lo=C3=AFc=20Fr=C3=A9mont?= Date: Tue, 13 Oct 2020 14:06:23 +0200 Subject: [PATCH 4/7] Update src/Bundle/test/app/AppKernel.php Co-authored-by: Kamil Kokot --- src/Bundle/test/app/AppKernel.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Bundle/test/app/AppKernel.php b/src/Bundle/test/app/AppKernel.php index 914bf60be..a499008fd 100644 --- a/src/Bundle/test/app/AppKernel.php +++ b/src/Bundle/test/app/AppKernel.php @@ -38,7 +38,7 @@ public function registerBundles() new AppBundle\AppBundle(), ]; - if (in_array($this->getEnvironment(), ['dev', 'test'])) { + if (in_array($this->getEnvironment(), ['dev', 'test'], true)) { $bundles[] = new FOS\RestBundle\FOSRestBundle(); $bundles[] = new JMS\SerializerBundle\JMSSerializerBundle(); $bundles[] = new Bazinga\Bundle\HateoasBundle\BazingaHateoasBundle(); From 24fe9f2904c50a93f32b0f4fc09fd071e074e3bb Mon Sep 17 00:00:00 2001 From: Kamil Kokot Date: Tue, 13 Oct 2020 16:09:25 +0200 Subject: [PATCH 5/7] Replace "prod" environment with "test_without_fosrest" one --- .travis.yml | 5 ++-- src/Bundle/test/app/AppKernel.php | 31 +++------------------- src/Bundle/test/app/config/config_dev.yml | 13 --------- src/Bundle/test/app/config/config_prod.yml | 2 -- src/Bundle/test/app/config/config_test.yml | 12 +++++++-- src/Bundle/test/app/console | 2 +- 6 files changed, 18 insertions(+), 47 deletions(-) delete mode 100644 src/Bundle/test/app/config/config_dev.yml delete mode 100644 src/Bundle/test/app/config/config_prod.yml diff --git a/.travis.yml b/.travis.yml index cae539ddf..68bbe95cc 100644 --- a/.travis.yml +++ b/.travis.yml @@ -63,6 +63,7 @@ script: - vendor/bin/phpunit - - composer require doctrine/orm:^2.5 --no-update --no-scripts --prefer-dist + # Test the whole bundle without FOSRestBundle dependency + - composer require doctrine/orm:^2.5 --no-update --no-scripts - composer update --no-dev --prefer-dist - - (cd src/Bundle/test && app/console cache:clear --env=prod) + - (cd src/Bundle/test && app/console cache:clear --env=test_without_fosrest) diff --git a/src/Bundle/test/app/AppKernel.php b/src/Bundle/test/app/AppKernel.php index a499008fd..1b1a5d58f 100644 --- a/src/Bundle/test/app/AppKernel.php +++ b/src/Bundle/test/app/AppKernel.php @@ -11,22 +11,13 @@ declare(strict_types=1); -use PSS\SymfonyMockerContainer\DependencyInjection\MockerContainer; use Symfony\Component\Config\Loader\LoaderInterface; use Symfony\Component\HttpKernel\Kernel; class AppKernel extends Kernel { - /** - * {@inheritdoc} - */ public function registerBundles() { - if ('prod' === $this->getEnvironment()) { - $loader = require __DIR__ . '/../../../../vendor/autoload.php'; - $loader->addPsr4('AppBundle\\', __DIR__ . '/../src/AppBundle/'); - } - $bundles = [ new Symfony\Bundle\FrameworkBundle\FrameworkBundle(), new Doctrine\Bundle\DoctrineBundle\DoctrineBundle(), @@ -38,7 +29,7 @@ public function registerBundles() new AppBundle\AppBundle(), ]; - if (in_array($this->getEnvironment(), ['dev', 'test'], true)) { + if ($this->getEnvironment() !== 'test_without_fosrest') { $bundles[] = new FOS\RestBundle\FOSRestBundle(); $bundles[] = new JMS\SerializerBundle\JMSSerializerBundle(); $bundles[] = new Bazinga\Bundle\HateoasBundle\BazingaHateoasBundle(); @@ -49,23 +40,9 @@ public function registerBundles() return $bundles; } - /** - * {@inheritdoc} - */ - public function registerContainerConfiguration(LoaderInterface $loader) + public function registerContainerConfiguration(LoaderInterface $loader): void { - $loader->load(__DIR__ . '/config/config_' . $this->getEnvironment() . '.yml'); - } - - /** - * {@inheritdoc} - */ - protected function getContainerBaseClass() - { - if (0 === strpos($this->environment, 'test')) { - return MockerContainer::class; - } - - return parent::getContainerBaseClass(); + $loader->load(__DIR__ . '/config/{config}.{php,xml,yaml,yml}', 'glob'); + $loader->load(__DIR__ . '/config/{config}_' . $this->getEnvironment() . '.{php,xml,yaml,yml}', 'glob'); } } diff --git a/src/Bundle/test/app/config/config_dev.yml b/src/Bundle/test/app/config/config_dev.yml deleted file mode 100644 index fda294dc3..000000000 --- a/src/Bundle/test/app/config/config_dev.yml +++ /dev/null @@ -1,13 +0,0 @@ -imports: - - { resource: config.yml } - -fos_rest: - view: - formats: - json: true - empty_content: 204 - format_listener: - rules: - - { path: '^/', priorities: ['json'], fallback_format: json, prefer_extension: true } - exception: - enabled: false diff --git a/src/Bundle/test/app/config/config_prod.yml b/src/Bundle/test/app/config/config_prod.yml deleted file mode 100644 index 8e0b6ff02..000000000 --- a/src/Bundle/test/app/config/config_prod.yml +++ /dev/null @@ -1,2 +0,0 @@ -imports: - - { resource: config.yml } diff --git a/src/Bundle/test/app/config/config_test.yml b/src/Bundle/test/app/config/config_test.yml index a3b2db43c..14ade9925 100644 --- a/src/Bundle/test/app/config/config_test.yml +++ b/src/Bundle/test/app/config/config_test.yml @@ -1,2 +1,10 @@ -imports: - - { resource: config_dev.yml } +fos_rest: + view: + formats: + json: true + empty_content: 204 + format_listener: + rules: + - { path: '^/', priorities: ['json'], fallback_format: json, prefer_extension: true } + exception: + enabled: false diff --git a/src/Bundle/test/app/console b/src/Bundle/test/app/console index c6b192f78..35a889f54 100755 --- a/src/Bundle/test/app/console +++ b/src/Bundle/test/app/console @@ -19,7 +19,7 @@ use Symfony\Bundle\FrameworkBundle\Console\Application; use Symfony\Component\Console\Input\ArgvInput; $input = new ArgvInput(); -$env = $input->getParameterOption(array('--env', '-e'), getenv('SYMFONY_ENV') ?: 'test'); +$env = $input->getParameterOption(['--env', '-e'], getenv('APP_ENV') ?? 'test'); $application = new Application(new AppKernel($env, true)); $application->run($input); From c197044231a546b84db8e1aa623d858a85819095 Mon Sep 17 00:00:00 2001 From: Kamil Kokot Date: Tue, 13 Oct 2020 16:13:43 +0200 Subject: [PATCH 6/7] Add conflict for next major releases of optional dependencies --- composer.json | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/composer.json b/composer.json index f2c6f9804..88a8a5594 100644 --- a/composer.json +++ b/composer.json @@ -48,9 +48,9 @@ }, "conflict": { "amphp/amp": "^2.4.3", - "friendsofsymfony/rest-bundle": "<3.0", - "jms/serializer-bundle": "<3.5", - "willdurand/hateoas-bundle": "<2.0" + "friendsofsymfony/rest-bundle": "<3.0 >=4.0", + "jms/serializer-bundle": "<3.5 >=4.0", + "willdurand/hateoas-bundle": "<2.0 >=3.0" }, "require-dev": { "doctrine/orm": "^2.5", From 69f35962c1d4f81a5f80b9cf71736e3849bc9b04 Mon Sep 17 00:00:00 2001 From: Kamil Kokot Date: Tue, 13 Oct 2020 16:43:10 +0200 Subject: [PATCH 7/7] Different way to remove FOSRestBundle with dependencies --- .travis.yml | 7 +++---- composer.json | 5 ++++- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/.travis.yml b/.travis.yml index 68bbe95cc..11e0bf35b 100644 --- a/.travis.yml +++ b/.travis.yml @@ -42,8 +42,8 @@ before_install: - (cd src/Component && composer config extra.symfony.require "${SYMFONY_VERSION}") install: - - composer require winzou/state-machine-bundle:$STATE_MACHINE_VERSION --no-update --no-scripts --prefer-dist - - composer require twig/twig:$TWIG_VERSION --dev --no-update --no-scripts --prefer-dist + - composer require winzou/state-machine-bundle:$STATE_MACHINE_VERSION --no-update --no-scripts + - composer require twig/twig:$TWIG_VERSION --dev --no-update --no-scripts - composer update --prefer-dist --no-scripts - (cd src/Component && composer update --prefer-dist --no-scripts) @@ -64,6 +64,5 @@ script: - vendor/bin/phpunit # Test the whole bundle without FOSRestBundle dependency - - composer require doctrine/orm:^2.5 --no-update --no-scripts - - composer update --no-dev --prefer-dist + - composer remove friendsofsymfony/rest-bundle willdurand/hateoas-bundle jms/serializer-bundle --dev --no-scripts - (cd src/Bundle/test && app/console cache:clear --env=test_without_fosrest) diff --git a/composer.json b/composer.json index 88a8a5594..9c5e4ef20 100644 --- a/composer.json +++ b/composer.json @@ -75,7 +75,10 @@ }, "suggest": { "doctrine/orm": "^2.5", - "sylius/locale": "^1.0" + "friendsofsymfony/rest-bundle": "^3.0", + "jms/serializer-bundle": "^3.5", + "sylius/locale": "^1.0", + "willdurand/hateoas-bundle": "^2.0" }, "extra": { "branch-alias": {