Mercurial > hg > nginx-tests
view upstream_keepalive.t @ 1619:436d0ffc2ea3
Tests: correctly shutdown ssl for reproducible session reuse tests.
Previously, session reuse tests in stream_ssl_certificate.t were prone
to testing errors, since the client doesn't write any application data
before closing a connection, which is done so to pass tests on win32.
In this case, the server may happened to get an unexpected eof meaning
that it will abandon that session. This is specific to stream testing
pattern, changes to ssl_certificate.t are applied too for consistency.
This is also specific to SSL_R_UNEXPECTED_EOF_WHILE_READING, which is
implemented in OpenSSL 3.0.0.
author | Sergey Kandaurov <pluknet@nginx.com> |
---|---|
date | Mon, 23 Nov 2020 22:46:06 +0000 |
parents | 144c6ce732e4 |
children | e57bb4224131 |
line wrap: on
line source
#!/usr/bin/perl # (C) Sergey Kandaurov # (C) Nginx, Inc. # Tests for upstream keepalive, keepalive_requests and keepalive_timeout. ############################################################################### use warnings; use strict; use Test::More; BEGIN { use FindBin; chdir($FindBin::Bin); } use lib 'lib'; use Test::Nginx; ############################################################################### select STDERR; $| = 1; select STDOUT; $| = 1; my $t = Test::Nginx->new()->has(qw/http proxy upstream_keepalive/)->plan(7) ->write_file_expand('nginx.conf', <<'EOF'); %%TEST_GLOBALS%% daemon off; events { } http { %%TEST_GLOBALS_HTTP%% upstream backend { server 127.0.0.1:8081; keepalive 1; keepalive_requests 3; keepalive_timeout 2s; } server { listen 127.0.0.1:8080; server_name localhost; proxy_http_version 1.1; proxy_set_header Connection $args; location / { proxy_pass http://backend; } } server { listen 127.0.0.1:8081; server_name localhost; location / { add_header X-Connection $connection; } } } EOF $t->write_file('index.html', 'SEE-THIS'); $t->run(); ############################################################################### my ($r, $n); # keepalive_requests like($r = http_get('/'), qr/SEE-THIS/, 'request'); $r =~ m/X-Connection: (\d+)/; $n = $1; like(http_get('/'), qr/X-Connection: $n.*SEE/ms, 'keepalive'); like(http_get('/'), qr/X-Connection: $n.*SEE/ms, 'keepalive again'); like(http_get('/'), qr/X-Connection: (?!$n).*SEE/ms, 'keepalive requests'); http_get('/?close'); # keepalive_timeout like($r = http_get('/'), qr/SEE-THIS/, 'request timer'); $r =~ m/X-Connection: (\d+)/; $n = $1; like(http_get('/'), qr/X-Connection: $n.*SEE/ms, 'keepalive timer'); select undef, undef, undef, 2.5; like(http_get('/'), qr/X-Connection: (?!$n).*SEE/ms, 'keepalive timeout'); ###############################################################################