services: test-db: image: postgres:15-alpine environment: POSTGRES_USER: test POSTGRES_PASSWORD: test POSTGRES_DB: authorization_test ports: - "5433:5432" healthcheck: test: ["CMD-SHELL", "pg_isready -U test -d authorization_test"] interval: 5s timeout: 5s retries: 5 test-redis: image: redis:7-alpine ports: - "6380:6379" healthcheck: test: ["CMD", "redis-cli", "ping"] interval: 5s timeout: 5s retries: 5 test-kafka: image: apache/kafka:3.7.0 environment: KAFKA_NODE_ID: 1 KAFKA_PROCESS_ROLES: broker,controller KAFKA_LISTENERS: PLAINTEXT://:9092,CONTROLLER://:9093 KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://test-kafka:9092 KAFKA_CONTROLLER_LISTENER_NAMES: CONTROLLER KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: CONTROLLER:PLAINTEXT,PLAINTEXT:PLAINTEXT KAFKA_CONTROLLER_QUORUM_VOTERS: 1@test-kafka:9093 KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1 KAFKA_TRANSACTION_STATE_LOG_REPLICATION_FACTOR: 1 KAFKA_TRANSACTION_STATE_LOG_MIN_ISR: 1 KAFKA_GROUP_INITIAL_REBALANCE_DELAY_MS: 0 CLUSTER_ID: MkU3OEVBNTcwNTJENDM2Qk ports: - "9093:9092" healthcheck: test: ["CMD-SHELL", "/opt/kafka/bin/kafka-topics.sh --bootstrap-server localhost:9092 --list || exit 1"] interval: 10s timeout: 10s retries: 10 start_period: 30s authorization-service-test: build: context: . dockerfile: Dockerfile.test environment: DATABASE_URL: postgresql://test:test@test-db:5432/authorization_test REDIS_HOST: test-redis REDIS_PORT: 6379 KAFKA_BROKERS: test-kafka:9092 JWT_SECRET: test-jwt-secret-key-for-docker-tests JWT_EXPIRES_IN: 1h NODE_ENV: test depends_on: test-db: condition: service_healthy test-redis: condition: service_healthy test-kafka: condition: service_healthy volumes: - ./coverage:/app/coverage command: sh -c "npx prisma migrate deploy && npm run test:unit && npm run test:integration && npm run test:e2e" networks: default: driver: bridge