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