-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathMakefile
175 lines (147 loc) · 3.7 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
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
SHELL := /bin/bash
DOCKER_REGISTRY ?= ""
TAG ?= latest
.PHONY: setup
setup:
@pipenv install --three
.PHONY: setup-dev
setup-dev: set-hooks gen-secrets-folder
@pipenv install --dev --three
.PHONY: requirements.txt
requirements.txt:
@pipenv update
@pipenv lock -r > requirements.txt
.PHONY: set-hooks
set-hooks:
@echo "Setting commit hooks"
@ ([ ! -L ".git/hooks/pre-commit" ] && ln -s $(PWD)/scripts/git-hooks/pre-commit.sh .git/hooks/pre-commit) || true
.PHONY: gen-secrets-folder
gen-secrets-folder:
@./scripts/gen-secrets-folder
.PHONY: create-ca
create-ca: gen-secrets-folder
@pipenv run python3 ./scripts/create-ca
.PHONY: create-pgp-key
create-pgp-key: gen-secrets-folder
@./scripts/gen-gnupg-key
.PHONY: format
format:
pipenv run black ./**/*.py
.PHONY: lint
lint:
pipenv run flake8 ./**/*.py
pipenv run black --check ./**/*.py
.PHONY: coverage
coverage:
-@pipenv run coverage combine -a
@pipenv run coverage report -m
.PHONY: coveralls
coveralls:
-@pipenv run coverage combine -a
@pipenv run coveralls
.PHONY: test
test:
ifeq "${CI}" ""
-$(MAKE) stop-postgres
$(MAKE) run-postgres
@until pg_isready -h localhost -p 5432; do echo waiting for database; sleep 2; done
endif
coverage run -m unittest discover -v -s test
ifeq "${CI}" ""
$(MAKE) stop-postgres
endif
.PHONY: test.dev
test.dev:
pipenv run $(MAKE) test
.PHONY: test-by-name
test-by-name:
ifeq "${CI}" ""
$(MAKE) run-postgres
@until pg_isready -U postgres -h localhost -p 5432; do echo waiting for database; sleep 2; done
endif
-@coverage run -m unittest $(NAME) -v
ifeq "${CI}" ""
$(MAKE) stop-postgres
endif
.PHONY: test-by-name.dev
test-by-name.dev:
pipenv run $(MAKE) test-by-name
.PHONY: integration-test
integration-test:
ifeq "${CI}" ""
-$(MAKE) stop-postgres
$(MAKE) run-postgres
@until pg_isready -h localhost -p 5432; do echo waiting for database; sleep 2; done
endif
coverage run -m unittest discover -v -s integration_test
ifeq "${CI}" ""
$(MAKE) stop-postgres
endif
.PHONY: integration-test.dev
integration-test.dev:
pipenv run $(MAKE) integration-test
.PHONY: build-image
build-image:
@docker build -t mtls-server:$(TAG) .
.PHONY: build-pypi
build-pypi:
@pipenv run python setup.py sdist bdist_wheel
.PHONY: tag-image
tag-image: build-image
@docker tag mtls-server:$(TAG) $(DOCKER_REGISTRY)mtls-server:$(TAG)
@echo "Tagged image: $(DOCKER_REGISTRY)mtls-server:$(TAG)"
.PHONY: run-postgres
run-postgres:
@docker run \
--name mtls-postgres \
--rm \
-d \
-e POSTGRES_DB=mtls \
-e POSTGRES_PASSWORD=mtls \
-e POSTGRES_HOST_AUTH_METHOD=trust \
-p 5432:5432 \
postgres:12
.PHONY: stop-postgres
stop-postgres:
-docker stop mtls-postgres
.PHONY: run
run:
@pipenv run python3 server.py
.PHONY: run.debug
run.debug:
@pipenv run python3 -m pdb mtls_server/server.py
.PHONY: run-prod
run-prod: build-image run-postgres
@docker run \
--name mtls-server \
--rm \
-d \
-v $(PWD)/secrets/gnupg:/home/mtls/secrets/gnupg \
-v $(PWD)/secrets/gnupg_admin:/home/mtls/secrets/gnupg_admin \
-v $(PWD)/secrets/certs/authority:/home/mtls/secrets/certs/authority \
-v $(PWD)/config.ini:/home/mtls/config.ini \
$(DOCKER_REGISTRY)mtls-server:$(TAG)
@docker run \
--name mtls-nginx \
--rm \
-d \
-p 443:443 \
--link mtls-server:mtls \
-v $(PWD)/nginx/nginx.conf:/etc/nginx/nginx.conf \
-v $(PWD)/nginx/includes:/etc/nginx/includes \
-v $(PWD)/secrets/certs/authority:/etc/nginx/ssl/client_certs/ \
-v $(PWD)/nginx/html:/usr/share/nginx/ \
nginx
.PHONY: stop-prod
stop-prod:
@docker stop mtls-nginx
@docker stop mtls-server
@docker stop mtls-postgres
.PHONY: clean
clean:
pipenv clean
rm -r build dist mtls_server.egg-info
.PHONY: .drone.yml
.drone.yml:
drone jsonnet --stream
drone sign --save drGrove/mtls-server