|  | #!/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 |