Merge "check mode: docker_puppet"

This commit is contained in:
Zuul 2018-10-16 23:12:05 +00:00 committed by Gerrit Code Review
commit c262998fcf
2 changed files with 108 additions and 11 deletions

View File

@ -27,8 +27,8 @@
state: absent state: absent
tags: tags:
- host_config - host_config
- container_puppet - container_config
- container_puppet_tasks - container_config_tasks
- container_config_scripts - container_config_scripts
- container_startup_configs - container_startup_configs
when: when:
@ -45,8 +45,8 @@
recurse: true recurse: true
tags: tags:
- host_config - host_config
- container_puppet - container_config
- container_puppet_tasks - container_config_tasks
- container_config_scripts - container_config_scripts
- container_startup_configs - container_startup_configs
when: when:
@ -98,14 +98,62 @@
tags: tags:
- container_config - container_config
- name: Delete existing /var/lib/docker-puppet/check-mode for check mode
file:
path: /var/lib/docker-puppet/check-mode
state: absent
tags:
- container_config
ignore_errors: true
check_mode: no
when:
- ansible_check_mode
- name: Create /var/lib/docker-puppet/check-mode for check mode
file:
path: /var/lib/docker-puppet/check-mode
state: directory
setype: svirt_sandbox_file_t
selevel: s0
tags:
- container_config
check_mode: no
when:
- ansible_check_mode
- name: Write docker-puppet.json file - name: Write docker-puppet.json file
copy: copy:
content: "{{ lookup('file', tripleo_role_name + '/puppet_config.yaml', errors='ignore') | default([], True) | from_yaml | to_json }}" content: "{{ lookup('file', tripleo_role_name + '/puppet_config.yaml', errors='ignore') | default([], True) | from_yaml | to_nice_json }}"
dest: /var/lib/docker-puppet/docker-puppet.json dest: /var/lib/docker-puppet/{{ ansible_check_mode | ternary('check-mode/', '') }}docker-puppet.json
force: yes force: yes
mode: '0600' mode: '0600'
tags: tags:
- container_config - container_config
check_mode: no
diff: no
- name: Diff docker-puppet.json changes for check mode
command:
diff -uN /var/lib/docker-puppet/docker-puppet.json /var/lib/docker-puppet/check-mode/docker-puppet.json
register: diff_results
tags:
- container_config
check_mode: no
when:
- ansible_check_mode
- ansible_diff_mode
failed_when: false
changed_when: diff_results.rc == 1
- name: Diff docker-puppet.json changes for check mode
debug:
var: diff_results.stdout_lines
changed_when: diff_results.rc == 1
when:
- ansible_check_mode
- ansible_diff_mode
tags:
- container_config
- name: Create /var/lib/docker-config-scripts - name: Create /var/lib/docker-config-scripts
file: file:
@ -115,7 +163,6 @@
tags: tags:
- container_config_scripts - container_config_scripts
# The container config files # The container config files
# /var/lib/docker-container-startup-configs.json is removed as we now write # /var/lib/docker-container-startup-configs.json is removed as we now write
# per-step files instead # per-step files instead
@ -141,7 +188,6 @@
tags: tags:
- container_config_scripts - container_config_scripts
# Here we are dumping all the docker container startup configuration data # Here we are dumping all the docker container startup configuration data
# so that we can have access to how they are started outside of heat # so that we can have access to how they are started outside of heat
# and docker-cmd. This lets us create command line tools to test containers. # and docker-cmd. This lets us create command line tools to test containers.
@ -262,6 +308,7 @@
when: ansible_check_mode when: ansible_check_mode
tags: tags:
- host_config - host_config
- container_config
- name: Create /etc/puppet/check-mode/hieradata directory for check mode - name: Create /etc/puppet/check-mode/hieradata directory for check mode
file: file:
@ -276,6 +323,7 @@
- not check_mode_dir.stat.exists - not check_mode_dir.stat.exists
tags: tags:
- host_config - host_config
- container_config
- name: Write the config_step hieradata - name: Write the config_step hieradata
copy: copy:
@ -298,6 +346,7 @@
check_mode: no check_mode: no
tags: tags:
- host_config - host_config
- container_config
- name: Run puppet host configuration for step {{ step }} - name: Run puppet host configuration for step {{ step }}
when: enable_puppet|default(true)|bool when: enable_puppet|default(true)|bool
@ -339,6 +388,10 @@
DEBUG: '{{ docker_puppet_debug | default(false) }}' DEBUG: '{{ docker_puppet_debug | default(false) }}'
PROCESS_COUNT: '{{ docker_puppet_process_count | default(3) }}' PROCESS_COUNT: '{{ docker_puppet_process_count | default(3) }}'
CONTAINER_CLI: "{{ container_cli | default('docker') }}" CONTAINER_CLI: "{{ container_cli | default('docker') }}"
CONFIG: '/var/lib/docker-puppet/{{ ansible_check_mode | ternary("check-mode/", "") }}docker-puppet.json'
CONFIG_VOLUME_PREFIX: '/var/lib/config-data{{ ansible_check_mode | ternary("/check-mode", "") }}'
CHECK_MODE: '{{ ansible_check_mode | ternary(1, 0) }}'
STARTUP_CONFIG_PATTERN: '/var/lib/tripleo-config/{{ ansible_check_mode | ternary("check-mode/", "") }}docker-container-startup-config-step_*.json'
when: step == "1" when: step == "1"
changed_when: false changed_when: false
check_mode: no check_mode: no
@ -356,6 +409,31 @@
tags: tags:
- container_config - container_config
- name: Diff docker-puppet.py puppet-generated changes for check mode
command:
diff -ruN /var/lib/config-data/puppet-generated /var/lib/config-data/check-mode/puppet-generated
register: diff_results
tags:
- container_config
check_mode: no
when:
- step == "1"
- ansible_check_mode
- ansible_diff_mode
failed_when: false
changed_when: diff_results.rc == 1
- name: Diff docker-puppet.py puppet-generated changes for check mode
debug:
var: diff_results.stdout_lines
changed_when: diff_results.rc == 1
when:
- step == "1"
- ansible_check_mode
- ansible_diff_mode
tags:
- container_config
################################################## ##################################################
# Per step starting of the containers using paunch # Per step starting of the containers using paunch
################################################## ##################################################

View File

@ -255,6 +255,13 @@ with open(sh_script, 'w') as script_file:
TAGS="--tags \"$PUPPET_TAGS\"" TAGS="--tags \"$PUPPET_TAGS\""
fi fi
CHECK_MODE=""
if [ -d "/tmp/puppet-check-mode" ]; then
mkdir -p /etc/puppet/check-mode
cp -a /tmp/puppet-check-mode/* /etc/puppet/check-mode
CHECK_MODE="--hiera_config /etc/puppet/check-mode/hiera.yaml"
fi
# Create a reference timestamp to easily find all files touched by # Create a reference timestamp to easily find all files touched by
# puppet. The sync ensures we get all the files we want due to # puppet. The sync ensures we get all the files we want due to
# different timestamp. # different timestamp.
@ -276,6 +283,7 @@ with open(sh_script, 'w') as script_file:
--logdest console \ --logdest console \
--modulepath=/etc/puppet/modules:/usr/share/openstack-puppet/modules \ --modulepath=/etc/puppet/modules:/usr/share/openstack-puppet/modules \
$TAGS \ $TAGS \
$CHECK_MODE \
/etc/config.pp /etc/config.pp
rc=$? rc=$?
set -e set -e
@ -322,7 +330,7 @@ with open(sh_script, 'w') as script_file:
def mp_puppet_config(*args): def mp_puppet_config(*args):
(config_volume,puppet_tags,manifest,config_image,volumes,privileged) = args[0] (config_volume,puppet_tags,manifest,config_image,volumes,privileged,check_mode) = args[0]
log = get_logger() log = get_logger()
log.info('Starting configuration of %s using image %s' % (config_volume, log.info('Starting configuration of %s using image %s' % (config_volume,
config_image)) config_image))
@ -332,6 +340,8 @@ def mp_puppet_config(*args):
log.debug('config_image %s' % config_image) log.debug('config_image %s' % config_image)
log.debug('volumes %s' % volumes) log.debug('volumes %s' % volumes)
log.debug('privileged %s' % privileged) log.debug('privileged %s' % privileged)
log.debug('check_mode %s' % check_mode)
with tempfile.NamedTemporaryFile() as tmp_man: with tempfile.NamedTemporaryFile() as tmp_man:
with open(tmp_man.name, 'w') as man_file: with open(tmp_man.name, 'w') as man_file:
man_file.write('include ::tripleo::packages\n') man_file.write('include ::tripleo::packages\n')
@ -368,6 +378,11 @@ def mp_puppet_config(*args):
dcmd = common_dcmd + cli_dcmd dcmd = common_dcmd + cli_dcmd
if check_mode:
dcmd.extend([
'--volume',
'/etc/puppet/check-mode:/tmp/puppet-check-mode:ro'])
for volume in volumes: for volume in volumes:
if volume: if volume:
dcmd.extend(['--volume', volume]) dcmd.extend(['--volume', volume])
@ -415,6 +430,9 @@ def mp_puppet_config(*args):
# to consume. # to consume.
process_map = [] process_map = []
check_mode = int(os.environ.get('CHECK_MODE', 0))
log.debug('CHECK_MODE: %s' % check_mode)
for config_volume in configs: for config_volume in configs:
service = configs[config_volume] service = configs[config_volume]
@ -429,7 +447,8 @@ for config_volume in configs:
else: else:
puppet_tags = "file,file_line,concat,augeas,cron" puppet_tags = "file,file_line,concat,augeas,cron"
process_map.append([config_volume, puppet_tags, manifest, config_image, volumes, privileged]) process_map.append([config_volume, puppet_tags, manifest, config_image,
volumes, privileged, check_mode])
for p in process_map: for p in process_map:
log.debug('- %s' % p) log.debug('- %s' % p)
@ -451,7 +470,7 @@ for returncode, config_volume in zip(returncodes, config_volumes):
# Update the startup configs with the config hash we generated above # Update the startup configs with the config hash we generated above
startup_configs = os.environ.get('STARTUP_CONFIG_PATTERN', '/var/lib/tripleo-config/docker-container-startup-config-step_*.json') startup_configs = os.environ.get('STARTUP_CONFIG_PATTERN', '/var/lib/tripleo-config/docker-container-startup-config-step_*.json')
log.debug('STARTUP_CONFIG_PATTERN: %s' % startup_configs) log.debug('STARTUP_CONFIG_PATTERN: %s' % startup_configs)
infiles = glob.glob('/var/lib/tripleo-config/docker-container-startup-config-step_*.json') infiles = glob.glob(startup_configs)
for infile in infiles: for infile in infiles:
with open(infile) as f: with open(infile) as f:
infile_data = json.load(f) infile_data = json.load(f)