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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
|
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.
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"
|