import os import testinfra.utils.ansible_runner testinfra_hosts = testinfra.utils.ansible_runner.AnsibleRunner( '.molecule/ansible_inventory.yml').get_hosts('parameters-mandatory') def test_authorized_keys(host): """ Tests if Ansible user authorized_keys has been set-up correctly. """ with host.sudo(): ssh_key = open(os.path.expanduser('~/.ssh/id_rsa.pub'), 'read').read().strip() authorized_keys = host.file('/home/ansible/.ssh/authorized_keys') assert authorized_keys.is_file assert ssh_key in authorized_keys.content def test_root_authorized_keys(host): """ Tests if Ansible key been removed from root's authorized keys. """ with host.sudo(): ssh_key = open(os.path.expanduser('~/.ssh/id_rsa.pub'), 'read').read().strip() assert ssh_key not in host.file('/root/.ssh/authorized_keys').content