2018-11-06 13:47:09 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
from __future__ import print_function
|
|
|
|
import os
|
2019-02-18 19:58:54 +00:00
|
|
|
import shutil
|
2019-07-23 16:25:53 +00:00
|
|
|
import sys
|
2018-11-06 13:47:09 +00:00
|
|
|
|
|
|
|
import ci_lib
|
|
|
|
|
|
|
|
|
|
|
|
# DebOps only supports Debian.
|
|
|
|
ci_lib.DISTROS = ['debian'] * ci_lib.TARGET_COUNT
|
|
|
|
|
|
|
|
project_dir = os.path.join(ci_lib.TMP, 'project')
|
|
|
|
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'):
|
2019-02-18 18:00:02 +00:00
|
|
|
containers = ci_lib.make_containers(port_offset=500, name_prefix='debops-')
|
2018-11-06 13:47:09 +00:00
|
|
|
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,)
|
|
|
|
)
|
|
|
|
|
|
|
|
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"
|
2019-02-18 19:58:54 +00:00
|
|
|
% (ci_lib.key_file,)
|
2018-11-06 13:47:09 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
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'):
|
2019-07-23 16:25:53 +00:00
|
|
|
ci_lib.run('debops common %s', ' '.join(sys.argv[1:]))
|
2018-11-06 13:47:09 +00:00
|
|
|
|
|
|
|
|
|
|
|
with ci_lib.Fold('second_run'):
|
2019-07-23 16:25:53 +00:00
|
|
|
ci_lib.run('debops common %s', ' '.join(sys.argv[1:]))
|