97 lines
3.6 KiB
Python
97 lines
3.6 KiB
Python
import os
|
|
import time
|
|
|
|
import pytest
|
|
|
|
from pyhttpd.conf import HttpdConf
|
|
|
|
|
|
class TestProxyHttp:
|
|
|
|
@pytest.fixture(autouse=True, scope='class')
|
|
def _class_scope(self, env):
|
|
# setup 3 vhosts on https: for reverse, forward and mixed proxying
|
|
# setup 3 vhosts on http: with different document roots
|
|
conf = HttpdConf(env)
|
|
conf.add("ProxyPreserveHost on")
|
|
conf.start_vhost(domains=[env.d_reverse], port=env.https_port)
|
|
conf.add([
|
|
f"ProxyPass / http://127.0.0.1:{env.http_port}/"
|
|
])
|
|
conf.end_vhost()
|
|
conf.add_vhost(domains=[env.d_reverse], port=env.http_port, doc_root='htdocs/test1')
|
|
|
|
conf.start_vhost(domains=[env.d_forward], port=env.https_port)
|
|
conf.add([
|
|
"ProxyRequests on"
|
|
])
|
|
conf.end_vhost()
|
|
conf.add_vhost(domains=[env.d_forward], port=env.http_port, doc_root='htdocs/test2')
|
|
|
|
conf.start_vhost(domains=[env.d_mixed], port=env.https_port)
|
|
conf.add([
|
|
f"ProxyPass / http://127.0.0.1:{env.http_port}/",
|
|
"ProxyRequests on"
|
|
])
|
|
conf.end_vhost()
|
|
conf.add_vhost(domains=[env.d_mixed], port=env.http_port, doc_root='htdocs')
|
|
conf.install()
|
|
assert env.apache_restart() == 0
|
|
|
|
@pytest.mark.parametrize(["via", "seen"], [
|
|
["reverse", "test1"],
|
|
["mixed", "generic"],
|
|
])
|
|
def test_proxy_01_001(self, env, via, seen):
|
|
# make requests to a reverse proxy https: vhost to the http: vhost
|
|
# check that we see the document we expect there (host matching worked)
|
|
r = env.curl_get(f"https://{via}.{env.http_tld}:{env.https_port}/alive.json", 5)
|
|
assert r.response["status"] == 200
|
|
assert r.json['host'] == seen
|
|
|
|
@pytest.mark.parametrize(["via", "seen"], [
|
|
["reverse", "test1"],
|
|
["forward", "test2"],
|
|
["mixed", "generic"],
|
|
])
|
|
def test_proxy_01_002(self, env, via, seen):
|
|
# make requests to a forward proxy https: vhost to the http: vhost
|
|
# check that we see the document we expect there (host matching worked)
|
|
# we need to explicitly provide a Host: header since mod_proxy cannot
|
|
# resolve the name via DNS.
|
|
if not env.curl_is_at_least('8.0.0'):
|
|
pytest.skip(f'need at least curl v8.0.0 for this')
|
|
domain = f"{via}.{env.http_tld}"
|
|
r = env.curl_get(f"http://127.0.0.1:{env.http_port}/alive.json", 5, options=[
|
|
'-H', f"Host: {domain}",
|
|
'--proxy', f"https://{domain}:{env.https_port}/",
|
|
'--resolve', f"{domain}:{env.https_port}:127.0.0.1",
|
|
'--proxy-cacert', f"{env.get_ca_pem_file(domain)}",
|
|
|
|
])
|
|
assert r.exit_code == 0, f"{r.stdout}{r.stderr}"
|
|
assert r.response["status"] == 200
|
|
assert r.json['host'] == seen
|
|
|
|
def test_proxy_01_003(self, env):
|
|
domain = f"test1.{env.http_tld}"
|
|
conf = HttpdConf(env)
|
|
conf.add([
|
|
"ProxyPreserveHost on",
|
|
"<Proxy balancer://backends>",
|
|
f" BalancerMember https://localhost:{env.https_port}",
|
|
" SSLProxyEngine on",
|
|
"</Proxy>",
|
|
])
|
|
conf.start_vhost(domains=[domain], port=env.https_port, doc_root="htdocs/test1")
|
|
conf.add([
|
|
"ProxyPass /proxy balancer://backends",
|
|
"ProxyPassReverse /proxy balancer://backends",
|
|
])
|
|
conf.end_vhost()
|
|
conf.install()
|
|
assert env.apache_restart() == 0
|
|
r = env.curl_get(f"https://{domain}:{env.https_port}/proxy/alive.json", 5)
|
|
assert r.response["status"] == 200
|
|
assert r.json['host'] == "test1"
|