|
| 1 | +# set all to phony |
| 2 | +SHELL=bash |
| 3 | + |
| 4 | +.PHONY: * |
| 5 | + |
| 6 | +COMPOSER_SHOW_EXTENSION_LIST=$(shell composer show -t | grep -o "\-\-\(ext-\).\+" | sort | uniq | cut -d- -f4- | tr -d '\n' | grep . | sed '/^$$/d' | xargs | sed -e 's/ /, /g' | tr -cd '[:alnum:],' | sed 's/.$$//') |
| 7 | +SLIM_DOCKER_IMAGE=$(shell php -r 'echo count(array_intersect(["gd", "vips"], explode(",", "${COMPOSER_SHOW_EXTENSION_LIST}"))) > 0 ? "" : "-slim";') |
| 8 | +PHP_VERSION:=$(shell docker run --rm -v "`pwd`:`pwd`" jess/jq jq -r -c '.config.platform.php' "`pwd`/composer.json" | php -r "echo str_replace('|', '.', explode('.', implode('|', explode('.', stream_get_contents(STDIN), 2)), 2)[0]);") |
| 9 | +CONTAINER_NAME=$(shell echo "ghcr.io/wyrihaximusnet/php:${PHP_VERSION}-nts-alpine${SLIM_DOCKER_IMAGE}-dev") |
| 10 | +COMPOSER_CACHE_DIR=$(shell composer config --global cache-dir -q || echo ${HOME}/.composer-php/cache) |
| 11 | +COMPOSER_CONTAINER_CACHE_DIR=$(shell docker run --rm -it ${CONTAINER_NAME} composer config --global cache-dir -q || echo ${HOME}/.composer-php/cache) |
| 12 | + |
| 13 | +ifneq ("$(wildcard /.you-are-in-a-wyrihaximus.net-php-docker-image)","") |
| 14 | + IN_DOCKER=TRUE |
| 15 | +else |
| 16 | + IN_DOCKER=FALSE |
| 17 | +endif |
| 18 | + |
| 19 | +ifeq ("$(IN_DOCKER)","TRUE") |
| 20 | + DOCKER_RUN:= |
| 21 | +else |
| 22 | + DOCKER_RUN:=docker run --rm -it \ |
| 23 | + -v "`pwd`:`pwd`" \ |
| 24 | + -v "${COMPOSER_CACHE_DIR}:${COMPOSER_CONTAINER_CACHE_DIR}" \ |
| 25 | + -w "`pwd`" \ |
| 26 | + ${CONTAINER_NAME} |
| 27 | +endif |
| 28 | + |
| 29 | +ifneq (,$(findstring icrosoft,$(shell cat /proc/version))) |
| 30 | + THREADS=1 |
| 31 | +else |
| 32 | + THREADS=$(shell nproc) |
| 33 | +endif |
| 34 | + |
| 35 | +all: ## Runs everything #### |
| 36 | + @grep -E '^[a-zA-Z0-9_-]+:.*?## .*$$' $(MAKEFILE_LIST) | grep -v "####" | awk 'BEGIN {FS = ":.*?## "}; {printf "%s\n", $$1}' | xargs --open-tty $(MAKE) |
| 37 | + |
| 38 | +syntax-php: ## Lint PHP syntax |
| 39 | + $(DOCKER_RUN) vendor/bin/parallel-lint --exclude vendor . |
| 40 | + |
| 41 | +cs-fix: ## Fix any automatically fixable code style issues ### |
| 42 | + $(DOCKER_RUN) vendor/bin/phpcbf --parallel=$(THREADS) --cache=./var/.phpcs.cache.json --standard=./etc/qa/phpcs.xml || $(DOCKER_RUN) vendor/bin/phpcbf --parallel=$(THREADS) --cache=./var/.phpcs.cache.json --standard=./etc/qa/phpcs.xml || $(DOCKER_RUN) vendor/bin/phpcbf --parallel=$(THREADS) --cache=./var/.phpcs.cache.json --standard=./etc/qa/phpcs.xml -vvvv |
| 43 | + |
| 44 | +cs: ## Check the code for code style issues |
| 45 | + $(DOCKER_RUN) vendor/bin/phpcs --parallel=$(THREADS) --cache=./var/.phpcs.cache.json --standard=./etc/qa/phpcs.xml |
| 46 | + |
| 47 | +stan: ## Run static analysis (PHPStan) |
| 48 | + $(DOCKER_RUN) vendor/bin/phpstan analyse src tests --level max --ansi -c ./etc/qa/phpstan.neon |
| 49 | + |
| 50 | +psalm: ## Run static analysis (Psalm) |
| 51 | + $(DOCKER_RUN) vendor/bin/psalm --threads=$(THREADS) --shepherd --stats --config=./etc/qa/psalm.xml |
| 52 | + |
| 53 | +unit-testing: ## Run tests |
| 54 | + $(DOCKER_RUN) vendor/bin/phpunit --colors=always -c ./etc/qa/phpunit.xml --coverage-text --coverage-html ./var/tests-unit-coverage-html --coverage-clover ./var/tests-unit-clover-coverage.xml |
| 55 | + $(DOCKER_RUN) test -n "$(COVERALLS_REPO_TOKEN)" && test -n "$(COVERALLS_RUN_LOCALLY)" && test -f ./var/tests-unit-clover-coverage.xml && vendor/bin/php-coveralls -v --coverage_clover ./build/logs/clover.xml --json_path ./var/tests-unit-clover-coverage-upload.json || true |
| 56 | + |
| 57 | +unit-testing-raw: ## Run tests #### |
| 58 | + php vendor/phpunit/phpunit/phpunit --colors=always -c ./etc/qa/phpunit.xml --coverage-text --coverage-html ./var/tests-unit-coverage-html --coverage-clover ./var/tests-unit-clover-coverage.xml |
| 59 | + test -n "$(COVERALLS_REPO_TOKEN)" && test -n "$(COVERALLS_RUN_LOCALLY)" && test -f ./var/tests-unit-clover-coverage.xml && ./vendor/bin/php-coveralls -v --coverage_clover ./build/logs/clover.xml --json_path ./var/tests-unit-clover-coverage-upload.json || true |
| 60 | + |
| 61 | +mutation-testing: ## Run mutation testing |
| 62 | + $(DOCKER_RUN) vendor/bin/roave-infection-static-analysis-plugin --ansi --log-verbosity=all --threads=$(THREADS) --psalm-config etc/qa/psalm.xml || (cat ./var/infection.log && false) |
| 63 | + |
| 64 | +mutation-testing-raw: ## Run mutation testing #### |
| 65 | + php vendor/roave/infection-static-analysis-plugin/bin/roave-infection-static-analysis-plugin --ansi --log-verbosity=all --threads=$(THREADS) --psalm-config etc/qa/psalm.xml || (cat ./var/infection.log && false) |
| 66 | + |
| 67 | +composer-require-checker: ## Ensure we require every package used in this package directly |
| 68 | + $(DOCKER_RUN) vendor/bin/composer-require-checker --ignore-parse-errors --ansi -vvv --config-file=./etc/qa/composer-require-checker.json |
| 69 | + |
| 70 | +composer-unused: ## Ensure we don't require any package we don't use in this package directly |
| 71 | + $(DOCKER_RUN) vendor/bin/composer-unused --ansi --configuration=./etc/qa/composer-unused.php |
| 72 | + |
| 73 | +composer-install: ## Install dependencies |
| 74 | + $(DOCKER_RUN) composer install --no-progress --ansi --no-interaction --prefer-dist -o |
| 75 | + |
| 76 | +backward-compatibility-check: ## Check code for backwards incompatible changes |
| 77 | + $(MAKE) backward-compatibility-check-raw || true |
| 78 | + |
| 79 | +backward-compatibility-check-raw: ## Check code for backwards incompatible changes, doesn't ignore the failure ### |
| 80 | + $(DOCKER_RUN) vendor/bin/roave-backward-compatibility-check |
| 81 | + |
| 82 | +shell: ## Provides Shell access in the expected environment #### |
| 83 | + $(DOCKER_RUN) bash |
| 84 | + |
| 85 | +install: ## Install dependencies #### |
| 86 | + $(DOCKER_RUN) composer install |
| 87 | + |
| 88 | +update: ## Update dependencies #### |
| 89 | + $(DOCKER_RUN) composer update -W |
| 90 | + |
| 91 | +outdated: ## Show outdated dependencies #### |
| 92 | + $(DOCKER_RUN) composer outdated |
| 93 | + |
| 94 | +task-list-ci: ## CI: Generate a JSON array of jobs to run, matches the commands run when running `make (|all)` #### |
| 95 | + @grep -E '^[a-zA-Z0-9_-]+:.*?## .*$$' $(MAKEFILE_LIST) | grep -v "###" | sort | awk 'BEGIN {FS = ":.*?## "}; {printf "%s\n", $$1}' | jq --raw-input --slurp -c 'split("\n")| .[0:-1]' |
| 96 | + |
| 97 | +help: ## Show this help #### |
| 98 | + @printf "\033[33mUsage:\033[0m\n make [target]\n\n\033[33mTargets:\033[0m\n" |
| 99 | + @grep -E '^[a-zA-Z0-9_-]+:.*?## .*$$' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?## "}; {printf " \033[32m%-32s\033[0m %s\n", $$1, $$2}' | tr -d '#' |
0 commit comments