From 4ef081eddf3b243bb7f7fbdbf4750b451c052840 Mon Sep 17 00:00:00 2001 From: Stefan Eissing Date: Tue, 20 Sep 2022 12:40:58 +0000 Subject: *) mod_proxy_http2: use only the ':authority' header to forward 'Host' information to a backend. Deduce ':authority' from what the client sent when 'ProxyPreserveHost' is on. git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk@1904164 13f79535-47bb-0310-9956-ffa450edef68 --- test/modules/http2/htdocs/cgi/hello.py | 1 + test/modules/http2/htdocs/cgi/mnot164.py | 9 ++++-- test/modules/http2/test_100_conn_reuse.py | 2 +- test/modules/http2/test_600_h2proxy.py | 53 ++++++++++++++++++++++++++----- 4 files changed, 53 insertions(+), 12 deletions(-) (limited to 'test') diff --git a/test/modules/http2/htdocs/cgi/hello.py b/test/modules/http2/htdocs/cgi/hello.py index 9fb2eb689d..f9aed3f1a4 100644 --- a/test/modules/http2/htdocs/cgi/hello.py +++ b/test/modules/http2/htdocs/cgi/hello.py @@ -6,6 +6,7 @@ print("Content-Type: application/json") print() print("{") print(" \"https\" : \"%s\"," % (os.getenv('HTTPS', ''))) +print(" \"x_host\" : \"%s\"," % (os.getenv('X_HOST', ''))) print(" \"host\" : \"%s\"," % (os.getenv('SERVER_NAME', ''))) print(" \"port\" : \"%s\"," % (os.getenv('SERVER_PORT', ''))) print(" \"protocol\" : \"%s\"," % (os.getenv('SERVER_PROTOCOL', ''))) diff --git a/test/modules/http2/htdocs/cgi/mnot164.py b/test/modules/http2/htdocs/cgi/mnot164.py index 949b0f195b..0e5d107246 100644 --- a/test/modules/http2/htdocs/cgi/mnot164.py +++ b/test/modules/http2/htdocs/cgi/mnot164.py @@ -12,10 +12,13 @@ try: except KeyError: text="a" count=77784 - - + +count = int(count) + print("Status: 200 OK") print("Content-Type: text/html") print() -sys.stdout.write(text*int(count)) +sys.stdout.flush() +for _ in range(count): + sys.stdout.write(text) diff --git a/test/modules/http2/test_100_conn_reuse.py b/test/modules/http2/test_100_conn_reuse.py index e0b663190a..3ebac24d60 100644 --- a/test/modules/http2/test_100_conn_reuse.py +++ b/test/modules/http2/test_100_conn_reuse.py @@ -27,7 +27,7 @@ class TestConnReuse: def test_h2_100_02(self, env): url = env.mkurl("https", "cgi", "/hello.py") hostname = ("cgi-alias.%s" % env.http_tld) - r = env.curl_get(url, 5, options=[ "-H", "Host:%s" % hostname ]) + r = env.curl_get(url, 5, options=["-H", f"Host: {hostname}"]) assert r.response["status"] == 200 assert "HTTP/2" == r.response["protocol"] assert hostname == r.response["json"]["host"] diff --git a/test/modules/http2/test_600_h2proxy.py b/test/modules/http2/test_600_h2proxy.py index d27143d22c..0f368eda03 100644 --- a/test/modules/http2/test_600_h2proxy.py +++ b/test/modules/http2/test_600_h2proxy.py @@ -6,16 +6,15 @@ from .env import H2Conf, H2TestEnv @pytest.mark.skipif(condition=H2TestEnv.is_unsupported, reason="mod_http2 not supported here") class TestH2Proxy: - @pytest.fixture(autouse=True, scope='class') - def _class_scope(self, env): - conf = H2Conf(env) + def test_h2_600_01(self, env): + conf = H2Conf(env, extras={ + f'cgi.{env.http_tld}': [ + "SetEnvIf Host (.+) X_HOST=$1", + ] + }) conf.add_vhost_cgi(h2proxy_self=True) - if env.verbosity > 1: - conf.add("LogLevel proxy:trace2 proxy_http2:trace2") conf.install() assert env.apache_restart() == 0 - - def test_h2_600_01(self, env): url = env.mkurl("https", "cgi", "/h2proxy/hello.py") r = env.curl_get(url, 5) assert r.response["status"] == 200 @@ -24,4 +23,42 @@ class TestH2Proxy: assert r.response["json"]["ssl_protocol"] != "" assert r.response["json"]["h2"] == "on" assert r.response["json"]["h2push"] == "off" - assert r.response["json"]["host"] == f"cgi.{env.http_tld}" + assert r.response["json"]["x_host"] == f"cgi.{env.http_tld}:{env.https_port}" + + def test_h2_600_02(self, env): + conf = H2Conf(env, extras={ + f'cgi.{env.http_tld}': [ + "SetEnvIf Host (.+) X_HOST=$1", + f"ProxyPreserveHost on", + f"ProxyPass /h2c/ h2c://127.0.0.1:{env.http_port}/", + ] + }) + conf.add_vhost_cgi() + conf.install() + assert env.apache_restart() == 0 + url = env.mkurl("https", "cgi", "/h2c/hello.py") + r = env.curl_get(url, 5) + assert r.response["status"] == 200 + assert r.response["json"]["protocol"] == "HTTP/2.0" + assert r.response["json"]["https"] == "" + # the proxied backend sees Host header as passed on front + assert r.response["json"]["x_host"] == f"cgi.{env.http_tld}:{env.https_port}" + + def test_h2_600_03(self, env): + conf = H2Conf(env, extras={ + f'cgi.{env.http_tld}': [ + "SetEnvIf Host (.+) X_HOST=$1", + f"ProxyPreserveHost off", + f"ProxyPass /h2c/ h2c://127.0.0.1:{env.http_port}/", + ] + }) + conf.add_vhost_cgi() + conf.install() + assert env.apache_restart() == 0 + url = env.mkurl("https", "cgi", "/h2c/hello.py") + r = env.curl_get(url, 5) + assert r.response["status"] == 200 + assert r.response["json"]["protocol"] == "HTTP/2.0" + assert r.response["json"]["https"] == "" + # the proxied backend sees Host as using in connecting to it + assert r.response["json"]["x_host"] == f"127.0.0.1:{env.http_port}" -- cgit v1.2.1