summaryrefslogtreecommitdiffstats
path: root/debian/vendor-h2o/t/50servername.t
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-13 21:12:02 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-13 21:12:02 +0000
commit77e50caaf2ef81cd91075cf836fed0e75718ffb4 (patch)
tree53b7b411290b63192fc9e924a3b6b65cdf67e9d0 /debian/vendor-h2o/t/50servername.t
parentAdding upstream version 1.8.3. (diff)
downloaddnsdist-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 '')
-rw-r--r--debian/vendor-h2o/t/50servername.t97
1 files changed, 97 insertions, 0 deletions
diff --git a/debian/vendor-h2o/t/50servername.t b/debian/vendor-h2o/t/50servername.t
new file mode 100644
index 0000000..62b30aa
--- /dev/null
+++ b/debian/vendor-h2o/t/50servername.t
@@ -0,0 +1,97 @@
+use strict;
+use warnings;
+use Test::More;
+use Net::EmptyPort qw(check_port empty_port);
+use t::Util;
+
+plan skip_all => 'curl not found'
+ unless prog_exists('curl');
+
+subtest "default server header" => sub {
+ my $server = spawn_h2o(<< "EOT");
+hosts:
+ default:
+ paths:
+ /:
+ file.dir: @{[ DOC_ROOT ]}
+EOT
+
+ my $resp = `curl --silent --dump-header /dev/stderr http://127.0.0.1:$server->{port}/index.txt 2>&1 > /dev/null`;
+ like $resp, qr{^HTTP/1\.1 200 }s, "200 response";
+ like $resp, qr{^server: h2o/.*\r$}im, "h2o default Server: header found";
+ is +(() = $resp =~ m{^server}img), 1, "header added only once";
+};
+
+subtest "alternate server header" => sub {
+ my $server = spawn_h2o(<< "EOT");
+hosts:
+ default:
+ paths:
+ /:
+ file.dir: @{[ DOC_ROOT ]}
+server-name: h2oalternate
+EOT
+
+ my $resp = `curl --silent --dump-header /dev/stderr http://127.0.0.1:$server->{port}/index.txt 2>&1 > /dev/null`;
+ like $resp, qr{^HTTP/1\.1 200 }s, "200 response";
+ like $resp, qr{^server: h2oalternate\r$}im, "alternate h2o Server: header found";
+ is +(() = $resp =~ m{^server}img), 1, "header added only once";
+};
+
+subtest "no server header" => sub {
+ my $server = spawn_h2o(<< "EOT");
+hosts:
+ default:
+ paths:
+ /:
+ file.dir: @{[ DOC_ROOT ]}
+server-name: h2oalternate
+send-server-name: OFF
+EOT
+ my $resp = `curl --silent --dump-header /dev/stderr http://127.0.0.1:$server->{port}/index.txt 2>&1 > /dev/null`;
+ like $resp, qr{^HTTP/1\.1 200 }s, "200 response";
+ unlike $resp, qr{\nserver}, "server unset";
+};
+
+my $upstream_port = empty_port();
+
+my $upstream = spawn_server(
+ argv => [ qw(plackup -s Starlet --keepalive-timeout 100 --access-log /dev/null --listen), $upstream_port, ASSETS_DIR . "/upstream.psgi" ],
+ is_ready => sub {
+ check_port($upstream_port);
+ },
+);
+
+subtest "preserve server header" => sub {
+ my $server = spawn_h2o(<< "EOT");
+hosts:
+ default:
+ paths:
+ /:
+ proxy.reverse.url: http://127.0.0.1:$upstream_port
+server-name: not-sent
+send-server-name: preserve
+EOT
+ my $resp = `curl --silent -Hserver:this-one-is-sent --dump-header /dev/stderr http://127.0.0.1:$server->{port}/echo-server-header 2>&1 > /dev/null`;
+ like $resp, qr{^HTTP/1\.1 200 }s, "200 response";
+ like $resp, qr{\nserver: this-one-is-sent}i, "server: set to expected value";
+ unlike $resp, qr{\nserver: not-sent}i, "server: not set to the internal value";
+};
+
+subtest "do not preserve server header" => sub {
+ my $server = spawn_h2o(<< "EOT");
+hosts:
+ default:
+ paths:
+ /:
+ proxy.reverse.url: http://127.0.0.1:$upstream_port
+server-name: sent-this-time
+send-server-name: ON
+EOT
+ my $resp = `curl --silent -Hserver:this-one-is-not-sent --dump-header /dev/stderr http://127.0.0.1:$server->{port}/echo-server-header 2>&1 > /dev/null`;
+ like $resp, qr{^HTTP/1\.1 200 }s, "200 response";
+ like $resp, qr{\nserver: sent-this-time}i, "server: set to the internal value";
+ unlike $resp, qr{\nserver: this-one-is-not-sent}i, "server: not set to the backend value";
+};
+
+done_testing();