Files
food-ai/backend/Makefile
dbastrikin 1aaf20619d refactor: split worker into paid/free via WORKER_PLAN env var
Replace dual-consumer priority WorkerPool with a single consumer per
worker process. WORKER_PLAN=paid|free selects the Kafka topic and
consumer group ID (dish-recognition-paid / dish-recognition-free).

docker-compose now runs worker-paid and worker-free as separate services
for independent scaling. Makefile dev target launches both workers locally.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-03-19 12:11:14 +02:00

69 lines
1.4 KiB
Makefile

.PHONY: run run-worker-paid run-worker-free dev dev-infra-up dev-infra-down test test-integration lint migrate-up migrate-down migrate-create migrate-status docker-up docker-down docker-logs docker-logs-worker
ifneq (,$(wildcard .env))
include .env
export
endif
# Run for development
run:
go run ./cmd/server
run-worker-paid:
WORKER_PLAN=paid go run ./cmd/worker
run-worker-free:
WORKER_PLAN=free go run ./cmd/worker
# Start only infra (postgres, kafka) in Docker, run server + both workers locally
dev: dev-infra-up
@trap 'kill 0' INT; \
go run ./cmd/server & \
WORKER_PLAN=paid go run ./cmd/worker & \
WORKER_PLAN=free go run ./cmd/worker & \
wait
dev-infra-up:
docker compose up -d postgres kafka kafka-init
dev-infra-down:
docker compose stop postgres kafka kafka-init
# Tests
test:
go test ./... -v -race -count=1
# Integration tests (require Docker)
test-integration:
go test -tags=integration ./... -v -race -count=1
# Linter
lint:
golangci-lint run ./...
# Migrations
migrate-up:
goose -dir migrations postgres "$(DATABASE_URL)" up
migrate-down:
goose -dir migrations postgres "$(DATABASE_URL)" down
migrate-create:
goose -dir migrations create $(name) sql
migrate-status:
goose -dir migrations postgres "$(DATABASE_URL)" status
# Docker
docker-up:
docker compose up -d
docker-down:
docker compose down
docker-logs:
docker compose logs -f app
docker-logs-worker:
docker compose logs -f worker-paid worker-free