- Git
- Docker / docker-compose
- Environment variables
cp -f .env .env.local
- Environment variables for testing
cp -f .env.test .env.test.local
Make sure the database name and ports are accurate in the DATABASE_URL
. Otherwise change the variable accordingly to the database definition in docker-compose.yml
.
DATABASE_URL="postgresql://<POSTGRES_USER>:<POSTGRES_PASSWORD>@postgres-test:<PORT>/<POSTGRES_DB>?serverVersion=15&charset=utf8"
cp -f .php-cs-fixer.dist.php .php-cs-fixer.php
Run this command to execute pre-commit.sh
each time a commit is created:
ln -s ../../bin/pre-commit.sh .git/hooks/pre-commit
docker-compose up --build -d
The previous command will automatically run the not already executed migrations. But the testing database needs to be updated accordingly. To do so run this command:
docker-compose exec -it php sh tests/init-test-database.sh
- Web server : http://localhost:8080
- Admin dashboard : http://localhost:8080/admin/dashboard
- Profiler : http://localhost:8080/_profiler/
Command to run all tests:
docker-compose exec -it php vendor/bin/phpunit
To run a given testing directory:
docker-compose exec -it php vendor/bin/phpunit tests/<SUBDIRECTORY_NAME>
- Run the php fixer
docker-compose exec -it php vendor/bin/php-cs-fixer fix -v --dry-run
- Run rector
docker-compose exec -it php php vendor/bin/rector process --dry-run
- Générer une migration :
docker-compose exec php symfony console make:migration
- Execute migrations:
docker-compose exec -it php bin/console app:sync-migrate
- Create an active admin with the console:
docker-compose exec -it php bin/console app:create-admin