| # Licensed under the Apache License: http://www.apache.org/licenses/LICENSE-2.0 |
| # For details: https://github.com/nedbat/coveragepy/blob/master/NOTICE.txt |
| |
| # Makefile for utility work on coverage.py. |
| |
| .DEFAULT_GOAL := help |
| |
| |
| ##@ Utilities |
| |
| .PHONY: help clean_platform clean sterile install |
| |
| help: ## Show this help. |
| @# Adapted from https://www.thapaliya.com/en/writings/well-documented-makefiles/ |
| @echo Available targets: |
| @awk -F ':.*##' '/^[^: ]+:.*##/{printf " \033[1m%-20s\033[m %s\n",$$1,$$2} /^##@/{printf "\n%s\n",substr($$0,5)}' $(MAKEFILE_LIST) |
| |
| _clean_platform: |
| @rm -f *.so */*.so |
| @rm -f *.pyd */*.pyd |
| @rm -rf __pycache__ */__pycache__ */*/__pycache__ */*/*/__pycache__ */*/*/*/__pycache__ */*/*/*/*/__pycache__ |
| @rm -f *.pyc */*.pyc */*/*.pyc */*/*/*.pyc */*/*/*/*.pyc */*/*/*/*/*.pyc |
| @rm -f *.pyo */*.pyo */*/*.pyo */*/*/*.pyo */*/*/*/*.pyo */*/*/*/*/*.pyo |
| @rm -f *$$py.class */*$$py.class */*/*$$py.class */*/*/*$$py.class */*/*/*/*$$py.class */*/*/*/*/*$$py.class |
| |
| debug_clean: ## Delete various debugging artifacts. |
| @rm -rf /tmp/dis $$COVERAGE_DEBUG_FILE |
| |
| clean: debug_clean _clean_platform ## Remove artifacts of test execution, installation, etc. |
| @echo "Cleaning..." |
| @-pip uninstall -yq coverage |
| @mkdir -p build # so the chmod won't fail if build doesn't exist |
| @chmod -R 777 build |
| @rm -rf build coverage.egg-info dist htmlcov |
| @rm -f *.bak */*.bak */*/*.bak */*/*/*.bak */*/*/*/*.bak */*/*/*/*/*.bak |
| @rm -f coverage/*,cover |
| @rm -f MANIFEST |
| @rm -f .coverage .coverage.* .metacov* |
| @rm -f coverage.xml coverage.json |
| @rm -f .tox/*/lib/*/site-packages/zzz_metacov.pth |
| @rm -f */.coverage */*/.coverage */*/*/.coverage */*/*/*/.coverage */*/*/*/*/.coverage */*/*/*/*/*/.coverage |
| @rm -f tests/covmain.zip tests/zipmods.zip tests/zip1.zip |
| @rm -rf doc/_build doc/_spell doc/sample_html_beta |
| @rm -rf tmp |
| @rm -rf .*cache */.*cache */*/.*cache */*/*/.*cache .hypothesis |
| @rm -rf tests/actual |
| @-make -C tests/gold/html clean |
| |
| sterile: clean ## Remove all non-controlled content, even if expensive. |
| rm -rf .tox |
| rm -f cheats.txt |
| |
| install: ## Install the developer tools |
| python3 -m pip install -r requirements/dev.pip |
| |
| |
| ##@ Tests and quality checks |
| |
| .PHONY: lint smoke |
| |
| lint: ## Run linters and checkers. |
| tox -q -e lint |
| |
| PYTEST_SMOKE_ARGS = -n auto -m "not expensive" --maxfail=3 $(ARGS) |
| |
| smoke: ## Run tests quickly with the C tracer in the lowest supported Python versions. |
| COVERAGE_TEST_CORES=ctrace tox -q -e py38 -- $(PYTEST_SMOKE_ARGS) |
| |
| |
| ##@ Metacov: coverage measurement of coverage.py itself |
| # See metacov.ini for details. |
| |
| .PHONY: metacov metahtml metasmoke |
| |
| metacov: ## Run meta-coverage, measuring ourself. |
| COVERAGE_COVERAGE=yes tox -q $(ARGS) |
| |
| metahtml: ## Produce meta-coverage HTML reports. |
| tox exec -q $(ARGS) -- python3 igor.py combine_html |
| |
| metasmoke: |
| COVERAGE_TEST_CORES=ctrace ARGS="-e py39" make --keep-going metacov metahtml |
| |
| |
| ##@ Requirements management |
| |
| # When updating requirements, a few rules to follow: |
| # |
| # 1) Don't install more than one .pip file at once. Always use pip-compile to |
| # combine .in files onto a single .pip file that can be installed where needed. |
| # |
| # 2) Check manual pins before `make upgrade` to see if they can be removed. Look |
| # in requirements/pins.pip, and search for "windows" in .in files to find pins |
| # and extra requirements that have been needed, but might be obsolete. |
| |
| .PHONY: upgrade doc_upgrade diff_upgrade |
| |
| DOCBIN = .tox/doc/bin |
| |
| |
| PIP_COMPILE = pip-compile ${COMPILE_OPTS} --allow-unsafe --resolver=backtracking |
| upgrade: ## Update the *.pip files with the latest packages satisfying *.in files. |
| $(MAKE) _upgrade COMPILE_OPTS="--upgrade" |
| |
| upgrade_one: ## Update the *.pip files for one package. `make upgrade_one package=...` |
| @test -n "$(package)" || { echo "\nUsage: make upgrade-one package=...\n"; exit 1; } |
| $(MAKE) _upgrade COMPILE_OPTS="--upgrade-package $(package)" |
| |
| _upgrade: export CUSTOM_COMPILE_COMMAND=make upgrade |
| _upgrade: |
| pip install -q -r requirements/pip-tools.pip |
| $(PIP_COMPILE) -o requirements/pip-tools.pip requirements/pip-tools.in |
| $(PIP_COMPILE) -o requirements/pip.pip requirements/pip.in |
| $(PIP_COMPILE) -o requirements/pytest.pip requirements/pytest.in |
| $(PIP_COMPILE) -o requirements/kit.pip requirements/kit.in |
| $(PIP_COMPILE) -o requirements/tox.pip requirements/tox.in |
| $(PIP_COMPILE) -o requirements/dev.pip requirements/dev.in |
| $(PIP_COMPILE) -o requirements/light-threads.pip requirements/light-threads.in |
| $(PIP_COMPILE) -o requirements/mypy.pip requirements/mypy.in |
| |
| doc_upgrade: export CUSTOM_COMPILE_COMMAND=make doc_upgrade |
| doc_upgrade: $(DOCBIN) ## Update the doc/requirements.pip file |
| $(DOCBIN)/pip install -q -r requirements/pip-tools.pip |
| $(DOCBIN)/$(PIP_COMPILE) --upgrade -o doc/requirements.pip doc/requirements.in |
| |
| diff_upgrade: ## Summarize the last `make upgrade` |
| @# The sort flags sort by the package name first, then by the -/+, and |
| @# sort by version numbers, so we get a summary with lines like this: |
| @# -bashlex==0.16 |
| @# +bashlex==0.17 |
| @# -build==0.9.0 |
| @# +build==0.10.0 |
| @git diff -U0 | grep -v '^@' | grep == | sort -k1.2,1.99 -k1.1,1.1r -u -V |
| |
| |
| ##@ Pre-builds for prepping the code |
| |
| .PHONY: css workflows prebuild |
| |
| CSS = coverage/htmlfiles/style.css |
| SCSS = coverage/htmlfiles/style.scss |
| |
| css: $(CSS) ## Compile .scss into .css. |
| $(CSS): $(SCSS) |
| pysassc --style=compact $(SCSS) $@ |
| cp $@ tests/gold/html/styled |
| |
| workflows: ## Run cog on the workflows to keep them up-to-date. |
| python -m cogapp -crP .github/workflows/*.yml |
| |
| prebuild: css workflows cogdoc ## One command for all source prep. |
| |
| |
| ##@ Sample HTML reports |
| |
| .PHONY: _sample_cog_html sample_html sample_html_beta |
| |
| _sample_cog_html: clean |
| python -m pip install -e . |
| cd ~/cog; \ |
| rm -rf htmlcov; \ |
| PYTEST_ADDOPTS= coverage run --branch --source=cogapp -m pytest -k CogTestsInMemory; \ |
| coverage combine; \ |
| coverage html |
| |
| sample_html: _sample_cog_html ## Generate sample HTML report. |
| rm -f doc/sample_html/*.* |
| cp -r ~/cog/htmlcov/ doc/sample_html/ |
| rm doc/sample_html/.gitignore |
| |
| sample_html_beta: _sample_cog_html ## Generate sample HTML report for a beta release. |
| rm -f doc/sample_html_beta/*.* |
| cp -r ~/cog/htmlcov/ doc/sample_html_beta/ |
| rm doc/sample_html_beta/.gitignore |
| |
| |
| ##@ Kitting: making releases |
| |
| .PHONY: release_version edit_for_release cheats relbranch relcommit1 relcommit2 |
| .PHONY: kit pypi_upload test_upload kit_local build_kits update_rtd |
| .PHONY: tag bump_version |
| |
| REPO_OWNER = nedbat/coveragepy |
| RTD_PROJECT = coverage |
| |
| release_version: #: Update the version for a release. |
| python igor.py release_version |
| |
| edit_for_release: #: Edit sources to insert release facts (see howto.txt). |
| python igor.py edit_for_release |
| |
| cheats: ## Create some useful snippets for releasing. |
| python igor.py cheats | tee cheats.txt |
| |
| relbranch: #: Create the branch for releasing (see howto.txt). |
| git switch -c nedbat/release-$$(date +%Y%m%d-%H%M%S) |
| |
| relcommit1: #: Commit the first release changes (see howto.txt). |
| git commit -am "docs: prep for $$(python setup.py --version)" |
| |
| relcommit2: #: Commit the latest sample HTML report (see howto.txt). |
| git add doc/sample_html |
| git commit -am "docs: sample HTML for $$(python setup.py --version)" |
| |
| kit: ## Make the source distribution. |
| python -m build |
| |
| pypi_upload: ## Upload the built distributions to PyPI. |
| python ci/trigger_action.py $(REPO_OWNER) publish-pypi |
| @echo "Use that^ URL to approve the upload" |
| |
| test_upload: ## Upload the distributions to PyPI's testing server. |
| python ci/trigger_action.py $(REPO_OWNER) publish-testpypi |
| @echo "Use that^ URL to approve the upload" |
| |
| kit_local: |
| # pip.conf looks like this: |
| # [global] |
| # find-links = file:///Users/ned/Downloads/local_pypi |
| cp -v dist/* `awk -F "//" '/find-links/ {print $$2}' ~/.pip/pip.conf` |
| # pip caches wheels of things it has installed. Clean them out so we |
| # don't go crazy trying to figure out why our new code isn't installing. |
| find ~/Library/Caches/pip/wheels -name 'coverage-*' -delete |
| |
| build_kits: ## Trigger GitHub to build kits |
| python ci/trigger_action.py $(REPO_OWNER) build-kits |
| |
| tag: #: Make a git tag with the version number (see howto.txt). |
| git tag -s -m "Version $$(python setup.py --version)" $$(python setup.py --version) |
| git push --follow-tags |
| |
| update_rtd: #: Update ReadTheDocs with the versions to show |
| python ci/update_rtfd.py $(RTD_PROJECT) |
| |
| bump_version: #: Edit sources to bump the version after a release (see howto.txt). |
| git switch -c nedbat/bump-version |
| python igor.py bump_version |
| git commit -a -m "build: bump version to $$(python setup.py --version | sed 's/a.*//')" |
| git push -u origin @ |
| |
| |
| ##@ Documentation |
| |
| .PHONY: cogdoc dochtml docdev docspell |
| |
| SPHINXOPTS = -aE |
| SPHINXBUILD = $(DOCBIN)/sphinx-build $(SPHINXOPTS) |
| SPHINXAUTOBUILD = $(DOCBIN)/sphinx-autobuild --port 9876 --ignore '.git/**' --open-browser |
| |
| $(DOCBIN): |
| tox -q -e doc --notest |
| |
| cogdoc: $(DOCBIN) ## Run docs through cog. |
| $(DOCBIN)/python -m cogapp -crP --verbosity=1 doc/*.rst |
| |
| dochtml: cogdoc $(DOCBIN) ## Build the docs HTML output. |
| $(SPHINXBUILD) -b html doc doc/_build/html |
| @echo "Start at: doc/_build/html/index.html" |
| |
| docdev: dochtml ## Build docs, and auto-watch for changes. |
| PATH=$(DOCBIN):$(PATH) $(SPHINXAUTOBUILD) -b html doc doc/_build/html |
| |
| docspell: $(DOCBIN) ## Run the spell checker on the docs. |
| # Very mac-specific... |
| PYENCHANT_LIBRARY_PATH=/opt/homebrew/lib/libenchant-2.dylib $(SPHINXBUILD) -b spelling doc doc/_spell |
| |
| |
| ##@ Publishing docs |
| |
| .PHONY: publish publishbeta github_releases comment_on_fixes |
| |
| WEBHOME = ~/web/stellated |
| WEBSAMPLE = $(WEBHOME)/files/sample_coverage_html |
| WEBSAMPLEBETA = $(WEBHOME)/files/sample_coverage_html_beta |
| |
| publish: ## Publish the sample HTML report. |
| rm -f $(WEBSAMPLE)/*.* |
| mkdir -p $(WEBSAMPLE) |
| cp doc/sample_html/*.* $(WEBSAMPLE) |
| |
| publishbeta: |
| rm -f $(WEBSAMPLEBETA)/*.* |
| mkdir -p $(WEBSAMPLEBETA) |
| cp doc/sample_html_beta/*.* $(WEBSAMPLEBETA) |
| |
| CHANGES_MD = tmp/rst_rst/changes.md |
| SCRIV_SOURCE = tmp/only-changes.md |
| |
| $(CHANGES_MD): CHANGES.rst $(DOCBIN) |
| $(SPHINXBUILD) -b rst doc tmp/rst_rst |
| pandoc -frst -tmarkdown_strict --markdown-headings=atx --wrap=none tmp/rst_rst/changes.rst > $(CHANGES_MD) |
| |
| $(SCRIV_SOURCE): $(CHANGES_MD) |
| @# Trim parts of the file that aren't changelog entries. |
| sed -n -e '/## Version/,/## Earlier/p' < $(CHANGES_MD) > tmp/trimmed.md |
| @# Replace sphinx references with published URLs. |
| sed -r -e 's@]\(([a-zA-Z0-9_]+)\.rst#([^)]+)\)@](https://coverage.readthedocs.io/en/latest/\1.html#\2)@g' < tmp/trimmed.md > $(SCRIV_SOURCE) |
| |
| github_releases: $(SCRIV_SOURCE) ## Update GitHub releases. |
| $(DOCBIN)/python -m scriv github-release --all |
| |
| comment_on_fixes: $(SCRIV_SOURCE) ## Add a comment to issues that were fixed. |
| python ci/comment_on_fixes.py $(REPO_OWNER) |