blob d7972e529351894b7da98f4f8712cc3369483cbc 1338 bytes (raw)
name: t/t0300-async_sinatra.sh # note: path name is non-authoritative(*)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
| | #!/bin/sh
. ./test-lib.sh
# n - number of seconds to sleep
n=10
CONFIG_RU=async_sinatra.ru
case $model in
NeverBlock-rack1|EventMachine-rack1) ;;
*)
t_info "skipping $T since it's not compatible with $model"
exit 0
;;
esac
t_plan 7 "async_sinatra test for EM"
t_begin "setup and start" && {
rainbows_setup
rtmpfiles a b c curl_err
# Async Sinatra does not support Rack::Lint
rainbows -E none -D $CONFIG_RU -c $unicorn_config
rainbows_wait_start
}
t_begin "send async requests off in parallel" && {
t0=$(unix_time)
( curl --no-buffer -sSf http://$listen/$n 2>> $curl_err | tee $a) &
( curl --no-buffer -sSf http://$listen/$n 2>> $curl_err | tee $b) &
( curl --no-buffer -sSf http://$listen/$n 2>> $curl_err | tee $c) &
}
t_begin "ensure elapsed requests were processed in parallel" && {
wait
t1=$(unix_time)
elapsed=$(( $t1 - $t0 ))
echo "elapsed=$elapsed < 30"
test $elapsed -lt 30
}
t_begin "termination signal sent" && {
kill $rainbows_pid
}
dbgcat a
dbgcat b
dbgcat c
dbgcat r_err
dbgcat curl_err
t_begin "no errors from curl" && {
test ! -s $curl_err
}
t_begin "no errors in stderr" && check_stderr
dbgcat r_err
t_begin "no responses are chunked" && {
test x"$(cat $a)" = x"delayed for $n seconds"
test x"$(cat $b)" = x"delayed for $n seconds"
test x"$(cat $c)" = x"delayed for $n seconds"
}
t_done
|
debug log:
solving d7972e5 ...
found d7972e5 in https://yhbt.net/rainbows.git/
(*) Git path names are given by the tree(s) the blob belongs to.
Blobs themselves have no identifier aside from the hash of its contents.^
Code repositories for project(s) associated with this public inbox
https://yhbt.net/rainbows.git/
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).