Files @ 3c51248b600c
Branch filter:

Location: majic-ansible-roles/roles/xmpp_server/molecule/default/tests/test_backup.py

branko
MAR-192: Switch to using go-sendxmpp where possible for testing XMPP server role:

- The sendxmpp in Debian 12 Bookworm is quite broken at this point,
and go-sendxmpp is somewhat close in terms of interface etc.
- Fix a number of tests related to sending messages.
import os

import testinfra.utils.ansible_runner


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


def test_backup(host):
    """
    Tests if Prosody data directory is correctly backed-up.
    """

    distribution_release = host.ansible("setup")["ansible_facts"]["ansible_distribution_release"]

    # Ugly, but functional for now.
    if distribution_release == "bullseye":
        # Deliver a couple of messages in order to make sure the directory structure
        # is created.
        send = host.run("echo 'Hello' | sendxmpp --tls-ca-path /usr/local/share/ca-certificates/testca.crt "
                        "-t -u jane.doe -p janepassword -j domain2:5222 jane.doe@domain2")
        assert send.rc == 0

        send = host.run("echo 'Hello' | sendxmpp --tls-ca-path /usr/local/share/ca-certificates/testca.crt "
                        "-t -u mick.doe -p mickpassword -j domain3:5222 mick.doe@domain3")
        assert send.rc == 0
    else:
        send = host.run(f"echo 'Hello' | go-sendxmpp --debug "
                        f"--username jane.doe@domain2 --password janepassword --jserver domain2:5222 "
                        f"jane.doe@domain2")
        assert send.rc == 0

        send = host.run(f"echo 'Hello' | go-sendxmpp --debug "
                        f"--username mick.doe@domain3 --password mickpassword --jserver domain3:5222 "
                        f"mick.doe@domain3")
        assert send.rc == 0


    with host.sudo():

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

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

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

        for directory_path in ["/root/restore/var/lib/prosody/domain2",
                               "/root/restore/var/lib/prosody/domain2/offline",
                               "/root/restore/var/lib/prosody/domain3",
                               "/root/restore/var/lib/prosody/domain3/offline"]:

            directory = host.file(directory_path)

            assert directory.is_directory
            assert directory.user == "prosody"
            assert directory.group == "prosody"
            assert directory.mode == 0o750

        for file_path in ["/root/restore/var/lib/prosody/domain2/offline/jane%2edoe.list",
                          "/root/restore/var/lib/prosody/domain3/offline/mick%2edoe.list"]:

            f = host.file(file_path)

            assert f.is_file
            assert f.user == 'prosody'
            assert f.group == 'prosody'
            assert f.mode == 0o640