blob: bdcfd6ea558a51179deaf0d185b732a8741e9dc5 (
plain)
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
|
use strict;
use warnings;
use Net::EmptyPort qw(check_port empty_port);
use Test::More;
use t::Util;
plan skip_all => 'plackup not found'
unless prog_exists('plackup');
plan skip_all => 'Starlet not found'
unless system('perl -MStarlet /dev/null > /dev/null 2>&1') == 0;
my $upstream_port = empty_port();
my $upstream = spawn_server(
argv => [
qw(plackup -s Starlet --access-log /dev/null -p), $upstream_port, ASSETS_DIR . "/upstream.psgi",
],
is_ready => sub {
check_port($upstream_port);
},
);
my $h2o = spawn_h2o(<< "EOT");
hosts:
default:
paths:
/:
proxy.reverse.url: http://127.0.0.1:$upstream_port
EOT
subtest 'http1' => sub {
plan skip_all => 'curl not found'
unless prog_exists('curl');
my $doit = sub {
my ($proto, $port) = @_;
my $extra = '';
if ($proto eq 'https') {
$extra .= ' --insecure';
$extra .= ' --http1.1'
if curl_supports_http2();
}
subtest $proto => sub {
my $resp = `curl --max-time 1 $extra $proto://127.0.0.1:$port/streaming-body 2>&1`;
like $resp, qr/operation timed out/i, "operation should time out";
sleep 1;
$resp = `curl --silent --dump-header /dev/stderr $extra $proto://127.0.0.1:$port/ 2>&1 > /dev/null`;
like $resp, qr{^HTTP/[^ ]+ 404\s}s, "server is still alive";
};
};
$doit->('http', $h2o->{port});
$doit->('https', $h2o->{tls_port});
};
# note: implement test using HTTP/2, nghttp --timeout 2 does not seem to work like above
done_testing;
|