First step is upgrading Sylius with composer
composer require sylius/sylius:~1.4.0
If you use migrations in your plugin's test application, take a look at following changes:
- Change base
AbstractMigration
namespace toDoctrine\Migrations\AbstractMigration
- Add
: void
return types to bothup
anddown
functions - Copy this and this migration to your migrations folder or run
(cd tests/Application && bin/console doctrine:migrations:diff)
to generate new migration with changes from Sylius - Apply new migrations with
(cd tests/Application && bin/console doctrine:migrations:migrate)
If you don't use migrations, just run (cd tests/Application && bin/console doctrine:schema:update --force)
to update the test application's database schema.
composer require symfony/dotenv:^4.2 --dev
- Follow Symfony dotenv update guide to incorporate required changes in
.env
files structure. Remember - they should be done ontests/Application/
level! Optionally, you can take a look at corresponding PR introducing these changes in PluginSkeleton (this PR also includes changes with Behat - see below)
Don't forget to clear the cache (tests/Application/bin/console cache:clear
) to be 100% everything is loaded properly.
If you're using Behat and want to be up-to-date with our configuration
- Update required extensions with
composer require friends-of-behat/symfony-extension:^2.0 friends-of-behat/page-object-extension:^0.3 --dev
- Remove extensions that are not needed yet with
composer remove friends-of-behat/context-service-extension friends-of-behat/cross-container-extension friends-of-behat/service-container-extension --dev
- Update your
behat.yml
- look at the diff here - Add
SymfonyExtensionBundle
to yourtests/Application/config/bundles.php
:return [ //... FriendsOfBehat\SymfonyExtension\Bundle\FriendsOfBehatSymfonyExtensionBundle::class => ['test' => true, 'test_cached' => true], ];
- If you use our Travis CI configuration, follow these changes introduced in
.travis.yml
file - Create
tests/Application/config/services_test.yaml
file with the following code and add these your own Behat services as well:imports: - { resource: "../../../vendor/sylius/sylius/src/Sylius/Behat/Resources/config/services.xml" }
- Remove all
__symfony__
prefixes in your Behat services - Remove all
<tag name="fob.context_service" />
tags from your Behat services - Make your Behat services public by default with
<defaults public="true" />
- Change
contexts_services
in your suite definitions tocontexts
- Take a look at SymfonyExtension UPGRADE guide if you have any more problems
Firstly, check out the PluginSkeleton 1.3 upgrade guide to update Sylius version step by step. To upgrade to Sylius 1.4 follow instructions from the previous section with following changes:
- Change namespaces of copied migrations to
Sylius\Migrations
- These changes are not required, but can be done as well, if you've changed application directory structure in
1.2.x
to1.3
update
- Add
\FriendsOfBehat\SymfonyExtension\Bundle\FriendsOfBehatSymfonyExtensionBundle()
to your bundles lists intests/Application/AppKernel.php
(preferably only intest
environment) - Import Sylius Behat services in
tests/Application/config/config_test.yml
and your own Behat services as well:imports: - { resource: "../../../../vendor/sylius/sylius/src/Sylius/Behat/Resources/config/services.xml" }
- Specify test application's kernel path in
behat.yml
:FriendsOfBehat\SymfonyExtension: kernel: class: AppKernel path: tests/Application/app/AppKernel.php