This repository has been archived by the owner on Jan 23, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 68
/
Copy pathMakefile
146 lines (112 loc) · 4.72 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
.PHONY: help
SHELL := /bin/bash
PYTHON ?= python3
VENV ?= ./venv
COMPOSE_ARGS ?=
JUNIT_RESULTS_DIR=tests/results
JUNIT_OPT=--junitxml $(JUNIT_RESULTS_DIR)
CERT_VALID_DAYS ?= 3650
APM_SERVER_URL ?= http://apm-server:8200
ES_URL ?= http://elasticsearch:9200
KIBANA_URL ?= http://kibana:5601
ES_USER ?= admin
ES_PASS ?= changeme
ELASTIC_APM_SECRET_TOKEN ?= SuPeRsEcReT
PYTHONHTTPSVERIFY ?= 1
PYTEST_ARGS ?=
# Make sure we run local versions of everything, particularly commands
# installed into our virtualenv with pip eg. `docker-compose`.
export PATH := ./bin:$(VENV)/bin:$(PATH)
export APM_SERVER_URL := $(APM_SERVER_URL)
export KIBANA_URL := $(KIBANA_URL)
export ES_URL := $(ES_URL)
export ES_USER := $(ES_USER)
export ES_PASS := $(ES_PASS)
export ELASTIC_APM_SECRET_TOKEN := $(ELASTIC_APM_SECRET_TOKEN)
export PYTHONHTTPSVERIFY := $(PYTHONHTTPSVERIFY)
help: ## Display this help text
@grep -E '^[a-zA-Z_-]+[%]?:.*?## .*$$' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-20s\033[0m %s\n", $$1, $$2}'
all: test
# The tests are written in Python. Make a virtualenv to handle the dependencies.
# make doesn't play nicely with custom VENV, intended only for CI usage
venv: requirements.txt ## Prepare the virtual environment
test -d $(VENV) || virtualenv -q --python=$(PYTHON) $(VENV);\
source $(VENV)/bin/activate || exit 1;\
pip install -q -r requirements.txt;\
touch $(VENV);
lint: venv ## Lint the project
source $(VENV)/bin/activate; \
flake8 --ignore=D100,D101,D102,D103,D104,D105,D106,D107,D200,D205,D400,D401,D403,W504 scripts/compose.py scripts/modules
.PHONY: create-x509-cert
create-x509-cert: ## Create an x509 certificate for use with the test suite
openssl req -x509 -newkey rsa:4096 -keyout scripts/tls/key.pem -out scripts/tls/cert.crt -days "${CERT_VALID_DAYS}" -subj '/CN=apm-server' -nodes
.PHONY: lint
build-env: venv ## Build the test environment
source $(VENV)/bin/activate; \
$(PYTHON) scripts/compose.py build $(COMPOSE_ARGS)
docker-compose build --parallel
start-env: venv ## Start the test environment
source $(VENV)/bin/activate; \
$(PYTHON) scripts/compose.py start $(COMPOSE_ARGS)
docker-compose up -d
stop-env: venv ## Stop the test environment
source $(VENV)/bin/activate; \
docker-compose down -v --remove-orphans || true
destroy-env: venv ## Destroy the test environment
[ -n "$$(docker ps -aqf network=apm-integration-testing)" ] && (docker ps -aqf network=apm-integration-testing | xargs -t docker rm -f && docker network rm apm-integration-testing) || true
# default (all) built for now
build-env-%: venv
$(MAKE) build-env
# default (all) started for now
env-%: venv
$(MAKE) start-env
.PHONY: copy-events
copy-events:
docker cp $(shell docker-compose ps | grep intake-receiver | awk '{print $$1}'):/events .
test: test-all test-helps ## Run all the tests
test-compose: venv ## Test compose.py
source $(VENV)/bin/activate; \
pytest $(PYTEST_ARGS) scripts/tests/test_*.py --reruns 3 --reruns-delay 5 -v -s $(JUNIT_OPT)/compose-junit.xml
test-compose-2:
virtualenv --python=python2.7 venv2
./venv2/bin/pip2 install mock pytest pyyaml
./venv2/bin/pytest $(PYTEST_ARGS) --noconftest scripts/tests/test_*.py
SUBCOMMANDS = list-options load-dashboards start status stop upload-sourcemap versions
test-helps:
$(foreach subcommand,$(SUBCOMMANDS), $(PYTHON) scripts/compose.py $(subcommand) --help > /tmp/file-output && echo "Passed $(subcommand)" || { echo "Failed $(subcommand). See output: " ; cat /tmp/file-output ; exit 1; };)
test-all: venv test-compose lint ## Run all the tests
source $(VENV)/bin/activate; \
pytest -v -s $(PYTEST_ARGS) $(JUNIT_OPT)/all-junit.xml
docker-test-%: ## Run a specific dockerized test. Ex: make docker-test-server
TARGET=test-$* $(MAKE) dockerized-test
dockerized-test: ## Run all the dockerized tests
./scripts/docker-summary.sh
@echo running make $(TARGET) inside a container
docker build --pull -t apm-integration-testing .
mkdir -p -m 777 "$(PWD)/$(JUNIT_RESULTS_DIR)"
chmod 777 "$(PWD)/$(JUNIT_RESULTS_DIR)"
docker run \
--name=apm-integration-testing \
--network=apm-integration-testing \
--security-opt seccomp=unconfined \
-e APM_SERVER_URL \
-e ES_URL \
-e KIBANA_URL \
-e PYTHONDONTWRITEBYTECODE=1 \
-e PYTHONHTTPSVERIFY=$(PYTHONHTTPSVERIFY) \
-e ES_USER \
-e ES_PASS \
-e ELASTIC_APM_SECRET_TOKEN \
-e OTEL_EXPORTER_OTLP_ENDPOINT \
-e OTEL_EXPORTER_OTLP_HEADERS \
-e OTEL_SERVICE_NAME="apm-integration-testing" \
-e TRACEPARENT \
-e OTEL_EXPORTER_OTLP_INSECURE \
-v "$(PWD)/$(JUNIT_RESULTS_DIR)":"/app/$(JUNIT_RESULTS_DIR)" \
--rm \
--entrypoint make \
apm-integration-testing \
$(TARGET)
@echo running make test-helps outside a container
$(MAKE) test-helps
.PHONY: test-% docker-test-% dockerized-test docker-compose-wait