-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
123 lines (98 loc) · 4.29 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
COLOUR_GREEN=\033[0;32m
COLOUR_RED=\033[0;31m
COLOUR_BLUE=\033[0;34m
COLOUR_END=\033[0m
.DEFAULT_GOAL:=help
SHELL:=/bin/bash
## checking if docker, or podman should be used. Podman is preferred.
ifeq ($(shell command -v podman 2> /dev/null),)
CONTAINERCMD=docker
else
CONTAINERCMD=podman
endif
# Checking if python exists
ifneq (, $(shell command -v python))
$(info Python is installed as 'python')
PYTHON := $(shell command -v python)
else ifneq (, $(shell command -v python3))
$(info Python3 is installed as 'python3')
PYTHON := $(shell command -v python3)
else
$(error Neither python nor python3 is installed)
endif
## Export default rookify version
export ROOKIFY_VERSION?=0.0.0.dev1
.PHONY: help
help: ## Display this help message
@echo -e '\n${COLOUR_BLUE}ROOKIFY MAKEFILE${COLOUR_BLUE}'
@echo -e '\n${COLOUR_RED}Usage: make <command>${COLOUR_END}'
@cat $(MAKEFILE_LIST) | grep '^[a-zA-Z]' | \
awk -F ':.*?## ' 'NF==2 {printf " %-26s%s\n\n", $$1, "${COLOUR_GREEN}"$$2"${COLOUR_END}"}'
@echo -e '${COLOUR_RED}Container related commands${COLOUR_END}'
@cat $(MAKEFILE_LIST) | grep '^[a-zA-Z]' | \
awk -F ':.*?#container# ' 'NF==2 {printf " %-26s%s\n\n", $$1, "${COLOUR_GREEN}"$$2"${COLOUR_END}"}'
@echo -e '${COLOUR_RED}OSISM helperscripts${COLOUR_END}'
@cat $(MAKEFILE_LIST) | grep '^[a-zA-Z]' | \
awk -F ':.*?#osism# ' 'NF==2 {printf " %-26s%s\n\n", $$1, "${COLOUR_GREEN}"$$2"${COLOUR_END}"}'
.PHONY: setup
setup: check-radoslib setup-venv setup-pre-commit ## Setup the pre-commit environment and then the venv environment
.PHONY: setup-pre-commit
setup-pre-commit:
./.venv/bin/pip install --user pre-commit && ./.venv/bin/python -m pre_commit install
.PHONY: setup-venv
setup-venv:
${PYTHON} -m venv --system-site-packages ./.venv && \
./.venv/bin/pip install -r requirements.txt
.PHONY: run-precommit
run-precommit: ## Run pre-commit to check if all files running through
pre-commit run --all-files
.PHONY: update-requirements
update-requirements: ## Update the requirements.txt with newer versions of pip packages
source ./.venv/bin/activate && \
pip freeze -l > requirements.txt
.PHONY: check-radoslib
export RADOSLIB_VERSION:=2.0.0
check-radoslib: ## Checks if radoslib is installed and if it contains the right version
# Get needed paths and information from locally installed librados
./scripts/check_local_rados_lib_installation.sh ${RADOSLIB_VERSION}
.PHONY: build-local-rookify
build-local-rookify: setup ## This builds rookify into .venv/bin/rookify
source .venv/bin/activate && pip install -e .
.PHONY: run-local-rookify
run-local-rookify: build-local-rookify ## Runs rookify in the local development environment (requires setup-venv)
./.venv/bin/rookify
.PHONY: run-tests-locally
run-tests-locally: setup-venv ## Runs the tests in the tests directory. NB: check that your local setup is connected through vpn to the testbed!
.venv/bin/python -m pytest
##
# Add container related commands here (so they appear below the container header)
# Note: use #container# so command appear under header in menu
##
.PHONY: run-tests
run-tests: up #container# Runs the tests in the container
${CONTAINERCMD} exec -it rookify-dev bash -c "/app/rookify/.venv/bin/python -m pytest"
.PHONY: run-rookify
run-rookify: up #container# Runs rookify in the container
${CONTAINERCMD} exec -it rookify-dev /app/rookify/.venv/bin/rookify
.PHONY: enter
enter: up #container# Enter the container
${CONTAINERCMD} exec -it rookify-dev bash
.PHONY: logs
logs: #container# Logs the container
${CONTAINERCMD} logs -f rookify-dev
.PHONY: down
down: #container# Remove the containers as setup by docker-compose.yml
${CONTAINERCMD} compose down
.PHONY: up
up: #container# Sets up the container as specified in docker-compose.yml and opens a bash terminal
${CONTAINERCMD} compose up -d
.PHONY: build-container
build-container: #container# Build container from Dockerfile only, add e.g. ROOKIFY_VERSION=0.0.1 to specify the version. Default value is 0.0.0.dev1
${CONTAINERCMD} build --build-arg ROOKIFY_VERSION=$(ROOKIFY_VERSION) --target rookify -t rookify:latest -f Dockerfile .
##
# Add osism specific scripts below here
# Note: use #osism# so command appear under header in menu
##
.PHONY: get-config
get-config: #osism# Gets configuration files from the OSISM testbed
./scripts/osism/get_configs_from_testbed.sh