tests: port all existing tests to TAP library
[rainbows.git] / t / lib-async-response.sh
blob368792b2aee4bb7b8b76a622da6e1432f26c4c88
1 CONFIG_RU=${CONFIG_RU-'async-response.ru'}
2 . ./test-lib.sh
4 case $CONFIG_RU in
5 *no-autochunk.ru)
6 t_plan 7 "async response w/o autochunk for $model"
7 skip_autochunk=true
8 ;;
9 *)
10 t_plan 6 "async response for $model"
11 skip_autochunk=false
13 esac
15 t_begin "setup and start" && {
16 rainbows_setup
17 rtmpfiles a b c curl_err
18 # can't load Rack::Lint here since it'll cause Rev to slurp
19 rainbows -E none -D $CONFIG_RU -c $unicorn_config
20 rainbows_wait_start
23 t_begin "send async requests off in parallel" && {
24 t0=$(date +%s)
25 ( curl --no-buffer -sSf http://$listen/ 2>> $curl_err | utee $a) &
26 ( curl --no-buffer -sSf http://$listen/ 2>> $curl_err | utee $b) &
27 ( curl --no-buffer -sSf http://$listen/ 2>> $curl_err | utee $c) &
28 wait
29 t1=$(date +%s)
32 t_begin "ensure elapsed requests were processed in parallel" && {
33 elapsed=$(( $t1 - $t0 ))
34 echo "elapsed=$elapsed < 30"
35 test $elapsed -lt 30
38 t_begin "termination signal sent" && {
39 kill $rainbows_pid
42 dbgcat a
43 dbgcat b
44 dbgcat c
45 dbgcat r_err
46 dbgcat curl_err
48 t_begin "no errors from curl" && {
49 test ! -s $curl_err
52 t_begin "no errors in stderr" && check_stderr
54 dbgcat r_err
56 if $skip_autochunk
57 then
58 t_begin "no responses are chunked" && {
59 test x"$(cat $a)" = x0123456789
60 test x"$(cat $b)" = x0123456789
61 test x"$(cat $c)" = x0123456789
65 t_done