-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
170 lines (134 loc) · 6.62 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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
# Executables (local)
DOCKER_COMP = docker compose
DOCKER_PHP_SERVICE = web-twig-demo-php
DOCKER_ENCORE_SERVICE = web-twig-demo-encore
DOCKER_SERVER_SERVICE = web-twig-demo-server
SHELL = bash
# Paths
APP_DOCKER_DIR = ../../apps/web-twig-demo/docker/
ICONS_PKG_DIR = ../icons/
DOCKER_PKG_DIR = /srv/spirit-web-twig-bundle/
# Docker containers
PHP_CONT_PHP = cd $(APP_DOCKER_DIR) && $(DOCKER_COMP) exec --workdir $(DOCKER_PKG_DIR) $(DOCKER_PHP_SERVICE)
# Executables
PHP = $(PHP_CONT_PHP) php
COMPOSER = $(PHP_CONT_PHP) composer
CONT_MAKE = $(PHP_CONT_PHP) make
# Misc
.DEFAULT_GOAL = help
.PHONY = help build up prestart start down logs sh bash cert composer vendor make phpunit test analyze icons-build
## —— 🐳 The Spirit Web Twig Bundle 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/'
## —— Docker 🐳 ————————————————————————————————————————————————————————————————
build: ## Builds the Docker images
cd $(APP_DOCKER_DIR) && $(DOCKER_COMP) build --pull --no-cache
up: ## Start the docker hub in detached mode (no logs), pass the parameter "f=" to `docker compose` file
@$(eval f ?=)
@upCommand="cd $(APP_DOCKER_DIR) && $(DOCKER_COMP)"; \
if [ -n "$f" ]; then \
upCommand+=" --file $(f)"; \
fi; \
upCommand+=" up --detach"; \
echo $$upCommand; \
eval $$upCommand
down: ## Stop the docker hub
cd $(APP_DOCKER_DIR) && $(DOCKER_COMP) down --remove-orphans
logs: ## Show live logs
cd $(APP_DOCKER_DIR) && $(DOCKER_COMP) logs --tail=0 --follow
prestart: ## Preparation before start
@if [ ! -d "$(ICONS_PKG_DIR)/dist/svg" ]; then \
$(MAKE) icons-build; \
fi
start: prestart up vendor encore ## Start the containers
stop: down ## Stop the docker hub (alias for `down`)
bash: ## Connect to the PHP container
$(PHP_CONT_PHP) bash
sh: bash ## Connect to the PHP container (alias for `bash`)
ifeq ($(os),win)
cert: ## Trust the Authority of server certificates, pass the parameter "os=" with "win" | "linux" (default is "mac") for specific OS
@$(eval os ?=)
cd $(APP_DOCKER_DIR) && docker cp `docker compose ps -q $(DOCKER_SERVER_SERVICE)`:/data/caddy/pki/authorities/local/root.crt %TEMP%/root.crt && certutil -addstore -f "ROOT" %TEMP%/root.crt
else ifeq ($(os),linux)
cert:
@$(eval os ?=)
cd $(APP_DOCKER_DIR) && docker cp `docker compose ps -q $(DOCKER_SERVER_SERVICE)`:/data/caddy/pki/authorities/local/root.crt /usr/local/share/ca-certificates/root.crt && sudo update-ca-certificates
else
cert:
@$(eval os ?=)
cd $(APP_DOCKER_DIR) && docker cp `docker compose ps -q $(DOCKER_SERVER_SERVICE)`:/data/caddy/pki/authorities/local/root.crt /tmp/root.crt && sudo security add-trusted-cert -d -r trustRoot -k /Library/Keychains/System.keychain /tmp/root.crt
endif
## —— Encore 🎭 ————————————————————————————————————————————————————————————————
encore-install: ## Install demo dependencies
cd $(APP_DOCKER_DIR) && $(DOCKER_COMP) exec $(DOCKER_ENCORE_SERVICE) yarn install
#/# Every time you create a new package and use it in the demo, you need to link it here.
#/# This is because the demo is not using the packages from npm, but from the local filesystem.
#/# It ensures that the demo is always using the latest version of the package.
#/# Thus the realtime local development is possible.
encore-link: ## Link demo dependencies
cd $(APP_DOCKER_DIR) && \
$(DOCKER_COMP) exec $(DOCKER_ENCORE_SERVICE) sh -c "cd /srv/spirit-web && \
yarn link && \
cd /srv/spirit-web-twig-demo && \
yarn link @lmc-eu/spirit-web && \
\
cd /srv/spirit-form-validations && \
yarn link && \
cd /srv/spirit-web-twig-demo && \
yarn link @lmc-eu/spirit-form-validations && \
\
cd /srv/spirit-demo && \
yarn link && \
cd /srv/spirit-web-twig-demo && \
yarn link @lmc-eu/spirit-demo && \
\
cd /srv/spirit-design-tokens && \
yarn link && \
cd /srv/spirit-web-twig-demo && \
yarn link @lmc-eu/spirit-design-tokens && \
\
cd /srv/spirit-common && \
yarn link && \
cd /srv/spirit-web-twig-demo && \
yarn link @lmc-eu/spirit-common"
encore-build: ## Build demo assets
cd $(APP_DOCKER_DIR) && $(DOCKER_COMP) exec $(DOCKER_ENCORE_SERVICE) yarn build
encore-watch: ## Watch demo assets
cd $(APP_DOCKER_DIR) && $(DOCKER_COMP) exec $(DOCKER_ENCORE_SERVICE) yarn watch
encore-sh: ## Connect to encore using bash
cd $(APP_DOCKER_DIR) && $(DOCKER_COMP) exec $(DOCKER_ENCORE_SERVICE) sh
encore-logs: ## Show live logs for Encore service
cd $(APP_DOCKER_DIR) && $(DOCKER_COMP) logs $(DOCKER_ENCORE_SERVICE) --tail=0 --follow
encore: encore-link ## Start demo client
## —— 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)
install: ## Install vendors according to the current composer.lock file
install: c=install --prefer-dist --no-progress --no-interaction
install: composer
phpstan: ## Run composer phpstan
@$(COMPOSER) phpstan
phpunit: ## Run composer phpunit
@$(COMPOSER) phpunit
phpunit-update: ## Run composer phpunit:update
@$(COMPOSER) phpunit:update
phpunit-coverage: ## Run composer phpunit:coverage
@$(COMPOSER) phpunit:coverage
ecs: ## Run composer ecs
@$(COMPOSER) ecs
ecs-fix: ## Run composer ecs-fix
@$(COMPOSER) ecs:fix
lint: ## Run linting
@$(COMPOSER) lint
lint-fix: ## Fix linting errors
@$(COMPOSER) lint:fix
test: ## Run composer tests
@$(COMPOSER) test
## —— Helpers 🔧 —————————————————————————————————————————————————————————————————
icons-build: ## Build Icons package
cd $(ICONS_PKG_DIR) && yarn build
## —— Makefile 📜 ————————————————————————————————————————————————————————————————
make: ## Run makefile in app pass the parameter "c=" to run a given command, example: make make c=npm-test
@$(eval c ?=)
@$(CONT_MAKE) $(c)