mirror of
https://github.com/certbot/certbot.git
synced 2026-01-14 23:22:21 +03:00
136 lines
5.1 KiB
Python
136 lines
5.1 KiB
Python
"""Common utilities for letsencrypt_apache."""
|
|
import os
|
|
import sys
|
|
import unittest
|
|
|
|
import augeas
|
|
import mock
|
|
import zope.component
|
|
|
|
from acme import jose
|
|
|
|
from letsencrypt.display import util as display_util
|
|
|
|
from letsencrypt.plugins import common
|
|
|
|
from letsencrypt.tests import test_util
|
|
|
|
from letsencrypt_apache import configurator
|
|
from letsencrypt_apache import constants
|
|
from letsencrypt_apache import obj
|
|
|
|
|
|
class ApacheTest(unittest.TestCase): # pylint: disable=too-few-public-methods
|
|
|
|
def setUp(self, test_dir="debian_apache_2_4/two_vhost_80",
|
|
config_root="debian_apache_2_4/two_vhost_80/apache2"):
|
|
# pylint: disable=arguments-differ
|
|
super(ApacheTest, self).setUp()
|
|
|
|
self.temp_dir, self.config_dir, self.work_dir = common.dir_setup(
|
|
test_dir=test_dir,
|
|
pkg="letsencrypt_apache.tests")
|
|
|
|
self.ssl_options = common.setup_ssl_options(
|
|
self.config_dir, constants.MOD_SSL_CONF_SRC,
|
|
constants.MOD_SSL_CONF_DEST)
|
|
|
|
self.config_path = os.path.join(self.temp_dir, config_root)
|
|
|
|
self.rsa512jwk = jose.JWKRSA.load(test_util.load_vector(
|
|
"rsa512_key.pem"))
|
|
|
|
|
|
class ParserTest(ApacheTest): # pytlint: disable=too-few-public-methods
|
|
|
|
def setUp(self, test_dir="debian_apache_2_4/two_vhost_80",
|
|
config_root="debian_apache_2_4/two_vhost_80/apache2"):
|
|
super(ParserTest, self).setUp(test_dir, config_root)
|
|
|
|
zope.component.provideUtility(display_util.FileDisplay(sys.stdout))
|
|
|
|
from letsencrypt_apache.parser import ApacheParser
|
|
self.aug = augeas.Augeas(
|
|
flags=augeas.Augeas.NONE | augeas.Augeas.NO_MODL_AUTOLOAD)
|
|
with mock.patch("letsencrypt_apache.parser.ApacheParser."
|
|
"update_runtime_variables"):
|
|
self.parser = ApacheParser(
|
|
self.aug, self.config_path, "dummy_ctl_path")
|
|
|
|
|
|
def get_apache_configurator(
|
|
config_path, config_dir, work_dir, version=(2, 4, 7), conf=None):
|
|
"""Create an Apache Configurator with the specified options.
|
|
|
|
:param conf: Function that returns binary paths. self.conf in Configurator
|
|
|
|
"""
|
|
backups = os.path.join(work_dir, "backups")
|
|
mock_le_config = mock.MagicMock(
|
|
apache_server_root=config_path,
|
|
apache_le_vhost_ext=constants.CLI_DEFAULTS["le_vhost_ext"],
|
|
backup_dir=backups,
|
|
config_dir=config_dir,
|
|
temp_checkpoint_dir=os.path.join(work_dir, "temp_checkpoints"),
|
|
in_progress_dir=os.path.join(backups, "IN_PROGRESS"),
|
|
work_dir=work_dir)
|
|
|
|
with mock.patch("letsencrypt_apache.configurator."
|
|
"subprocess.Popen") as mock_popen:
|
|
# This indicates config_test passes
|
|
mock_popen().communicate.return_value = ("Fine output", "No problems")
|
|
mock_popen().returncode = 0
|
|
with mock.patch("letsencrypt_apache.configurator.le_util."
|
|
"exe_exists") as mock_exe_exists:
|
|
mock_exe_exists.return_value = True
|
|
with mock.patch("letsencrypt_apache.parser.ApacheParser."
|
|
"update_runtime_variables"):
|
|
config = configurator.ApacheConfigurator(
|
|
config=mock_le_config,
|
|
name="apache",
|
|
version=version)
|
|
# This allows testing scripts to set it a bit more quickly
|
|
if conf is not None:
|
|
config.conf = conf # pragma: no cover
|
|
|
|
config.prepare()
|
|
|
|
return config
|
|
|
|
|
|
def get_vh_truth(temp_dir, config_name):
|
|
"""Return the ground truth for the specified directory."""
|
|
if config_name == "debian_apache_2_4/two_vhost_80":
|
|
prefix = os.path.join(
|
|
temp_dir, config_name, "apache2/sites-available")
|
|
aug_pre = "/files" + prefix
|
|
vh_truth = [
|
|
obj.VirtualHost(
|
|
os.path.join(prefix, "encryption-example.conf"),
|
|
os.path.join(aug_pre, "encryption-example.conf/VirtualHost"),
|
|
set([obj.Addr.fromstring("*:80")]),
|
|
False, True, "encryption-example.demo"),
|
|
obj.VirtualHost(
|
|
os.path.join(prefix, "default-ssl.conf"),
|
|
os.path.join(aug_pre, "default-ssl.conf/IfModule/VirtualHost"),
|
|
set([obj.Addr.fromstring("_default_:443")]), True, False),
|
|
obj.VirtualHost(
|
|
os.path.join(prefix, "000-default.conf"),
|
|
os.path.join(aug_pre, "000-default.conf/VirtualHost"),
|
|
set([obj.Addr.fromstring("*:80")]), False, True,
|
|
"ip-172-30-0-17"),
|
|
obj.VirtualHost(
|
|
os.path.join(prefix, "letsencrypt.conf"),
|
|
os.path.join(aug_pre, "letsencrypt.conf/VirtualHost"),
|
|
set([obj.Addr.fromstring("*:80")]), False, True,
|
|
"letsencrypt.demo"),
|
|
obj.VirtualHost(
|
|
os.path.join(prefix, "mod_macro-example.conf"),
|
|
os.path.join(aug_pre,
|
|
"mod_macro-example.conf/Macro/VirtualHost"),
|
|
set([obj.Addr.fromstring("*:80")]), False, True, modmacro=True)
|
|
]
|
|
return vh_truth
|
|
|
|
return None # pragma: no cover
|