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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
| | #!/bin/sh
# don't set nr_client for Rev, only _one_ app running at once :x
nr_client=${nr_client-2}
. ./test-lib.sh
t_plan 19 "reopen rotated logs"
t_begin "setup and startup" && {
rtmpfiles curl_out curl_err r_rot
rainbows_setup $model
rainbows -D sleep.ru -c $unicorn_config
rainbows_wait_start
}
t_begin "ensure server is responsive" && {
curl -sSf http://$listen/ >/dev/null
}
t_begin "start $nr_client concurrent requests" && {
start=$(unix_time)
for i in $(awk "BEGIN{for(i=0;i<$nr_client;++i) print i}" </dev/null)
do
( curl -sSf http://$listen/2 >> $curl_out 2>> $curl_err ) &
done
}
t_begin "ensure stderr log is clean" && check_stderr
t_begin "external log rotation" && {
rm -f $r_rot
mv $r_err $r_rot
}
t_begin "send reopen log signal (USR1)" && {
kill -USR1 $rainbows_pid
}
t_begin "wait for rotated log to reappear" && {
nr=60
while ! test -f $r_err && test $nr -ge 0
do
sleep 1
nr=$(( $nr - 1 ))
done
}
t_begin "wait for worker to reopen logs" && {
nr=60
re="worker=.* done reopening logs"
while ! grep "$re" < $r_err >/dev/null && test $nr -ge 0
do
sleep 1
nr=$(( $nr - 1 ))
done
}
dbgcat r_rot
dbgcat r_err
t_begin "wait curl requests to finish" && {
wait
t_info elapsed=$(( $(unix_time) - $start ))
}
t_begin "ensure no errors from curl" && {
test ! -s $curl_err
}
t_begin "curl got $nr_client responses" && {
test "$(count_lines < $curl_out)" -eq $nr_client
}
t_begin "all responses were identical" && {
nr=$(sort < $curl_out | uniq | count_lines)
test "$nr" -eq 1
}
t_begin 'response was "Hello"' && {
test x$(sort < $curl_out | uniq) = xHello
}
t_begin "current server stderr is clean" && check_stderr
t_begin "rotated stderr is clean" && {
check_stderr $r_rot
}
t_begin "server is now writing logs to new stderr" && {
before_rot=$(count_bytes < $r_rot)
before_err=$(count_bytes < $r_err)
curl -sSfv http://$listen/
after_rot=$(count_bytes < $r_rot)
after_err=$(count_bytes < $r_err)
test $after_rot -eq $before_rot
test $after_err -gt $before_err
}
t_begin "stop server" && {
kill $rainbows_pid
}
dbgcat r_err
t_begin "current server stderr is clean" && check_stderr
t_begin "rotated stderr is clean" && check_stderr $r_rot
t_done
|