diff options
author | Eric Wong <normalperson@yhbt.net> | 2010-05-03 15:19:53 -0700 |
---|---|---|
committer | Eric Wong <normalperson@yhbt.net> | 2010-05-03 15:19:53 -0700 |
commit | 798f5e3a507c20b4abf03aa8313659d3f632a0fa (patch) | |
tree | 4b781e5f16cc8428f76bc399e6e5cafdeeb41879 /t/t0100-rack-input-hammer-content-length.sh | |
parent | 9f1131f5972ba90c1c54c76cc97633447142b307 (diff) | |
download | rainbows-798f5e3a507c20b4abf03aa8313659d3f632a0fa.tar.gz |
It turns out we were painfully lacking in tests for HTTP requests where the Content-Length header _is_ set.
Diffstat (limited to 't/t0100-rack-input-hammer-content-length.sh')
-rwxr-xr-x | t/t0100-rack-input-hammer-content-length.sh | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/t/t0100-rack-input-hammer-content-length.sh b/t/t0100-rack-input-hammer-content-length.sh new file mode 100755 index 0000000..181954e --- /dev/null +++ b/t/t0100-rack-input-hammer-content-length.sh @@ -0,0 +1,50 @@ +nr_client=${nr_client-4} +. ./test-lib.sh +test -r random_blob || die "random_blob required, run with 'make $0'" + +# basically we don't trust our own implementation of content-md5-put +# nor our Ruby 1.9 knowledge nor proper use of encodings in Ruby. +# So we try to use things like curl and sha1sum that are implemented +# without the Ruby interpreter to validate our own Ruby internals. + +t_plan 7 "concurrent rack.input hammer stress test (content-length)" + +t_begin "setup and startup" && { + rtmpfiles curl_out curl_err + rainbows_setup $model + rainbows -D sha1.ru -c $unicorn_config + rainbows_wait_start +} + +t_begin "send $nr_client concurrent requests" && { + start=$(date +%s) + for i in $(awk "BEGIN{for(i=0;i<$nr_client;++i) print i}" </dev/null) + do + ( + curl -sSf -T random_blob http://$listen/$i \ + >> $curl_out 2>> $curl_err + ) & + done + wait + t_info elapsed=$(( $(date +%s) - $start )) +} + +t_begin "kill server" && kill $rainbows_pid + +t_begin "got $nr_client responses" && { + test $nr_client -eq $(wc -l < $curl_out) +} + +t_begin "all responses identical" && { + test 1 -eq $(sort < $curl_out | uniq | wc -l) +} + +t_begin "sha1 matches on-disk sha1" && { + blob_sha1=$(rsha1 < random_blob) + t_info blob_sha1=$blob_sha1 + test x"$blob_sha1" = x"$(sort < $curl_out | uniq)" +} + +t_begin "no errors in stderr log" && check_stderr + +t_done |