Files @ 85d033089f0e
Branch filter:

Location: majic-ansible-roles/roles/mail_forwarder/molecule/default/tests/test_optional.py - annotation

branko
MAR-181: Remove release-specific code for database role tests:

- Code was present due to difference between Debian Stretch and Debian
Buster.
13982172ed2e
f774e938a4ed
01f4b619cfa6
f774e938a4ed
f774e938a4ed
f774e938a4ed
f774e938a4ed
f774e938a4ed
d62b3adec462
f774e938a4ed
f774e938a4ed
fb5e4e372902
f774e938a4ed
f774e938a4ed
f774e938a4ed
f774e938a4ed
8927efb4fb61
f774e938a4ed
fb5e4e372902
f774e938a4ed
d752715bb533
f774e938a4ed
fb5e4e372902
fb5e4e372902
f774e938a4ed
f774e938a4ed
f774e938a4ed
f774e938a4ed
8927efb4fb61
fb5e4e372902
d752715bb533
f774e938a4ed
fb5e4e372902
fb5e4e372902
23a9ea4219dc
f774e938a4ed
f774e938a4ed
f774e938a4ed
f774e938a4ed
f774e938a4ed
f774e938a4ed
fb5e4e372902
f774e938a4ed
f774e938a4ed
f774e938a4ed
f774e938a4ed
8927efb4fb61
fb5e4e372902
f774e938a4ed
f774e938a4ed
f774e938a4ed
01f4b619cfa6
01f4b619cfa6
01f4b619cfa6
fb5e4e372902
fb5e4e372902
fb5e4e372902
fb5e4e372902
f774e938a4ed
d752715bb533
d752715bb533
f774e938a4ed
f774e938a4ed
fb5e4e372902
f774e938a4ed
f774e938a4ed
f774e938a4ed
f774e938a4ed
fb5e4e372902
f774e938a4ed
f774e938a4ed
f774e938a4ed
01f4b619cfa6
01f4b619cfa6
01f4b619cfa6
fb5e4e372902
fb5e4e372902
23a9ea4219dc
23a9ea4219dc
23a9ea4219dc
f774e938a4ed
d752715bb533
f774e938a4ed
f774e938a4ed
fb5e4e372902
f774e938a4ed
f774e938a4ed
f774e938a4ed
f774e938a4ed
fb5e4e372902
f774e938a4ed
f774e938a4ed
fb5e4e372902
f774e938a4ed
fb5e4e372902
f774e938a4ed
f774e938a4ed
f774e938a4ed
fb5e4e372902
f774e938a4ed
f774e938a4ed
fb5e4e372902
f774e938a4ed
fb5e4e372902
f774e938a4ed
f774e938a4ed
f774e938a4ed
f774e938a4ed
f774e938a4ed
f774e938a4ed
5ea45eee5187
5ea45eee5187
5ea45eee5187
fb5e4e372902
fb5e4e372902
6c1d08d39449
f774e938a4ed
d752715bb533
90bda8fea4aa
90bda8fea4aa
90bda8fea4aa
90bda8fea4aa
90bda8fea4aa
90bda8fea4aa
90bda8fea4aa
90bda8fea4aa
90bda8fea4aa
90bda8fea4aa
90bda8fea4aa
90bda8fea4aa
90bda8fea4aa
90bda8fea4aa
import os
import re
import time

import testinfra.utils.ansible_runner


testinfra_hosts = testinfra.utils.ansible_runner.AnsibleRunner(
    os.environ['MOLECULE_INVENTORY_FILE']).get_hosts('parameters-optional')


def test_smtp_mailname(host):
    """
    Tests if SMTP mailname has been configured correctly.
    """

    hostname = host.run('hostname').stdout.strip()

    mailname = host.file('/etc/mailname')

    assert mailname.content_string == "%s" % hostname


def test_postfix_main_cf_file_content(host):
    """
    Tests if the Postfix main configuration file content is correct.
    """

    hostname = host.run('hostname').stdout.strip()
    config = host.file('/etc/postfix/main.cf')
    config_lines = config.content_string.split("\n")

    assert "myhostname = %s" % hostname in config_lines
    assert "mydestination = %s, %s, localhost.localdomain, localhost" % (hostname, hostname) in config_lines
    assert "relayhost = mail-server:27" in config_lines
    assert "mynetworks = 127.0.0.0/8 [::ffff:127.0.0.0]/104 [::1]/128" in config_lines
    assert "smtp_tls_security_level=verify" in config_lines
    assert "smtp_tls_CAfile=/etc/ssl/certs/smtp_relay_truststore.pem" in config_lines
    assert "smtp_host_lookup = dns, native" in config_lines


def test_local_aliases(host):
    """
    Tests if local aliases are configured correctly.
    """

    hostname = host.run('hostname').stdout.strip()
    send = host.run('swaks --suppress-data --to root@localhost')
    assert send.rc == 0
    message_id = re.search('Ok: queued as (.*)', send.stdout).group(1)

    # Wait for a little while for message to be processed.
    time.sleep(5)

    with host.sudo():
        mail_log = host.file('/var/log/mail.log')
        pattern1 = "%s: to=<root@%s>, orig_to=<root@localhost>.*status=sent" % (message_id, hostname)
        pattern2 = "%s: to=<testuser@%s>, orig_to=<root@localhost>.*status=sent" % (message_id, hostname)

        assert re.search(pattern1, mail_log.content_string) is not None
        assert re.search(pattern2, mail_log.content_string) is not None


def test_relay_mail_sending(host):
    """
    Tests if mails are sent correctly via relay if relay has been configured.
    """

    send = host.run('swaks --suppress-data --to root@domain1 --server localhost')
    assert send.rc == 0
    message_id = re.search('Ok: queued as (.*)', send.stdout).group(1)

    # Wait for a little while for message to be processed.
    time.sleep(5)

    with host.sudo():
        mail_log = host.file('/var/log/mail.log')
        # Pattern used to verify the mail was sent over relay on designated
        # port.
        pattern = r"%s: to=<root@domain1>, relay=mail-server\[[^]]*\]:27.*status=sent" % message_id

        assert re.search(pattern, mail_log.content_string) is not None


def test_tls_enforced_towards_relay_mail_server(host):
    """
    Tests if TLS verification is enfoced towards the relay mail server.
    """

    with host.sudo():
        # Replace the relayhost with name that is not present in relay's
        # certificate.
        command = host.run("sed -i -e s#relayhost\\ =\\ mail-server#relayhost\\ =\\ domain1# /etc/postfix/main.cf")
        assert command.rc == 0
        command = host.run("service postfix restart")
        assert command.rc == 0

        # Try to send out an e-mail
        send = host.run('swaks --suppress-data --to root@domain1 --server localhost')

        # Restore correct relay name in the configuration file.
        command = host.run("sed -i -e s#relayhost\\ =\\ domain1#relayhost\\ =\\ mail-server# /etc/postfix/main.cf")
        assert command.rc == 0
        command = host.run("service postfix restart")
        assert command.rc == 0

        # Finally check the results.
        assert send.rc == 0
        message_id = re.search('Ok: queued as (.*)', send.stdout).group(1)

        # Wait for a little while for message to be processed.
        time.sleep(5)

        with host.sudo():
            mail_log = host.file('/var/log/mail.log')
            pattern = r"%s: to=<root@domain1>, relay=domain1.*status=deferred \(Server certificate not verified\)" % message_id

            assert re.search(pattern, mail_log.content_string) is not None


def test_mail_message_size_limit(host):
    """
    Tests if the mail message size limit advertised by the SMTP server
    is correct.
    """

    capabilities = host.run("(echo 'ehlo localhost' && sleep 2) | telnet localhost 25")
    begin = capabilities.stdout.find("250-SIZE")
    end = capabilities.stdout.find("\n", begin)
    mail_message_size_limit = capabilities.stdout[begin:end]

    assert mail_message_size_limit == "250-SIZE 20480001"