-
Notifications
You must be signed in to change notification settings - Fork 1
/
docker-compose.test.yml
118 lines (113 loc) · 3.4 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
version: '2.4' # Depending on service condition was removed in v3+
services:
client:
image: ${APP_NAME}-client
container_name: ${APP_NAME}-client
environment:
- REACT_APP_API_URL=http://hcapemployers.localhost:8081
build:
context: ./client
dockerfile: Dockerfile.test
ports:
- 4000:4000
volumes:
- ./client:/client # Use client dir in host for hot reloading
- /client/node_modules # Use node_modules in container
depends_on:
- server
networks:
- backend
server:
image: ${APP_NAME}-server
container_name: ${APP_NAME}-server
build:
context: ./server
dockerfile: Dockerfile.test
args:
VERSION: ${COMMIT_SHA}
environment:
- APP_ENV=local
- NODE_ENV=${NODE_ENV}
- POSTGRES_HOST=${POSTGRES_HOST}
- POSTGRES_DB=${POSTGRES_DB}
- POSTGRES_USER=${POSTGRES_USER}
- POSTGRES_PASSWORD=${POSTGRES_PASSWORD}
- VERSION=${COMMIT_SHA}
- KEYCLOAK_REALM=${KEYCLOAK_LOCAL_REALM}
- KEYCLOAK_AUTH_URL=${KEYCLOAK_LOCAL_AUTH_URL}
- KEYCLOAK_API_CLIENTID=${KEYCLOAK_LOCAL_API_CLIENTID}
- KEYCLOAK_API_SECRET=${KEYCLOAK_API_SECRET}
- KEYCLOAK_FE_CLIENTID=${KEYCLOAK_LOCAL_FE_CLIENTID}
- KEYCLOAK_SA_USERNAME=${KEYCLOAK_SA_USERNAME}
- KEYCLOAK_SA_PASSWORD=${KEYCLOAK_SA_PASSWORD}
- KEYCLOAK_LOCAL_USERNAME=${KEYCLOAK_LOCAL_USERNAME}
- KEYCLOAK_LOCAL_PASSWORD=${KEYCLOAK_LOCAL_PASSWORD}
- KEYCLOAK_LOCAL_SECRET=${KEYCLOAK_LOCAL_SECRET}
- SERVER_PORT=8081
- FEATURE_KEYCLOAK_MIGRATION=${FEATURE_KEYCLOAK_MIGRATION}
- REACT_APP_GOOGLE_SITE_VERIFICATION=${REACT_APP_GOOGLE_SITE_VERIFICATION}
- COLLECTOR_VARIABLE=${COLLECTOR_VARIABLE}
expose:
- '8081'
ports:
- '8081:8081'
volumes:
- ./server:/server # Use server dir in host for hot reloading
- /server/node_modules # Use node_modules in container
depends_on:
postgres:
condition: service_started
keycloak:
condition: service_healthy
networks:
- backend
restart: 'always'
postgres:
image: postgis/postgis:13-3.1-alpine
container_name: ${APP_NAME}-postgres
restart: always
expose:
- '5432'
environment:
- POSTGRES_DB=${POSTGRES_DB}
- POSTGRES_USER=${POSTGRES_USER}
- POSTGRES_PASSWORD=${POSTGRES_PASSWORD}
volumes:
- ./.pgdata-test:/var/lib/postgresql/data
- ./.docker/postgres/sql-init:/docker-entrypoint-initdb.d
ports:
- '5432:5432'
networks:
- backend
keycloak:
image: ${APP_NAME}-keycloak
container_name: ${APP_NAME}-keycloak
build:
context: ./.docker/keycloak
dockerfile: Dockerfile.test
environment:
DB_VENDOR: POSTGRES
DB_ADDR: postgres
DB_DATABASE: db_test_keycloak
DB_USER: ${POSTGRES_USER}
DB_PASSWORD: ${POSTGRES_PASSWORD}
KEYCLOAK_USER: ${KEYCLOAK_SA_USERNAME}
KEYCLOAK_PASSWORD: ${KEYCLOAK_SA_PASSWORD}
KEYCLOAK_IMPORT: /tmp/realm-testing.json -Dkeycloak.profile.feature.upload_scripts=enabled
ports:
- 8080:8080
depends_on:
- postgres
networks:
backend:
aliases:
- keycloak.localhost
healthcheck:
test: ['CMD-SHELL', 'curl -f http://keycloak.localhost:8080/auth']
interval: 10s
timeout: 10s
retries: 20
start_period: 20s
networks:
backend:
driver: 'bridge'