tests: port all existing tests to TAP library
[rainbows.git] / t / lib-reopen-logs.sh
blob822de8b73c84d9b56eba4a8102056f88a1144462
1 #!/bin/sh
2 # don't set nr_client for Rev, only _one_ app running at once :x
3 nr_client=${nr_client-2}
4 . ./test-lib.sh
6 t_plan 18 "reopen rotated logs"
8 t_begin "setup and startup" && {
9 rtmpfiles curl_out curl_err r_rot
10 rainbows_setup $model
11 rainbows -D sleep.ru -c $unicorn_config
12 rainbows_wait_start
15 t_begin "ensure server is responsive" && {
16 curl -sSf http://$listen/ >/dev/null
19 t_begin "start $nr_client concurrent requests" && {
20 start=$(date +%s)
21 for i in $(awk "BEGIN{for(i=0;i<$nr_client;++i) print i}" </dev/null)
23 ( curl -sSf http://$listen/2 >> $curl_out 2>> $curl_err ) &
24 done
27 t_begin "ensure stderr log is clean" && check_stderr
29 t_begin "external log rotation" && {
30 rm -f $r_rot
31 mv $r_err $r_rot
34 t_begin "send reopen log signal (USR1)" && {
35 kill -USR1 $rainbows_pid
38 t_begin "wait for rotated log to reappear" && {
39 nr=60
40 while ! test -f $r_err && test $nr -ge 0
42 sleep 1
43 nr=$(( $nr - 1 ))
44 done
47 dbgcat r_rot
48 dbgcat r_err
50 t_begin "wait curl requests to finish" && {
51 wait
52 t_info elapsed=$(( $(date +%s) - $start ))
55 t_begin "ensure no errors from curl" && {
56 test ! -s $curl_err
59 t_begin "curl got $nr_client responses" && {
60 test "$(wc -l < $curl_out)" -eq $nr_client
63 t_begin "all responses were identical" && {
64 nr=$(sort < $curl_out | uniq | wc -l)
65 test "$nr" -eq 1
68 t_begin 'response was "Hello"' && {
69 test x$(sort < $curl_out | uniq) = xHello
72 t_begin "current server stderr is clean" && check_stderr
74 t_begin "rotated stderr is clean" && {
75 check_stderr $r_rot
78 t_begin "server is now writing logs to new stderr" && {
79 before_rot=$(wc -c < $r_rot)
80 before_err=$(wc -c < $r_err)
81 curl -sSfv http://$listen/
82 after_rot=$(wc -c < $r_rot)
83 after_err=$(wc -c < $r_err)
84 test $after_rot -eq $before_rot
85 test $after_err -gt $before_err
88 t_begin "stop server" && {
89 kill $rainbows_pid
92 dbgcat r_err
94 t_begin "current server stderr is clean" && check_stderr
95 t_begin "rotated stderr is clean" && check_stderr $r_rot
97 t_done