-
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
112 lines (91 loc) · 4.56 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
makefile:=$(lastword $(MAKEFILE_LIST))
project_name:=$(shell basename $(shell dirname $(realpath $(makefile))))
tmpdir:=$(shell mktemp -d)
default: help
.PHONY: help
help:
@echo
@echo make
@grep -E '^[a-zA-Z0-9 _ -]+:.*#' $(makefile) | sort | while read -r l; do printf " \033[1;32m$$(echo $$l | cut -f 1 -d':')\033[00m:$$(echo $$l | cut -f 2- -d'#')\n"; done
.PHONY: pip
pip: # Runs pip install with the requirements.txt file
pip install -r requirements.txt
.PHONY: shell
shell: .env # Opens a bash shell in the context of the project
docker compose run app bash
.PHONY: update
update: .env # Updates the project's docker compose image.
docker compose build
docker compose run app flask db history
docker compose run app flask db upgrade
.PHONY: db-downgrade
db-downgrade: .env # Downgrades the db by one upgrade script each time it is run.
docker compose run app flask db downgrade
.PHONY: db-reset
db-reset: .env # Reinitializes the database. You need to run make update to apply all migrations after a reset.
docker compose down --volumes
.PHONY: dev
dev: .env # Starts the webserver based on the current src on port 9091
docker compose up --build
.PHONY: dev-cuda
dev-cuda: .env # Starts the webserver based on the current src on port 9091 with cuda enabled
docker compose -f docker-compose.yml -f docker-compose.cuda.yml up --build
.PHONY: test
test: # Executes all tests in the baked image file. Requires models/
docker compose up -d test-db
docker compose run $(EXTRA_COMPOSE_TEST_OPTIONS) app pytest --cov . --cov-report="xml:.artifacts/coverage.xml"
.PHONY: mypy
mypy: # Runs mypy type checking
docker compose run app mypy
.PHONY: schemas
schemas: # Generates json files
#docker run --rm -v ./src/seer/schemas:/app/src/seer/schemas $(project_name):latest python src/seer/generate_schemas.py
docker compose run app python src/seer/generate_schemas.py
git clone --depth 1 https://github.com/getsentry/sentry-data-schemas.git $(tmpdir)
docker run --rm -t \
-v $(tmpdir):/sentry-data-schemas:ro \
-v $$(pwd)/src/:/src:ro \
tufin/oasdiff breaking /sentry-data-schemas/seer/seer_api.json /src/seer/schemas/seer_api.json
.PHONY: migration
migration: .env
docker compose run app flask db migrate -m 'Migration'
.PHONY: check-no-pending-migrations
check-no-pending-migrations: .env
docker compose run app flask db check
.PHONY: merge-migrations
merge-migrations: .env
docker compose run app flask db merge heads
.env:
cp .env.example .env
gocd: ## Build GoCD pipelines
rm -rf ./gocd/generated-pipelines
mkdir -p ./gocd/generated-pipelines
cd ./gocd/templates && jb install && jb update
# Format
find . -type f \( -name '*.libsonnet' -o -name '*.jsonnet' \) -print0 | xargs -n 1 -0 jsonnetfmt -i
# Lint
find . -type f \( -name '*.libsonnet' -o -name '*.jsonnet' \) -print0 | xargs -n 1 -0 jsonnet-lint -J ./gocd/templates/vendor
# Build
cd ./gocd/templates && find . -type f \( -name '*.jsonnet' \) -print0 | xargs -n 1 -0 jsonnet --ext-code output-files=true -J vendor -m ../generated-pipelines
# Convert JSON to yaml
cd ./gocd/generated-pipelines && find . -type f \( -name '*.yaml' \) -print0 | xargs -n 1 -0 yq -p json -o yaml -i
.PHONY: gocd
upgrade-package-versions: ## Upgrade package versions in requirements.txt from constraints in requirements-constraints.txt
pip-compile --upgrade --strip-extras --quiet requirements-constraints.txt -o requirements.txt
HEAD_SHA:=$(shell git rev-parse --short HEAD)
TIME:=$(shell date +%F.%T)
SEER_STAGING_VERSION_SHA:=$(HEAD_SHA).$(TIME)
export SENTRY_ORG:=sentry
export SENTRY_PROJECT:=seer
push-staging:
# Ensure the google authentication helper is working. If this fails, https://cloud.google.com/artifact-registry/docs/docker/authentication#gcloud-helper
gcloud auth configure-docker us-west1-docker.pkg.dev > /dev/null
# Setup your SBX_PROJECT in .env from the sandbox project name
docker build . --platform linux/amd64 --build-arg SEER_VERSION_SHA=$(SEER_STAGING_VERSION_SHA) --build-arg SENTRY_ENVIRONMENT=staging -t us-west1-docker.pkg.dev/$(SBX_PROJECT)/staging/seer
docker build . --platform linux/amd64 -f Compose.Dockerfile --build-arg SBX_PROJECT=$(SBX_PROJECT) -t us-west1-docker.pkg.dev/$(SBX_PROJECT)/staging/seer.compose
docker push us-west1-docker.pkg.dev/$(SBX_PROJECT)/staging/seer
docker push us-west1-docker.pkg.dev/$(SBX_PROJECT)/staging/seer.compose
sentry-cli releases new "${SEER_STAGING_VERSION_SHA}"
sentry-cli releases deploys "${SEER_STAGING_VERSION_SHA}" new -e staging
sentry-cli releases finalize "${SEER_STAGING_VERSION_SHA}"
sentry-cli releases set-commits "${SEER_STAGING_VERSION_SHA}" --auto || true