Sha256: 758c6772cf01c6d03eb5dfa087c87d0ee710b3d5f7de2c9ddc5e59651f3035a8

Contents?: true

Size: 919 Bytes

Versions: 10

Compression:

Stored size: 919 Bytes

Contents

#!/bin/sh
. ./test-lib.sh
skip_models StreamResponseEpoll
t_plan 6 "keepalive_timeout 0 tests for $model"

t_begin "setup and start" && {
	rainbows_setup $model 2 0
	grep 'keepalive_timeout 0' $unicorn_config
	rainbows -D env.ru -c $unicorn_config
	rainbows_wait_start
}

t_begin 'check server responds with Connection: close' && {
	curl -sSfi http://$listen/ | grep 'Connection: close'
}

t_begin "send keepalive response that does not expect close" && {
	req='GET / HTTP/1.1\r\nHost: example.com\r\n\r\n'
	t0=$(date +%s)
	(
		cat $fifo > $tmp &
		printf "$req"
		wait
		date +%s > $ok
	) | socat - TCP:$listen > $fifo
	now="$(cat $ok)"
	elapsed=$(( $now - $t0 ))
	t_info "elapsed=$elapsed (expecting <=3)"
	test $elapsed -le 3
}

t_begin "'Connection: close' header set" && {
	grep 'Connection: close' $tmp
}

t_begin "killing succeeds" && {
	kill $rainbows_pid
}

t_begin "check stderr" && {
	check_stderr
}

t_done

Version data entries

10 entries across 10 versions & 1 rubygems

Version Path
rainbows-4.4.3 t/t0017-keepalive-timeout-zero.sh
rainbows-4.4.2 t/t0017-keepalive-timeout-zero.sh
rainbows-4.4.1.1.gd5c8c t/t0017-keepalive-timeout-zero.sh
rainbows-4.4.1 t/t0017-keepalive-timeout-zero.sh
rainbows-4.4.0 t/t0017-keepalive-timeout-zero.sh
rainbows-4.3.1 t/t0017-keepalive-timeout-zero.sh
rainbows-4.3.0 t/t0017-keepalive-timeout-zero.sh
rainbows-4.2.0 t/t0017-keepalive-timeout-zero.sh
rainbows-4.1.0 t/t0017-keepalive-timeout-zero.sh
rainbows-4.0.0 t/t0017-keepalive-timeout-zero.sh