-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMakefile
More file actions
81 lines (60 loc) · 2.96 KB
/
Makefile
File metadata and controls
81 lines (60 loc) · 2.96 KB
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
.PHONY: setup build up down logs migrate seed workload collect collect-cpp demo demo-reset benchmark benchmark-100k regression-eval test test-backend test-collector test-frontend lint clean
setup:
cp -n .env.example .env || true
cd backend && python3 -m venv .venv && .venv/bin/pip install -r requirements.txt
cd frontend && npm install
build:
docker compose build
up:
docker compose up -d
down:
docker compose down
logs:
docker compose logs -f backend collector
migrate:
docker compose exec backend alembic upgrade head
seed:
docker compose exec backend python -m app.demo.seed_data
workload:
docker compose exec backend python -m app.demo.workload --iterations $(or $(N),500)
collect:
docker compose exec backend python -m app.core.collector
collect-cpp:
docker compose run --rm collector
demo: up
@echo "waiting for db + kafka..."
@sleep 6
$(MAKE) migrate
$(MAKE) seed
docker compose exec -T db psql -U querylens -d querylens -c "SELECT pg_stat_statements_reset();" >/dev/null
docker compose exec -T db psql -U querylens -d querylens -c "TRUNCATE querylens.query_regressions, querylens.query_reports, querylens.query_plans, querylens.query_metrics, querylens.query_fingerprints, querylens.collector_status CASCADE;" >/dev/null
docker compose exec -T db psql -U querylens -d querylens -c "CREATE INDEX IF NOT EXISTS orders_user_id_idx ON demo.orders(user_id);" >/dev/null
docker compose exec -T db psql -U querylens -d querylens -c "CREATE INDEX IF NOT EXISTS vector_items_embedding_hnsw_idx ON demo.vector_items USING hnsw (embedding vector_l2_ops);" >/dev/null
docker compose exec backend python -m app.demo.workload --iterations 500 --no-drop-index
$(MAKE) collect-cpp
@echo "--- baseline collected from C++ collector ---"
docker compose exec backend python -m app.demo.workload --iterations 1500
$(MAKE) collect-cpp
@echo "--- degraded collected from C++ collector ---"
@echo "open http://localhost:3030 and http://localhost:3000"
demo-reset:
docker compose exec -T db psql -U querylens -d querylens -c "SELECT pg_stat_statements_reset();" >/dev/null
docker compose exec -T db psql -U querylens -d querylens -c "TRUNCATE querylens.query_regressions, querylens.query_reports, querylens.query_plans, querylens.query_metrics, querylens.query_fingerprints, querylens.collector_status CASCADE;" >/dev/null
test: test-backend test-collector test-frontend
benchmark:
docker compose exec backend python -m app.bench.telemetry_benchmark --events $(or $(N),10000)
benchmark-100k:
docker compose exec backend python -m app.bench.telemetry_benchmark --events 100000
regression-eval:
cd backend && .venv/bin/python ../scripts/evaluate_regression_detection.py
test-backend:
cd backend && .venv/bin/pytest tests/ -v
test-collector:
docker compose run --rm collector --help
test-frontend:
cd frontend && npm run build
lint:
cd backend && .venv/bin/ruff check app/ tests/
clean:
docker compose down -v
rm -rf backend/.pytest_cache backend/.ruff_cache frontend/dist collector/build