services: postgres: image: postgres:16-alpine ports: - "5433:5432" environment: POSTGRES_DB: capakraken POSTGRES_USER: capakraken POSTGRES_PASSWORD: capakraken_dev volumes: - capakraken_pgdata:/var/lib/postgresql/data healthcheck: test: ["CMD-SHELL", "pg_isready -U capakraken"] interval: 5s timeout: 3s retries: 5 redis: image: redis:7-alpine ports: - "6380:6379" healthcheck: test: ["CMD", "redis-cli", "ping"] interval: 5s timeout: 3s retries: 5 pgadmin: image: dpage/pgadmin4 ports: - "5050:80" environment: PGADMIN_DEFAULT_EMAIL: admin@capakraken.dev PGADMIN_DEFAULT_PASSWORD: admin depends_on: postgres: condition: service_healthy app: build: context: . dockerfile: Dockerfile.dev ports: - "3100:3100" environment: DATABASE_URL: postgresql://capakraken:capakraken_dev@postgres:5432/capakraken REDIS_URL: redis://redis:6379 NEXTAUTH_URL: http://localhost:3100 NEXTAUTH_SECRET: dev-secret-change-in-production depends_on: postgres: condition: service_healthy redis: condition: service_healthy volumes: - .:/app - /app/node_modules - /app/.next profiles: - full postgres-test: image: postgres:16-alpine ports: - "5434:5432" environment: POSTGRES_DB: capakraken_test POSTGRES_USER: capakraken POSTGRES_PASSWORD: capakraken_test tmpfs: - /var/lib/postgresql/data profiles: - test volumes: capakraken_pgdata: