| #!/bin/bash |
| |
| cd $(dirname $0) |
| |
| set -e |
| |
| PORT=12345 |
| TIMEOUT=10 |
| |
| ./compile_extension.sh |
| |
| run_test() { |
| echo |
| echo "Running multirequest test, args: $@" |
| |
| RUN_UNDER="" |
| EXTRA_ARGS="" |
| ARGS="-d xdebug.profiler_enable=0 -d display_errors=on -dextension=../ext/google/protobuf/modules/protobuf.so" |
| |
| for i in "$@"; do |
| case $i in |
| --valgrind) |
| RUN_UNDER="valgrind --error-exitcode=1" |
| shift |
| ;; |
| --keep_descriptors) |
| EXTRA_ARGS=-dprotobuf.keep_descriptor_pool_after_request=1 |
| shift |
| ;; |
| esac |
| done |
| |
| export ZEND_DONT_UNLOAD_MODULES=1 |
| export USE_ZEND_ALLOC=0 |
| rm -f nohup.out |
| nohup $RUN_UNDER php $ARGS $EXTRA_ARGS -S localhost:$PORT multirequest.php >nohup.out 2>&1 & |
| PID=$! |
| |
| if ! timeout $TIMEOUT bash -c "until echo > /dev/tcp/localhost/$PORT; do sleep 0.1; done" > /dev/null 2>&1; then |
| echo "Server failed to come up after $TIMEOUT seconds" |
| cat nohup.out |
| exit 1 |
| fi |
| |
| seq 2 | xargs -I{} wget -nv http://localhost:$PORT/multirequest.result -O multirequest{}.result |
| REQUESTS_SUCCEEDED=$? |
| |
| |
| if kill $PID > /dev/null 2>&1 && [[ $REQUESTS_SUCCEEDED == "0" ]]; then |
| wait |
| echo "Multirequest test SUCCEEDED" |
| else |
| echo "Multirequest test FAILED" |
| cat nohup.out |
| exit 1 |
| fi |
| } |
| |
| run_test |
| run_test --keep_descriptors |
| run_test --valgrind |
| run_test --valgrind --keep_descriptors |