pocky / modern-plugin-skeleton
Acme example plugin for modern Sylius.
Installs: 11
Dependents: 0
Suggesters: 0
Security: 0
Stars: 9
Watchers: 3
Forks: 3
Open Issues: 0
Type:sylius-plugin
Requires
- php: ^8.2
- sylius/mailer-bundle: ^1.8 || ^2.0@beta
- sylius/sylius: ^1.12
- symfony/webpack-encore-bundle: ^1.15
Requires (Dev)
- behat/behat: ^3.7
- behat/mink-selenium2-driver: ^1.4
- dmore/behat-chrome-extension: ^1.3
- dmore/chrome-mink-driver: ^2.7
- friends-of-behat/mink: ^1.8
- friends-of-behat/mink-browserkit-driver: ^1.4
- friends-of-behat/mink-debug-extension: ^2.0
- friends-of-behat/mink-extension: ^2.4
- friends-of-behat/page-object-extension: ^0.3
- friends-of-behat/suite-settings-extension: ^1.0
- friends-of-behat/symfony-extension: ^2.1
- friends-of-behat/variadic-extension: ^1.3
- lchrusciel/api-test-case: ^5.0
- phpspec/phpspec: ^7.2
- phpstan/extension-installer: ^1.0
- phpstan/phpstan: ^1.8.4
- phpstan/phpstan-doctrine: ^1.3.37
- phpstan/phpstan-strict-rules: ^1.3.0
- phpstan/phpstan-webmozart-assert: ^1.2.0
- phpunit/phpunit: ^9.5
- polishsymfonycommunity/symfony-mocker-container: ^1.0
- stripe/stripe-php: ^6.43
- sylius-labs/coding-standard: ^4.0
- sylius/sylius-rector: 0.11.x-dev
- symfony/browser-kit: ^6.0
- symfony/debug-bundle: ^6.0
- symfony/dotenv: ^6.0
- symfony/flex: ^2.2.2
- symfony/intl: ^6.0
- symfony/web-profiler-bundle: ^6.0
- vimeo/psalm: ^5.8.0
This package is auto-updated.
Last update: 2025-01-04 17:07:43 UTC
README
Modern Plugin Skeleton
Modern Skeleton for starting Sylius plugins.
Warning
This plugin DOES NOT follow standard Sylius directory structure for plugins but a new "Symfony standard skeleton" one and services declaration in PHP (Symfony is actually leaving xml for PHP).
New directory structure:
├── assets
├── bin
├── config
├── docs
├── etc
├── features
├── public
├── src
├── templates
├── tests
└── translations
Informations:
- Related pull request on github (Symfony): symfony/symfony#32845
- Document for Symfony Bundle: https://github.com/yceruto/acme-bundle
Quickstart Installation (docker)
-
Run
composer create-project pocky/modern-plugin-skeleton ProjectName dev-main
or clone this project -
From the plugin skeleton root directory, run the following commands:
$ chmod -Rf 777 tests/Application/var $ docker compose up -d $ docker compose exec php php -d memory_limit=-1 /usr/bin/composer install $ docker compose exec nodejs yarn --cwd tests/Application install $ docker compose exec php tests/Application/bin/console doctrine:database:create --if-not-exists -vvv $ docker compose exec php tests/Application/bin/console doctrine:schema:create -vvv $ docker compose exec php tests/Application/bin/console assets:install tests/Application/public -vvv $ docker compose exec nodejs yarn --cwd tests/Application build $ docker compose exec php tests/Application/bin/console cache:warmup -vvv $ docker compose exec php tests/Application/bin/console sylius:fixtures:load -n
Quality tools
$ docker compose exec php composer validate --ansi --strict $ docker compose exec php vendor/bin/phpstan analyse -c phpstan.neon -l max src/ $ docker compose exec php vendor/bin/psalm $ docker compose exec php vendor/bin/phpspec run --ansi -f progress --no-interaction $ docker compose exec php vendor/bin/phpunit --colors=always $ docker compose exec php vendor/bin/behat --profile docker --colors --strict -vvv --no-interaction
ProTip use Makefile
;)
Official Documentation
For a comprehensive guide on Sylius Plugins development please go to Sylius documentation, there you will find the Plugin Development Guide, that is full of examples.
Quickstart Installation (legacy)
-
Run
composer create-project pocky/modern-plugin-skeleton ProjectName
. -
From the plugin skeleton root directory, run the following commands:
$ (cd tests/Application && yarn install) $ (cd tests/Application && yarn build) $ (cd tests/Application && APP_ENV=test bin/console assets:install public) $ (cd tests/Application && APP_ENV=test bin/console doctrine:database:create) $ (cd tests/Application && APP_ENV=test bin/console doctrine:schema:create)
To be able to setup a plugin's database, remember to configure you database credentials in tests/Application/.env
and tests/Application/.env.test
.
Usage
Running plugin tests
-
PHPUnit
vendor/bin/phpunit
-
PHPSpec
vendor/bin/phpspec run
-
Behat (non-JS scenarios)
vendor/bin/behat --strict --tags="~@javascript"
-
Behat (JS scenarios)
-
Start Headless Chrome:
google-chrome-stable --enable-automation --disable-background-networking --no-default-browser-check --no-first-run --disable-popup-blocking --disable-default-apps --allow-insecure-localhost --disable-translate --disable-extensions --no-sandbox --enable-features=Metal --headless --remote-debugging-port=9222 --window-size=2880,1800 --proxy-server='direct://' --proxy-bypass-list='*' http://127.0.0.1
- Install SSL certificates (only once needed) and run test application's webserver on
127.0.0.1:8080
:
symfony server:ca:install APP_ENV=test symfony server:start --port=8080 --dir=tests/Application/public --daemon
- Run Behat:
vendor/bin/behat --strict --tags="@javascript"
-
Static Analysis
-
Psalm
vendor/bin/psalm
-
PHPStan
vendor/bin/phpstan analyse -c phpstan.neon -l max src/
-
-
Coding Standard
vendor/bin/ecs check src
Opening Sylius with your plugin
-
Using
test
environment:(cd tests/Application && APP_ENV=test bin/console sylius:fixtures:load) (cd tests/Application && APP_ENV=test bin/console server:run -d public)
-
Using
dev
environment:(cd tests/Application && APP_ENV=dev bin/console sylius:fixtures:load) (cd tests/Application && APP_ENV=dev bin/console server:run -d public)