DOCKER_TAG := markdone-dev OPEN_CMD := $(shell type xdg-open &> /dev/null && echo 'xdg-open' || echo 'open') .PHONY: default default: test # Builds the python3 venv with all dev requirements env: python3 -m venv env ./env/bin/pip install -r requirements-dev.txt # Generates a smaller env for running tox, which builds it's own env .PHONY: test-env test-env: python3 -m venv env ./env/bin/pip install tox # Runs tests with tox .PHONY: test test: env ./env/bin/tox # Generates a small build env for building and uploading dists .PHONY: build-env build-env: python3 -m venv env ./env/bin/pip install twine wheel # Builds wheel for package to upload .PHONY: build build: env ./env/bin/python setup.py sdist ./env/bin/python setup.py bdist_wheel # Verify that the python version matches the git tag so we don't push bad shas .PHONY: verify-tag-version verify-tag-version: $(eval TAG_NAME = $(shell [ -n "$(DRONE_TAG)" ] && echo $(DRONE_TAG) || git describe --tags --exact-match)) test "v$(shell python setup.py -V)" = "$(TAG_NAME)" # Uses twine to upload to pypi .PHONY: upload upload: verify-tag-version build ./env/bin/twine upload dist/* # Uses twine to upload to test pypi .PHONY: upload-test upload-test: verify-tag-version build ./env/bin/twine upload --repository-url https://test.pypi.org/legacy/ dist/* # Cleans all build, runtime, and test artifacts .PHONY: clean clean: rm -fr ./build ./markdone_python.egg-info ./htmlcov ./.coverage ./.pytest_cache ./.tox find . -name '*.pyc' -delete find . -name '__pycache__' -delete # Cleans dist and env .PHONY: dist-clean dist-clean: clean rm -fr ./dist ./env # Install pre-commit hooks .PHONY: install-hooks install-hooks: env ./env/bin/tox -e pre-commit -- install -f --install-hooks # Generates test coverage .coverage: ./env/bin/tox # Builds coverage html htmlcov/index.html: .coverage ./env/bin/coverage html # Opens coverage html in browser (on macOS and some Linux systems) .PHONY: open-coverage open-coverage: htmlcov/index.html $(OPEN_CMD) htmlcov/index.html .PHONY: docker-build docker-build: docker build . -t $(DOCKER_TAG)