blob: 23c5f14201f85613050a45ffe2ad0c696a36a7ca (
plain)
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
|
import logging
import os
import sys
import pytest
from .env import ProxyTestEnv
sys.path.append(os.path.join(os.path.dirname(__file__), '../..'))
def pytest_report_header(config, startdir):
env = ProxyTestEnv()
return "mod_proxy: [apache: {aversion}({prefix})]".format(
prefix=env.prefix,
aversion=env.get_httpd_version(),
)
@pytest.fixture(scope="package")
def env(pytestconfig) -> ProxyTestEnv:
level = logging.INFO
console = logging.StreamHandler()
console.setLevel(level)
console.setFormatter(logging.Formatter('%(levelname)s: %(message)s'))
logging.getLogger('').addHandler(console)
logging.getLogger('').setLevel(level=level)
env = ProxyTestEnv(pytestconfig=pytestconfig)
env.setup_httpd()
env.apache_access_log_clear()
env.httpd_error_log.clear_log()
return env
@pytest.fixture(autouse=True, scope="package")
def _session_scope(env):
# we'd like to check the httpd error logs after the test suite has
# run to catch anything unusual. For this, we setup the ignore list
# of errors and warnings that we do expect.
env.httpd_error_log.set_ignored_lognos([
'AH01144', # No protocol handler was valid for the URL
])
env.httpd_error_log.add_ignored_patterns([
#re.compile(r'.*urn:ietf:params:acme:error:.*'),
])
yield
assert env.apache_stop() == 0
errors, warnings = env.httpd_error_log.get_missed()
assert (len(errors), len(warnings)) == (0, 0),\
f"apache logged {len(errors)} errors and {len(warnings)} warnings: \n"\
"{0}\n{1}\n".format("\n".join(errors), "\n".join(warnings))
|