mirror of
https://github.com/bigchaindb/bigchaindb.git
synced 2024-10-13 13:34:05 +00:00

Solution: Do not rely on depends_on when running containers in the foreground. Solves #2322.
145 lines
4.4 KiB
Makefile
145 lines
4.4 KiB
Makefile
.PHONY: help run start stop logs test test-unit test-unit-watch test-acceptance cov doc doc-acceptance clean reset release dist check-deps clean-build clean-pyc clean-test
|
|
|
|
.DEFAULT_GOAL := help
|
|
|
|
|
|
#############################
|
|
# Open a URL in the browser #
|
|
#############################
|
|
define BROWSER_PYSCRIPT
|
|
import os, webbrowser, sys
|
|
try:
|
|
from urllib import pathname2url
|
|
except:
|
|
from urllib.request import pathname2url
|
|
|
|
webbrowser.open("file://" + pathname2url(os.path.abspath(sys.argv[1])))
|
|
endef
|
|
export BROWSER_PYSCRIPT
|
|
|
|
|
|
##################################
|
|
# Display help for this makefile #
|
|
##################################
|
|
define PRINT_HELP_PYSCRIPT
|
|
import re, sys
|
|
|
|
print("BigchainDB 2.0 developer toolbox")
|
|
print("--------------------------------")
|
|
print("Usage: make COMMAND")
|
|
print("")
|
|
print("Commands:")
|
|
for line in sys.stdin:
|
|
match = re.match(r'^([a-zA-Z_-]+):.*?## (.*)$$', line)
|
|
if match:
|
|
target, help = match.groups()
|
|
print(" %-16s %s" % (target, help))
|
|
endef
|
|
export PRINT_HELP_PYSCRIPT
|
|
|
|
##################
|
|
# Basic commands #
|
|
##################
|
|
DOCKER := docker
|
|
DC := docker-compose
|
|
BROWSER := python -c "$$BROWSER_PYSCRIPT"
|
|
HELP := python -c "$$PRINT_HELP_PYSCRIPT"
|
|
ECHO := /usr/bin/env echo
|
|
|
|
IS_DOCKER_COMPOSE_INSTALLED := $(shell command -v docker-compose 2> /dev/null)
|
|
|
|
################
|
|
# Main targets #
|
|
################
|
|
|
|
help: ## Show this help
|
|
@$(HELP) < $(MAKEFILE_LIST)
|
|
|
|
run: check-deps ## Run BigchainDB from source (stop it with ctrl+c)
|
|
# although bigchaindb has tendermint and mongodb in depends_on,
|
|
# launch them first otherwise tendermint will get stuck upon sending yet another log
|
|
# due to some docker-compose issue; does not happen when containers are run as daemons
|
|
@$(DC) up --no-deps mongodb tendermint bigchaindb
|
|
|
|
start: check-deps ## Run BigchainDB from source and daemonize it (stop with `make stop`)
|
|
@$(DC) up -d bigchaindb
|
|
|
|
stop: check-deps ## Stop BigchainDB
|
|
@$(DC) stop
|
|
|
|
logs: check-deps ## Attach to the logs
|
|
@$(DC) logs -f bigchaindb
|
|
|
|
test: check-deps test-unit test-acceptance ## Run unit and acceptance tests
|
|
|
|
test-unit: check-deps ## Run all tests once
|
|
@$(DC) up -d bdb
|
|
@$(DC) exec bigchaindb pytest
|
|
|
|
test-unit-watch: check-deps ## Run all tests and wait. Every time you change code, tests will be run again
|
|
@$(DC) run --rm --no-deps bigchaindb pytest -f
|
|
|
|
test-acceptance: check-deps ## Run all acceptance tests
|
|
@./run-acceptance-test.sh
|
|
|
|
cov: check-deps ## Check code coverage and open the result in the browser
|
|
@$(DC) run --rm bigchaindb pytest -v --cov=bigchaindb --cov-report html
|
|
$(BROWSER) htmlcov/index.html
|
|
|
|
doc: check-deps ## Generate HTML documentation and open it in the browser
|
|
@$(DC) run --rm --no-deps bdocs make -C docs/root html
|
|
@$(DC) run --rm --no-deps bdocs make -C docs/server html
|
|
@$(DC) run --rm --no-deps bdocs make -C docs/contributing html
|
|
$(BROWSER) docs/root/build/html/index.html
|
|
|
|
doc-acceptance: check-deps ## Create documentation for acceptance tests
|
|
@$(DC) run --rm python-acceptance pycco -i -s /src -d /docs
|
|
$(BROWSER) acceptance/python/docs/index.html
|
|
|
|
clean: clean-build clean-pyc clean-test ## Remove all build, test, coverage and Python artifacts
|
|
@$(ECHO) "Cleaning was successful."
|
|
|
|
reset: check-deps ## Stop and REMOVE all containers. WARNING: you will LOSE all data stored in BigchainDB.
|
|
@$(DC) down
|
|
|
|
release: dist ## package and upload a release
|
|
twine upload dist/*
|
|
|
|
dist: clean ## builds source (and not for now, wheel package)
|
|
python setup.py sdist
|
|
# python setup.py bdist_wheel
|
|
ls -l dist
|
|
|
|
###############
|
|
# Sub targets #
|
|
###############
|
|
|
|
check-deps:
|
|
ifndef IS_DOCKER_COMPOSE_INSTALLED
|
|
@$(ECHO) "Error: docker-compose is not installed"
|
|
@$(ECHO)
|
|
@$(ECHO) "You need docker-compose to run this command. Check out the official docs on how to install it in your system:"
|
|
@$(ECHO) "- https://docs.docker.com/compose/install/"
|
|
@$(ECHO)
|
|
@$(DC) # docker-compose is not installed, so we call it to generate an error and exit
|
|
endif
|
|
|
|
clean-build: # Remove build artifacts
|
|
@rm -fr build/
|
|
@rm -fr dist/
|
|
@rm -fr .eggs/
|
|
@find . -name '*.egg-info' -exec rm -fr {} +
|
|
@find . -name '*.egg' -exec rm -f {} +
|
|
|
|
clean-pyc: # Remove Python file artifacts
|
|
@find . -name '*.pyc' -exec rm -f {} +
|
|
@find . -name '*.pyo' -exec rm -f {} +
|
|
@find . -name '*~' -exec rm -f {} +
|
|
@find . -name '__pycache__' -exec rm -fr {} +
|
|
|
|
clean-test: # Remove test and coverage artifacts
|
|
@find . -name '.pytest_cache' -exec rm -fr {} +
|
|
@rm -fr .tox/
|
|
@rm -f .coverage
|
|
@rm -fr htmlcov/
|