3 test -r random_blob || die
"random_blob required, run with 'make $0'"
5 if ! grep -v ^VmRSS
: /proc
/self
/status
>/dev
/null
2>&1
7 t_info
"skipping, can't read RSS from /proc/self/status"
11 t_plan
10 "large file response slurp avoidance for $model"
13 t_begin
"setup and startup" && {
16 # can't load Rack::Lint here since it'll cause Rev to slurp
17 zbatery
-E none
-D large-file-response.ru
-c $unicorn_config
21 t_begin
"read random blob size" && {
22 random_blob_size
=$
(wc -c < random_blob
)
25 t_begin
"read current RSS" && {
26 curl
-v http
://$listen/rss
28 rss_before
=$
(curl
-sSfv http
://$listen/rss
)
29 t_info
"rss_before=$rss_before"
32 t_begin
"send a series HTTP/1.1 requests sequentially" && {
35 size
=$
( (curl
-sSfv http
://$listen/random_blob
&&
37 test $size -eq $random_blob_size
38 test xok
= x$
(cat $ok)
42 # this was a problem during development
43 t_begin
"HTTP/1.0 test" && {
44 size
=$
( (curl
-0 -sSfv http
://$listen/random_blob
&&
46 test $size -eq $random_blob_size
47 test xok
= x$
(cat $ok)
50 t_begin
"HTTP/0.9 test" && {
52 printf 'GET /random_blob\r\n'
56 ) | socat
- TCP
:$listen > $fifo
58 test xok
= x$
(cat $ok)
63 t_begin
"read RSS again" && {
64 curl
-v http
://$listen/rss
65 rss_after
=$
(curl
-sSfv http
://$listen/rss
)
66 t_info
"rss_after=$rss_after"
69 t_begin
"shutdown server" && {
70 kill -QUIT $zbatery_pid
73 t_begin
"compare RSS before and after" && {
74 diff=$
(( $rss_after - $rss_before ))
75 t_info
"test diff=$diff < orig=$random_blob_size"
76 test $diff -le $random_blob_size
81 t_begin
"check stderr" && check_stderr