-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathJustfile
More file actions
115 lines (88 loc) · 3.94 KB
/
Justfile
File metadata and controls
115 lines (88 loc) · 3.94 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
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
set dotenv-load := true
# Показать список доступных команд.
default:
@just --list
# Поднять все сервисы в фоне с пересборкой образов.
up:
docker compose up -d --build
# Поднять сервисы в фоне без пересборки.
up-no-build:
docker compose up -d
# Остановить и удалить контейнеры/сеть (данные в volume сохраняются).
down:
docker compose down
# Остановить и удалить контейнеры/сеть вместе с volume.
down-v:
docker compose down -v
# Перезапустить контейнеры без пересборки.
restart:
docker compose restart
# Показать статус контейнеров.
ps:
docker compose ps
# Показать полезные ссылки локального окружения.
urls:
@echo "API docs: http://localhost:8000/docs"
@echo "Metrics: http://localhost:8000/metrics"
@echo "Prometheus: http://localhost:9090"
@echo "Grafana: http://localhost:3000"
@echo "Jaeger: http://localhost:16686"
@echo "Locust UI: http://localhost:8089"
# Смотреть логи (все сервисы или один сервис: `just logs api`).
logs service="":
if [ -n "{{service}}" ]; then docker compose logs -f --tail=200 "{{service}}"; else docker compose logs -f --tail=200; fi
# Применить миграции Alembic до последней ревизии.
migrate:
docker compose run --rm --entrypoint alembic api upgrade head
# Открыть shell внутри контейнера API.
app-shell:
docker compose exec api sh
# Открыть psql в контейнере Postgres.
db-shell:
docker compose exec postgres psql -U "${POSTGRES_USER:-task_user}" -d "${POSTGRES_DB:-task_manager}"
# Открыть redis-cli в контейнере Redis.
redis-cli:
docker compose exec redis redis-cli
# Запустить Locust в UI режиме для ручного управления нагрузкой.
load:
uv run locust -f load/locustfile.py --host "${LOCUST_HOST:-http://localhost:8000}" --web-port "${LOCUST_WEB_PORT:-8089}"
# Запустить Locust в headless режиме.
load-headless users="20" spawn="2" run_time="5m":
uv run locust -f load/locustfile.py --host "${LOCUST_HOST:-http://localhost:8000}" --headless -u {{users}} -r {{spawn}} --run-time {{run_time}} --only-summary
# Установить git pre-commit hook в локальный репозиторий.
pre-commit-install:
uv run pre-commit install
# Прогнать pre-commit проверки по всем файлам.
pre-commit-run:
uv run pre-commit run --all-files
# Обновить версии хуков в .pre-commit-config.yaml.
pre-commit-update:
uv run pre-commit autoupdate
# Запустить все тесты.
test:
uv run pytest
# Запустить только unit-тесты.
test-unit:
uv run pytest tests/unit -q
# Запустить интеграционные тесты (требуется доступная PostgreSQL БД).
test-integration:
uv run pytest tests/integration -q -m integration
# Запустить тесты с покрытием в консоли.
test-cov:
uv run pytest --cov=app --cov-report=term-missing
# Запустить тесты с HTML-отчётом покрытия (htmlcov/index.html).
test-cov-html:
uv run pytest --cov=app --cov-report=html
# Очистить артефакты тестов и покрытия.
test-clear:
rm -rf htmlcov .pytest_cache
rm -f .coverage coverage.xml
# Проверить код линтером Ruff (без автоисправлений).
lint:
uv run ruff check .
# Проверить код Ruff и автоматически применить безопасные фиксы.
lint-fix:
uv run ruff check . --fix
# Отформатировать код через Ruff formatter.
format:
uv run ruff format .