summaryrefslogtreecommitdiffstats
path: root/debian/vendor-h2o/t/80issues61.t
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;