forked from metabrainz/listenbrainz-server
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest.sh
executable file
·327 lines (276 loc) · 8.38 KB
/
test.sh
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
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
#!/bin/bash
# Github Actions automatically sets the CI environment variable. We use this variable to detect if the script is running
# inside a CI environment and modify its execution as needed.
if [ "$CI" == "true" ] ; then
echo "Running in CI mode"
fi
# UNIT TESTS
# ./test.sh build unit test containers, bring up, make database, test, bring down
# for development:
# ./test.sh -u build unit test containers, bring up background and load database if needed
# ./test.sh [params] run unit tests, passing optional params to inner test
# ./test.sh -s stop unit test containers without removing
# ./test.sh -d clean unit test containers
# FRONTEND TESTS
# ./test.sh fe run frontend tests
# ./test.sh fe -u run frontend tests, update snapshots
# ./test.sh fe -b build frontend test containers
# ./test.sh fe -t run type-checker
# ./test.sh fe -f run linters
# SPARK TESTS
# ./test.sh spark run spark tests
# ./test.sh spark -b build spark test containers
# INTEGRATION TESTS
# ./test.sh int run integration tests
COMPOSE_FILE_LOC=docker/docker-compose.test.yml
COMPOSE_PROJECT_NAME=listenbrainz_test
SPARK_COMPOSE_FILE_LOC=docker/docker-compose.spark.yml
SPARK_COMPOSE_PROJECT_NAME=listenbrainz_spark_test
INT_COMPOSE_FILE_LOC=docker/docker-compose.integration.yml
INT_COMPOSE_PROJECT_NAME=listenbrainz_int
if [[ ! -d "docker" ]]; then
echo "This script must be run from the top level directory of the listenbrainz-server source."
exit 255
fi
function invoke_docker_compose {
docker-compose -f $COMPOSE_FILE_LOC \
-p $COMPOSE_PROJECT_NAME \
"$@"
}
function invoke_docker_compose_spark {
docker-compose -f $SPARK_COMPOSE_FILE_LOC \
-p $SPARK_COMPOSE_PROJECT_NAME \
"$@"
}
function invoke_docker_compose_int {
docker-compose -f $INT_COMPOSE_FILE_LOC \
-p $INT_COMPOSE_PROJECT_NAME \
"$@"
}
function docker_compose_run {
invoke_docker_compose run --rm --user `id -u`:`id -g` "$@"
}
function docker_compose_run_fe {
invoke_docker_compose run --rm frontend_tester npm run "$@"
}
function docker_compose_run_spark {
# We run spark tests as root and not the local user due to the requirement for
# the uid to exist as a real user
invoke_docker_compose_spark run --rm "$@"
}
function docker_compose_run_int {
invoke_docker_compose_int run --rm --user `id -u`:`id -g` "$@"
}
function build_unit_containers {
invoke_docker_compose build lb_db redis rabbitmq listenbrainz couchdb
}
function bring_up_unit_db {
invoke_docker_compose up -d lb_db redis rabbitmq couchdb
}
function unit_setup {
echo "Running setup"
# PostgreSQL Database initialization
docker_compose_run listenbrainz dockerize \
-wait tcp://lb_db:5432 -timeout 60s \
-wait tcp://rabbitmq:5672 -timeout 60s \
-wait tcp://couchdb:5984 -timeout 60s \
bash -c "python3 manage.py init_db --create-db && \
python3 manage.py init_msb_db --create-db && \
python3 manage.py init_ts_db --create-db"
}
function is_unit_db_running {
# Check if the database container is running
containername="${COMPOSE_PROJECT_NAME}_lb_db_1"
res=`docker ps --filter "name=$containername" --filter "status=running" -q`
if [ -n "$res" ]; then
return 0
else
return 1
fi
}
function is_unit_db_exists {
containername="${COMPOSE_PROJECT_NAME}_lb_db_1"
res=`docker ps --filter "name=$containername" --filter "status=exited" -q`
if [ -n "$res" ]; then
return 0
else
return 1
fi
}
function unit_stop {
# Stopping all unit test containers associated with this project
invoke_docker_compose stop
}
function unit_dcdown {
# Shutting down all unit test containers associated with this project
invoke_docker_compose down
}
function build_frontend_containers {
invoke_docker_compose build frontend_tester
}
function update_snapshots {
docker_compose_run_fe test:update-snapshots
}
function run_lint_check {
if [ "$CI" == "true" ] ; then
command="format:ci"
else
command="format"
fi
docker_compose_run_fe $command
}
function run_frontend_tests {
if [ "$CI" == "true" ] ; then
command="test:ci"
else
command="test"
fi
docker_compose_run_fe $command
}
function run_type_check {
docker_compose_run_fe type-check
}
function spark_setup {
echo "Running spark test setup"
invoke_docker_compose_spark up -d namenode datanode
}
function build_spark_containers {
invoke_docker_compose_spark build namenode
}
function spark_dcdown {
# Shutting down all spark test containers associated with this project
invoke_docker_compose_spark down
}
function int_build {
invoke_docker_compose_int build
}
function int_dcdown {
# Shutting down all integration test containers associated with this project
invoke_docker_compose_int down
}
function int_setup {
echo "Running setup"
docker_compose_run_int listenbrainz dockerize \
-wait tcp://lb_db:5432 -timeout 60s \
-wait tcp://couchdb:5984 -timeout 60s \
bash -c "python3 manage.py init_db --create-db && \
python3 manage.py init_msb_db --create-db && \
python3 manage.py init_ts_db --create-db"
}
function bring_up_int_containers {
invoke_docker_compose_int up -d lb_db redis timescale_writer rabbitmq couchdb
}
# Exit immediately if a command exits with a non-zero status.
# set -e
# trap cleanup EXIT # Cleanup after tests finish running
if [ "$1" == "spark" ]; then
if [ "$2" == "-b" ]; then
echo "Building containers"
build_spark_containers
exit 0
fi
spark_setup
echo "Running tests"
docker_compose_run_spark request_consumer
RET=$?
spark_dcdown
exit $RET
fi
if [ "$1" == "int" ]; then
echo "Taking down old containers"
int_dcdown
echo "Building current setup"
int_build
echo "Building containers"
int_setup
echo "Bringing containers up"
bring_up_int_containers
shift
if [ -z "$@" ]; then
TESTS_TO_RUN="listenbrainz/tests/integration"
else
TESTS_TO_RUN="$@"
fi
echo "Running tests $TESTS_TO_RUN"
docker_compose_run_int listenbrainz dockerize \
-wait tcp://lb_db:5432 -timeout 60s \
-wait tcp://redis:6379 -timeout 60s \
-wait tcp://rabbitmq:5672 -timeout 60s \
bash -c "pytest $TESTS_TO_RUN"
RET=$?
echo "Taking containers down"
int_dcdown
exit $RET
fi
if [ "$1" == "fe" ]; then
if [ "$2" == "-u" ]; then
echo "Running tests and updating snapshots"
update_snapshots
exit 0
fi
if [ "$2" == "-b" ]; then
echo "Building containers"
build_frontend_containers
exit 0
fi
if [ "$2" == "-t" ]; then
echo "Running type checker"
run_type_check
exit $?
fi
if [ "$2" == "-f" ]; then
echo "Running linters"
run_lint_check
exit $?
fi
echo "Running tests"
run_frontend_tests
exit $?
fi
if [ "$1" == "-s" ]; then
echo "Stopping unit test containers"
unit_stop
exit 0
fi
if [ "$1" == "-d" ]; then
echo "Running docker-compose down"
unit_dcdown
exit 0
fi
# if -u flag, bring up db, run setup, quit
if [ "$1" == "-u" ]; then
is_unit_db_exists
DB_EXISTS=$?
is_unit_db_running
DB_RUNNING=$?
if [ $DB_EXISTS -eq 0 -o $DB_RUNNING -eq 0 ]; then
echo "Database is already up, doing nothing"
else
echo "Building containers"
build_unit_containers
echo "Bringing up DB"
bring_up_unit_db
unit_setup
fi
exit 0
fi
is_unit_db_exists
DB_EXISTS=$?
is_unit_db_running
DB_RUNNING=$?
if [ $DB_EXISTS -eq 1 -a $DB_RUNNING -eq 1 ]; then
# If no containers, build them, run setup then run tests, then bring down
build_unit_containers
bring_up_unit_db
unit_setup
echo "Running tests"
docker_compose_run listenbrainz pytest "$@"
RET=$?
unit_dcdown
exit $RET
else
# Else, we have containers, just run tests
echo "Running tests"
docker_compose_run listenbrainz pytest "$@"
exit $?
fi