2018-11-06 13:47:09 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
from __future__ import print_function
|
|
|
|
import os
|
|
|
|
|
|
|
|
import ci_lib
|
|
|
|
|
|
|
|
|
|
|
|
# DebOps only supports Debian.
|
|
|
|
ci_lib.DISTROS = ['debian'] * ci_lib.TARGET_COUNT
|
|
|
|
|
|
|
|
project_dir = os.path.join(ci_lib.TMP, 'project')
|
|
|
|
key_file = os.path.join(
|
|
|
|
ci_lib.GIT_ROOT,
|
|
|
|
'tests/data/docker/mitogen__has_sudo_pubkey.key',
|
|
|
|
)
|
|
|
|
vars_path = 'ansible/inventory/group_vars/debops_all_hosts.yml'
|
|
|
|
inventory_path = 'ansible/inventory/hosts'
|
|
|
|
docker_hostname = ci_lib.get_docker_hostname()
|
|
|
|
|
|
|
|
|
|
|
|
with ci_lib.Fold('docker_setup'):
|
|
|
|
containers = ci_lib.make_containers()
|
|
|
|
ci_lib.start_containers(containers)
|
|
|
|
|
|
|
|
|
|
|
|
with ci_lib.Fold('job_setup'):
|
|
|
|
ci_lib.run('debops-init %s', project_dir)
|
|
|
|
os.chdir(project_dir)
|
|
|
|
|
|
|
|
with open('.debops.cfg', 'w') as fp:
|
|
|
|
fp.write(
|
|
|
|
"[ansible defaults]\n"
|
|
|
|
"strategy_plugins = %s/ansible_mitogen/plugins/strategy\n"
|
|
|
|
"strategy = mitogen_linear\n"
|
|
|
|
% (ci_lib.GIT_ROOT,)
|
|
|
|
)
|
|
|
|
|
|
|
|
ci_lib.run('chmod go= %s', key_file)
|
|
|
|
with open(vars_path, 'w') as fp:
|
|
|
|
fp.write(
|
|
|
|
"ansible_python_interpreter: /usr/bin/python2.7\n"
|
|
|
|
"\n"
|
|
|
|
"ansible_user: mitogen__has_sudo_pubkey\n"
|
|
|
|
"ansible_become_pass: has_sudo_pubkey_password\n"
|
|
|
|
"ansible_ssh_private_key_file: %s\n"
|
|
|
|
"\n"
|
|
|
|
# Speed up slow DH generation.
|
|
|
|
"dhparam__bits: ['128', '64']\n"
|
|
|
|
% (key_file,)
|
|
|
|
)
|
|
|
|
|
|
|
|
with open(inventory_path, 'a') as fp:
|
|
|
|
fp.writelines(
|
|
|
|
'%(name)s '
|
|
|
|
'ansible_host=%(hostname)s '
|
|
|
|
'ansible_port=%(port)d '
|
2018-11-07 01:16:18 +00:00
|
|
|
'ansible_python_interpreter=%(python_path)s '
|
2018-11-06 13:47:09 +00:00
|
|
|
'\n'
|
|
|
|
% container
|
|
|
|
for container in containers
|
|
|
|
)
|
|
|
|
|
|
|
|
print()
|
|
|
|
print(' echo --- ansible/inventory/hosts: ---')
|
|
|
|
ci_lib.run('cat ansible/inventory/hosts')
|
|
|
|
print('---')
|
|
|
|
print()
|
|
|
|
|
|
|
|
# Now we have real host key checking, we need to turn it off
|
|
|
|
os.environ['ANSIBLE_HOST_KEY_CHECKING'] = 'False'
|
|
|
|
|
|
|
|
|
|
|
|
with ci_lib.Fold('first_run'):
|
|
|
|
ci_lib.run('debops common')
|
|
|
|
|
|
|
|
|
|
|
|
with ci_lib.Fold('second_run'):
|
|
|
|
ci_lib.run('debops common')
|