-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
95 lines (66 loc) · 3.65 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
# Executables (local)
DOCKER_COMP = docker compose
# Docker containers
PHP_CONT = $(DOCKER_COMP) exec php
# Executables
PHP = $(PHP_CONT) php
COMPOSER = $(PHP_CONT) composer
SYMFONY = $(PHP) bin/console
# Misc
.DEFAULT_GOAL = help
.PHONY : help build up start down logs sh composer vendor sf cc test
## —— 🎵 🐳 The Symfony Docker Makefile 🐳 🎵 ——————————————————————————————————
help: ## Outputs this help screen
@grep -E '(^[a-zA-Z0-9\./_-]+:.*?##.*$$)|(^##)' $(MAKEFILE_LIST) | awk 'BEGIN {FS = ":.*?## "}{printf "\033[32m%-30s\033[0m %s\n", $$1, $$2}' | sed -e 's/\[32m##/[33m/'
build: ## Builds the Docker images
@$(DOCKER_COMP) build --pull --no-cache
up: ## Start the docker hub in detached mode (no logs)
@$(DOCKER_COMP) up --detach
start: build up ## Build and start the containers
down: ## Stop the docker hub
@$(DOCKER_COMP) down --remove-orphans
logs: ## Show live logs
@$(DOCKER_COMP) logs --tail=0 --follow
sh: ## Connect to the FrankenPHP container
@$(PHP_CONT) bash
test: ## Start tests with phpunit, pass the parameter "c=" to add options to phpunit, example: make test c="--group e2e --stop-on-failure"
@$(eval c ?=)
@$(DOCKER_COMP) exec -e APP_ENV=test php bin/phpunit $(c)
## —— Composer 🧙 ——————————————————————————————————————————————————————————————
composer: ## Run composer, pass the parameter "c=" to run a given command, example: make composer c='req symfony/orm-pack'
@$(eval c ?=)
@$(COMPOSER) $(c)
vendor: ## Install vendors according to the current composer.lock file
vendor: c=install --prefer-dist --no-dev --no-progress --no-scripts --no-interaction
vendor: composer
## —— Symfony 🎵 ———————————————————————————————————————————————————————————————
sf: ## List all Symfony commands or pass the parameter "c=" to run a given command, example: make sf c=about
@$(eval c ?=)
@$(SYMFONY) $(c)
cc: c=c:c ## Clear the cache
cc: sf
## —— skankJukebox DEV 🎵 ———————————————————————————————————————————————————————
assets: c=asset-map:compile ## compile assets
assets: sf
db-upgrade: ## update db schema
@$(SYMFONY) doctrine:schema:update --force --no-interaction
db-upgrade-test: ## update db schema for test
@$(SYMFONY) --env=test doctrine:schema:update --force --no-interaction
build-cache: ## Builds the Docker images with cache
@$(DOCKER_COMP) build
fix-style: ## fix coding style with php-cs
$(PHP) vendor/bin/php-cs-fixer -v -n fix
clear: ## clear cache and assets
@$(PHP_CONT) rm -fR ./var
@$(PHP_CONT) rm -fR ./public/assets
vendor-dev: ## Install dev vendors according to the current composer.lock file
vendor-dev: c=install
vendor-dev: composer
ci: ## execute ci : rector, phpstan, php-cs
@$(PHP) vendor/bin/rector -n && $(PHP) vendor/bin/phpstan && $(PHP) vendor/bin/php-cs-fixer -v -n check
@$(SYMFONY) lint:yaml ./
@$(SYMFONY) lint:twig
@$(SYMFONY) lint:container
install-dev: down clear build up db-upgrade-test vendor-dev ## install jukebox in a development environment
## —— skankJukebox use 🎵 ———————————————————————————————————————————————————————
install: down clear build-cache up db-upgrade vendor assets ## install jukebox in a production environment