-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMakefile
More file actions
71 lines (57 loc) · 3.05 KB
/
Makefile
File metadata and controls
71 lines (57 loc) · 3.05 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
.PHONY: up down demo demo-reset seed workload collect test test-unit build lint logs install screenshots
# --- docker compose ---
up:
docker compose up -d
down:
docker compose down
logs:
docker compose logs -f backend
# --- full demo pipeline (idempotent) ---
demo: up
@echo "waiting for db..."
@sleep 3
docker compose exec backend alembic upgrade head
docker compose exec backend python -m app.demo.seed_data
@echo "--- resetting demo state for reproducible run ---"
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 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 backend python -m app.demo.workload --iterations 400 --no-drop-index
docker compose exec backend python -m app.core.collector
@echo "--- baseline collected ---"
docker compose exec backend python -m app.demo.workload --iterations 1500
docker compose exec backend python -m app.core.collector
@echo "--- regression snapshot collected ---"
@echo "open http://localhost:3030"
# explicit reset (without re-running workload)
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 CASCADE;"
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);"
@echo "reset done"
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
# --- tests ---
test:
cd backend && .venv/bin/pytest tests/ -v
test-unit:
cd backend && .venv/bin/pytest tests/test_fingerprint.py tests/test_explain_parser.py tests/test_regression_detector.py -v
# --- frontend ---
build:
cd frontend && npm run build
# regenerate README screenshots — assumes stack is running on :3030 with demo data
screenshots:
cd docs/screenshots && (test -d node_modules || npm install --no-fund --no-audit playwright) && \
(test -d node_modules/playwright/.local-browsers || npx playwright install chromium) && \
FID=$$(curl -s http://localhost:8765/api/regressions?limit=100 | python3 -c "import json,sys; d=json.load(sys.stdin); [print(r['fingerprint_id']) or sys.exit(0) for r in d['items'] if r['regression_type']=='index_scan_to_seq_scan']") && \
node capture.mjs $$FID
# --- lint ---
lint:
cd backend && .venv/bin/ruff check app/ tests/
install:
cd backend && python3 -m venv .venv && .venv/bin/pip install -r requirements.txt
cd frontend && npm install