Files @ 17cf34f73ca6
Branch filter:

Location: majic-ansible-roles/roles/database/tests/test_backup.py

branko
MAR-28: Implemented additional tests for mail_server role:

- Deploy a number of tools on clients in order to test SMTP, IMAP, and Sieve
services.
- Added one more user to LDAP directory for testing group restrictions.
- Deploy CA certificate on all testing machines for TLS validation purposes.
- Use different custom-configured cipher for mail server ciphers.
- Fixed invalid postmaster address for parameters-optional host.
- Deploy configuration files for use with Imap-CLI on client test machines.
- Updated testing of SMTP server to include checks for users that do not belong
to mail group.
- Extended some SMTP-related tests to cover both test servers.
- Some small fixes in SMTP-related tests for expected output from commands.
- Implemented tests covering Dovecot (IMAP + Sieve) functionality.
- Implemented tests for running/enabled services.
- Implemented tests for ClamAV.
- Implemented tests for firewall and connectivity.
- Implemented tests for Postfix TLS configuration.
- TODO: Tests for Sieve TLS configuration have not been written yet due to
limitation of available tools.
import testinfra.utils.ansible_runner

testinfra_hosts = testinfra.utils.ansible_runner.AnsibleRunner(
    '.molecule/ansible_inventory').get_hosts('backup')


def test_backup_directories(File, Sudo):
    """
    Tests if backup directories have been set-up correctly.
    """

    with Sudo():
        directories = ["/srv/backup", "/srv/backup/mariadb"]

        for path in directories:

            directory = File(path)

            assert directory.is_directory
            assert directory.user == 'root'
            assert directory.group == 'root'
            assert directory.mode == 0o700


def test_backup_script_file(File, Sudo):
    """
    Tests if backup script file for dumping database has been set-up correctly.
    """

    with Sudo():
        script = File('/etc/duply/main/pre.d/dump_testdb.sh')

        assert script.is_file
        assert script.user == 'root'
        assert script.group == 'root'
        assert script.mode == 0o700
        assert "/usr/bin/mysqldump \"testdb\" > \"/srv/backup/mariadb/testdb.sql\"" in script.content


def test_backup_run(Command, File, Sudo):
    """
    Tests if backup runs correctly, and if restore will included the backed-up
    database.
    """

    with Sudo():

        # Remove restore directory in order to make sure restore has worked
        # correctly.
        Command("rm -rf /root/restore")

        backup_run = Command('duply main backup')
        assert backup_run.rc == 0

        database_dump = File('/srv/backup/mariadb/testdb.sql')
        assert database_dump.is_file
        assert 'Database: testdb' in database_dump.content

        restore_run = Command('duply main restore /root/restore')
        assert restore_run.rc == 0

        restored_database_dump = File('/root/restore/srv/backup/mariadb/testdb.sql')
        assert restored_database_dump.is_file
        assert restored_database_dump.content == database_dump.content