forked from mozilla-services/socorro
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
129 lines (104 loc) · 3.9 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
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
# Include my.env and export it so variables set in there are available
# in the Makefile.
include my.env
export
# Set these in the environment to override them. This is helpful for
# development if you have file ownership problems because the user
# in the container doesn't match the user on your host.
SOCORRO_UID ?= 10001
SOCORRO_GID ?= 10001
# Set this in the environment to force --no-cache docker builds.
DOCKER_BUILD_OPTS :=
ifeq (1, ${NOCACHE})
DOCKER_BUILD_OPTS := --no-cache
endif
DC := $(shell which docker-compose)
.DEFAULT_GOAL := help
.PHONY: help
help:
@echo "Usage: make RULE"
@echo ""
@grep -E '^[a-zA-Z0-9_-]+:.*?## .*$$' Makefile \
| grep -v grep \
| sed -n 's/^\(.*\): \(.*\)##\(.*\)/\1\3/p' \
| column -t -s '|'
@echo ""
@echo "See https://socorro.readthedocs.io/ for more documentation."
my.env:
@if [ ! -f my.env ]; \
then \
echo "Copying my.env.dist to my.env..."; \
cp docker/config/my.env.dist my.env; \
fi
.docker-build:
make build
.PHONY: build
build: my.env ## | Build docker images.
${DC} build ${DOCKER_BUILD_OPTS} --build-arg userid=${SOCORRO_UID} --build-arg groupid=${SOCORRO_GID} app
${DC} build oidcprovider
touch .docker-build
.docker-build-docs:
make build-docs
.PHONY: build-docs
build-docs: my.env
${DC} build ${DOCKER_BUILD_OPTS} --build-arg userid=${SOCORRO_UID} --build-arg groupid=${SOCORRO_GID} docs
touch .docker-build-docs
.PHONY: setup
setup: my.env .docker-build ## | Set up Postgres, Elasticsearch, local SQS, and local S3 services.
${DC} run --rm app shell /app/bin/setup_services.sh
.PHONY: updatedata
updatedata: my.env ## | Add/update necessary database data.
${DC} run --rm app shell /app/bin/update_data.sh
.PHONY: run
run: my.env ## | Run processor and webapp and all required services.
${DC} up processor webapp
.PHONY: runservices
runservices: my.env ## | Run service containers (Postgres, SQS, etc)
${DC} up -d statsd postgresql memcached localstack elasticsearch
.PHONY: stop
stop: my.env ## | Stop all service containers.
${DC} stop
.PHONY: shell
shell: my.env .docker-build ## | Open a shell in the app container.
${DC} run --rm app shell
.PHONY: clean
clean: ## | Remove all build, test, coverage, and Python artifacts.
-rm .docker-build*
-rm -rf .cache
.PHONY: docs
docs: my.env .docker-build-docs ## | Generate Sphinx HTML documetation.
${DC} run --rm --user ${SOCORRO_UID} docs make -C docs/ html
.PHONY: lint
lint: my.env ## | Lint code.
${DC} run --rm --no-deps app shell ./bin/lint.sh
.PHONY: lintfix
lintfix: my.env ## | Reformat code.
${DC} run --rm --no-deps app shell ./bin/lint.sh --fix
.PHONY: test
test: my.env .docker-build ## | Run unit tests.
# Make sure services are started and start localstack before the others to
# give it a little more time to wake up
${DC} up -d localstack
${DC} up -d elasticsearch postgresql statsd
# Run tests
${DC} run --rm test shell ./bin/test.sh
.PHONY: test-ci
test-ci: my.env .docker-build ## | Run unit tests in CI.
# Make sure services are started and start localstack before the others to
# give it a little more time to wake up
${DC} up -d localstack
${DC} up -d elasticsearch postgresql statsd
# Run tests in test-ci which doesn't volume mount local directory
${DC} run --rm test-ci shell ./bin/test.sh
.PHONY: testshell
testshell: my.env .docker-build ## | Open a shell in the test environment.
${DC} run --rm test shell
.PHONY: rebuildreqs
rebuildreqs: .env .docker-build ## | Rebuild requirements.txt file after requirements.in changes.
docker-compose run --rm --no-deps app shell pip-compile --generate-hashes
.PHONY: updatereqs
updatereqs: .env .docker-build ## | Update deps in requirements.txt file.
docker-compose run --rm --no-deps app shell pip-compile --generate-hashes -U