2022-08-27 10:49:32 +03:00
|
|
|
#!/usr/bin/env sh
|
|
|
|
|
2019-01-27 12:54:04 +03:00
|
|
|
export APP_ENV=test
|
2020-09-26 11:43:50 +03:00
|
|
|
export TEST_ENV=api
|
2024-02-17 01:02:46 +03:00
|
|
|
export TEST_RUNTIME="${TEST_RUNTIME:-"rr"}" # rr is the only runtime currently supported
|
2022-08-27 10:49:32 +03:00
|
|
|
export DB_DRIVER="${DB_DRIVER:-"postgres"}"
|
|
|
|
export GENERATE_COVERAGE="${GENERATE_COVERAGE:-"no"}"
|
2019-01-27 12:54:04 +03:00
|
|
|
|
2022-01-06 00:14:09 +03:00
|
|
|
# Reset logs
|
2022-08-27 10:09:14 +03:00
|
|
|
OUTPUT_LOGS=data/log/api-tests/output.log
|
2021-02-13 13:40:19 +03:00
|
|
|
rm -rf data/log/api-tests
|
2022-01-06 00:14:09 +03:00
|
|
|
mkdir data/log/api-tests
|
2022-08-27 10:09:14 +03:00
|
|
|
touch $OUTPUT_LOGS
|
2021-02-13 13:40:19 +03:00
|
|
|
|
2019-01-27 12:54:04 +03:00
|
|
|
# Try to stop server just in case it hanged in last execution
|
2024-02-23 21:30:58 +03:00
|
|
|
[ "$TEST_RUNTIME" = 'rr' ] && bin/rr stop -f -w .
|
2019-01-27 12:54:04 +03:00
|
|
|
|
|
|
|
echo 'Starting server...'
|
2024-02-23 21:30:58 +03:00
|
|
|
[ "$TEST_RUNTIME" = 'rr' ] && bin/rr serve -p -w . -c=config/roadrunner/.rr.test.yml \
|
2022-08-27 10:43:20 +03:00
|
|
|
-o=logs.output="${PWD}/${OUTPUT_LOGS}" \
|
|
|
|
-o=logs.channels.http.output="${PWD}/${OUTPUT_LOGS}" \
|
|
|
|
-o=logs.channels.server.output="${PWD}/${OUTPUT_LOGS}" &
|
2022-08-27 10:09:14 +03:00
|
|
|
sleep 2 # Let's give the server a couple of seconds to start
|
2019-01-27 12:54:04 +03:00
|
|
|
|
2024-02-21 00:16:09 +03:00
|
|
|
vendor/bin/phpunit --order-by=random -c phpunit-api.xml --testdox --colors=always $*
|
2024-02-10 11:54:59 +03:00
|
|
|
TESTS_EXIT_CODE=$?
|
2019-11-09 13:25:33 +03:00
|
|
|
|
2024-02-23 21:30:58 +03:00
|
|
|
[ "$TEST_RUNTIME" = 'rr' ] && bin/rr stop -w .
|
2019-11-09 13:25:33 +03:00
|
|
|
|
|
|
|
# Exit this script with the same code as the tests. If tests failed, this script has to fail
|
2024-02-10 11:54:59 +03:00
|
|
|
exit $TESTS_EXIT_CODE
|