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
|
import logging
import os
import sys
import pytest
sys.path.append(os.path.join(os.path.dirname(__file__), '../..'))
from .md_env import MDTestEnv
from .md_acme import MDPebbleRunner, MDBoulderRunner
def pytest_report_header(config):
env = MDTestEnv()
return "mod_md: [apache: {aversion}({prefix}), mod_{ssl}, ACME server: {acme}]".format(
prefix=env.prefix,
aversion=env.get_httpd_version(),
ssl=env.ssl_module,
acme=env.acme_server,
)
@pytest.fixture(scope="package")
def env(pytestconfig) -> MDTestEnv:
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 = MDTestEnv(pytestconfig=pytestconfig)
env.setup_httpd()
env.apache_access_log_clear()
env.httpd_error_log.clear_log()
yield env
env.apache_stop()
@pytest.fixture(autouse=True, scope="package")
def _md_package_scope(env):
env.httpd_error_log.add_ignored_lognos([
"AH10085" # There are no SSL certificates configured and no other module contributed any
])
@pytest.fixture(scope="package")
def acme(env):
acme_server = None
if env.acme_server == 'pebble':
acme_server = MDPebbleRunner(env, configs={
'default': os.path.join(env.gen_dir, 'pebble/pebble.json'),
'eab': os.path.join(env.gen_dir, 'pebble/pebble-eab.json'),
})
elif env.acme_server == 'boulder':
acme_server = MDBoulderRunner(env)
yield acme_server
if acme_server is not None:
acme_server.stop()
|