-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdocker-compose-test.yml
125 lines (116 loc) · 2.59 KB
/
docker-compose-test.yml
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
116
117
118
119
120
121
122
123
124
125
version: '3.8'
services:
db-test:
image: postgres:15.1-alpine
container_name: db-test
ports:
- 5434:5432
environment:
POSTGRES_USER: ylab
POSTGRES_PASSWORD: ylab
POSTGRES_DB: test_menuapp
networks:
- nettest
healthcheck:
test: ["CMD-SHELL", "pg_isready -d $${POSTGRES_DB} -U $${POSTGRES_USER}"]
interval: 5s
timeout: 5s
retries: 3
cache-test:
image: redis:6.2-alpine
container_name: cache-test
volumes:
- ./redis-conf:/conf
environment:
REDIS_HOST: cache-test
REDIS_PORT: 6379
REDIS_DB: 0
command: redis-server /conf/test.conf
networks:
- netcachetest
ports:
- 6383:6379
healthcheck:
test: redis-cli ping
interval: 5s
timeout: 5s
retries: 10
api-test:
build:
context: ./src
dockerfile: Dockerfile.test
container_name: api-test
command: |
bash -c 'pytest -v'
volumes:
- ./src:/src
- xls:/xls
ports:
- 8080:8000
environment:
DB_USER: ylab
DB_PASS: ylab
DB_NAME: test_menuapp
DB_HOST: db-test
REDIS_HOST: cache-test
REDIS_PORT: 6379
REDIS_DB: 0
RABBITMQ_USER: ylab
RABBITMQ_PASSWORD: ylab
RABBITMQ_HOST: broker-test
RABBITMQ_PORT: 5672
networks:
- nettest
- netcachetest
- netqueuetest
depends_on:
db-test:
condition: service_healthy
cache-test:
condition: service_healthy
broker-test:
image: rabbitmq:3.11-alpine
container_name: broker-test
networks:
- netqueuetest
ports:
- 5673:5672
- 15673:15672
environment:
RABBITMQ_DEFAULT_USER: ylab
RABBITMQ_DEFAULT_PASS: ylab
healthcheck:
test: ["CMD-SHELL", "rabbitmq-diagnostics -q ping"]
interval: 30s
timeout: 30s
retries: 3
worker-test:
build:
context: ./src
dockerfile: Dockerfile.test
container_name: worker-test
networks:
- netqueuetest
environment:
CELERY_BROKER_URL: amqp://ylab:ylab@broker-test:5672//
CELERY_BACKEND_URL: rpc://
command: celery --app=app:celeryapp worker --loglevel=INFO
volumes:
- xls:/xls
healthcheck:
test: ["CMD-SHELL", "celery inspect ping -A tasks.add -d celery@worker-test"]
interval: 1m30s
timeout: 30s
retries: 5
start_period: 30s
depends_on:
broker-test:
condition: service_healthy
api-test:
condition: service_started
networks:
nettest: {}
netcachetest: {}
netqueuetest: {}
volumes:
xls: