|
|
|
#!/usr/bin/env python
|
|
|
|
# Run tests/ansible/all.yml under Ansible and Ansible-Mitogen
|
|
|
|
|
|
|
|
import collections
|
|
|
|
import glob
|
|
|
|
import os
|
|
|
|
import signal
|
|
|
|
import sys
|
|
|
|
|
|
|
|
import ci_lib
|
|
|
|
|
|
|
|
|
|
|
|
TESTS_DIR = os.path.join(ci_lib.GIT_ROOT, 'tests/ansible')
|
|
|
|
HOSTS_DIR = os.path.join(ci_lib.TMP, 'hosts')
|
|
|
|
|
|
|
|
|
|
|
|
def pause_if_interactive():
|
|
|
|
if os.path.exists('/tmp/interactive'):
|
|
|
|
while True:
|
|
|
|
signal.pause()
|
|
|
|
|
|
|
|
|
|
|
|
interesting = ci_lib.get_interesting_procs()
|
|
|
|
|
|
|
|
|
|
|
|
with ci_lib.Fold('unit_tests'):
|
|
|
|
os.environ['SKIP_MITOGEN'] = '1'
|
|
|
|
ci_lib.run('./run_tests -v')
|
|
|
|
|
|
|
|
|
|
|
|
ci_lib.check_stray_processes(interesting)
|
|
|
|
|
|
|
|
|
|
|
|
with ci_lib.Fold('docker_setup'):
|
|
|
|
containers = ci_lib.make_containers()
|
|
|
|
ci_lib.start_containers(containers)
|
|
|
|
|
|
|
|
|
|
|
|
with ci_lib.Fold('job_setup'):
|
|
|
|
os.chdir(TESTS_DIR)
|
|
|
|
os.chmod('../data/docker/mitogen__has_sudo_pubkey.key', int('0600', 7))
|
|
|
|
|
|
|
|
ci_lib.run("mkdir %s", HOSTS_DIR)
|
|
|
|
for path in glob.glob(TESTS_DIR + '/hosts/*'):
|
|
|
|
if not path.endswith('default.hosts'):
|
|
|
|
ci_lib.run("ln -s %s %s", path, HOSTS_DIR)
|
|
|
|
|
|
|
|
distros = collections.defaultdict(list)
|
|
|
|
families = collections.defaultdict(list)
|
|
|
|
for container in containers:
|
|
|
|
distros[container['distro']].append(container['name'])
|
|
|
|
families[container['family']].append(container['name'])
|
|
|
|
|
|
|
|
inventory_path = os.path.join(HOSTS_DIR, 'target')
|
|
|
|
with open(inventory_path, 'w') as fp:
|
|
|
|
fp.write('[test-targets]\n')
|
|
|
|
fp.writelines(
|
|
|
|
"%(name)s "
|
|
|
|
"ansible_host=%(hostname)s "
|
|
|
|
"ansible_port=%(port)s "
|
|
|
|
"ansible_python_interpreter=%(python_path)s "
|
|
|
|
"ansible_user=mitogen__has_sudo_nopw "
|
|
|
|
"ansible_password=has_sudo_nopw_password"
|
|
|
|
"\n"
|
|
|
|
% container
|
|
|
|
for container in containers
|
|
|
|
)
|
|
|
|
|
|
|
|
for distro, hostnames in sorted(distros.items(), key=lambda t: t[0]):
|
|
|
|
fp.write('\n[%s]\n' % distro)
|
|
|
|
fp.writelines('%s\n' % name for name in hostnames)
|
|
|
|
|
|
|
|
for family, hostnames in sorted(families.items(), key=lambda t: t[0]):
|
|
|
|
fp.write('\n[%s]\n' % family)
|
|
|
|
fp.writelines('%s\n' % name for name in hostnames)
|
|
|
|
|
|
|
|
fp.write('\n[linux:children]\ntest-targets\n')
|
|
|
|
|
|
|
|
ci_lib.dump_file(inventory_path)
|
|
|
|
|
|
|
|
if not ci_lib.exists_in_path('sshpass'):
|
|
|
|
ci_lib.run("sudo apt-get update")
|
|
|
|
ci_lib.run("sudo apt-get install -y sshpass")
|
|
|
|
|
|
|
|
|
|
|
|
with ci_lib.Fold('ansible'):
|
|
|
|
playbook = os.environ.get('PLAYBOOK', 'all.yml')
|
|
|
|
try:
|
|
|
|
ci_lib.run('./run_ansible_playbook.py %s -i "%s" %s',
|
|
|
|
playbook, HOSTS_DIR, ' '.join(sys.argv[1:]))
|
|
|
|
except:
|
|
|
|
pause_if_interactive()
|
|
|
|
raise
|
|
|
|
|
|
|
|
|
|
|
|
ci_lib.check_stray_processes(interesting, containers)
|
|
|
|
|
|
|
|
pause_if_interactive()
|