diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-13 21:12:02 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-13 21:12:02 +0000 |
commit | 77e50caaf2ef81cd91075cf836fed0e75718ffb4 (patch) | |
tree | 53b7b411290b63192fc9e924a3b6b65cdf67e9d0 /debian/vendor-h2o/t/50chunked-encoding-proxying.t | |
parent | Adding upstream version 1.8.3. (diff) | |
download | dnsdist-77e50caaf2ef81cd91075cf836fed0e75718ffb4.tar.xz dnsdist-77e50caaf2ef81cd91075cf836fed0e75718ffb4.zip |
Adding debian version 1.8.3-2.debian/1.8.3-2
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'debian/vendor-h2o/t/50chunked-encoding-proxying.t')
-rw-r--r-- | debian/vendor-h2o/t/50chunked-encoding-proxying.t | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/debian/vendor-h2o/t/50chunked-encoding-proxying.t b/debian/vendor-h2o/t/50chunked-encoding-proxying.t new file mode 100644 index 0000000..bb0dff8 --- /dev/null +++ b/debian/vendor-h2o/t/50chunked-encoding-proxying.t @@ -0,0 +1,84 @@ +use strict; +use warnings; +use Net::EmptyPort qw(check_port empty_port); +use Test::More; +use t::Util; +use Time::HiRes qw(usleep); + +plan skip_all => 'nc not found' + unless prog_exists('nc'); + +plan skip_all => 'nghttp not found' + unless prog_exists('nghttp'); + +my $upstream_port = empty_port(); +$| = 1; +my $socket = new IO::Socket::INET ( + LocalHost => '127.0.0.1', + LocalPort => $upstream_port, + Proto => 'tcp', + Listen => 1, + Reuse => 1 +); +die "cannot create socket $!\n" unless $socket; + +check_port($upstream_port) or die "can't connect to server socket"; +# accent and close check_port's connection +my $client_socket = $socket->accept(); +close($client_socket); + +my $server = spawn_h2o(<< "EOT"); +hosts: + default: + paths: + "/": + proxy.reverse.url: http://127.0.0.1:$upstream_port +EOT + +sub doit { + my $chunk = shift; + my $data = shift; + my $stream_window_bits = shift; + my $defer_close = shift; + my $expect_rst_stream = shift; + open my $nghttp, "-|", "nghttp -w $stream_window_bits -v http://127.0.0.1:$server->{'port'}/ -H 'host: host.example.com' 2>&1"; + + my $req; + $client_socket = $socket->accept(); + $client_socket->recv($req, 1024); + $client_socket->send("HTTP/1.1 200 Ok\r\nTransfer-Encoding:chunked\r\nConnection:close\r\n\r\n$chunk"); + if ($defer_close) { + usleep(50000); + } + close($client_socket); + + my $found_rst_stream=0; + my $found_data=""; + while(<$nghttp>) { + if (/^[\[|\s]/) { + if (/RST_STREAM/) { + $found_rst_stream = 1; + } + } else { + # reassamble the DATA output + if (/^([^\[|^\s]+)[\[|\s].*DATA.*/) { + $found_data = $found_data.$1; + } + } + } + if ($expect_rst_stream) { + ok($found_rst_stream == 1, "Found RST_STREAM"); + } else { + ok($found_rst_stream == 0, "RST_STREAM not found, as expected"); + } + ok($found_data eq $data, "Found the expected data"); +} + +for my $w (1 .. 5) { + doit("5\r\nHello\r\n50\r\nThere", "HelloThere", $w, 0, 1); + doit("5\r\nHello\r\n50\r\nThere", "HelloThere", $w, 1, 1); +} +doit("5\r\nHello\r\n5\r\nThere\r\n", "HelloThere", 14); + +$socket->close(); +done_testing(); |