Files @ 3dd7f39302f8
Branch filter:

Location: majic-ansible-roles/roles/bootstrap/tests/test_parameters_mandatory.py

branko
MAR-29: Implemented tests for php_website role:

- Install some additional tools for testing everything.
- Updated test playbook to change allowed extensions for running PHP scripts on
parameters-optional.
- Updated error page to use correct extension for parameters-optional test
instance.
- Expanded rewrite configuration slightly for parameters-optional.
- Install libmariadb-client-lgpl-dev-compat to test mysql_config symlink
creation.
- Deploy a number of PHP pages used for testing if pages are served correctly.
- Set file permissions on deployed PHP FPM pool configuraiton files.
- Use expanded syntax when deploying TLS keys/certificates in order to avoid
issues with TAB mangling.
- Fixed set-up of Strict-Transport-Security header when HTTPS enforcement is
disabled.
- Added a number of PHP and static test pages.
- Wrote tests covering full functionality of the role.
import os


import testinfra.utils.ansible_runner


testinfra_hosts = testinfra.utils.ansible_runner.AnsibleRunner(
    '.molecule/ansible_inventory').get_hosts('parameters-mandatory')


def test_authorized_keys(File, Sudo):
    """
    Tests if Ansible user authorized_keys has been set-up correctly.
    """

    with Sudo():

        ssh_key = open(os.path.expanduser('~/.ssh/id_rsa.pub'), 'read').read().strip()
        authorized_keys = File('/home/ansible/.ssh/authorized_keys')

        assert authorized_keys.is_file
        assert ssh_key in authorized_keys.content


def test_root_authorized_keys(File, Sudo):
    """
    Tests if Ansible key been removed from root's authorized keys.
    """

    with Sudo():

        ssh_key = open(os.path.expanduser('~/.ssh/id_rsa.pub'), 'read').read().strip()

        assert ssh_key not in File('/root/.ssh/authorized_keys').content