Merge "Include extra conf file updates when updating SHA's"

This commit is contained in:
Jenkins 2016-01-11 15:39:14 +00:00 committed by Gerrit Code Review
commit 9782bb58b2
7 changed files with 70 additions and 7 deletions

View File

@ -47,7 +47,7 @@
dest: "/etc/aodh/api_paste.ini" dest: "/etc/aodh/api_paste.ini"
config_overrides: "{{ aodh_api_paste_ini_overrides }}" config_overrides: "{{ aodh_api_paste_ini_overrides }}"
config_type: "ini" config_type: "ini"
- src: "policy.json" - src: "policy.json.j2"
dest: "/etc/aodh/policy.json" dest: "/etc/aodh/policy.json"
config_overrides: "{{ aodh_policy_overrides }}" config_overrides: "{{ aodh_policy_overrides }}"
config_type: "json" config_type: "json"

View File

@ -43,7 +43,7 @@
dest: "/etc/ceilometer/pipeline.yaml" dest: "/etc/ceilometer/pipeline.yaml"
config_overrides: "{{ ceilometer_pipeline_yaml_overrides }}" config_overrides: "{{ ceilometer_pipeline_yaml_overrides }}"
config_type: "yaml" config_type: "yaml"
- src: "policy.json" - src: "policy.json.j2"
dest: "/etc/ceilometer/policy.json" dest: "/etc/ceilometer/policy.json"
config_overrides: "{{ ceilometer_policy_overrides }}" config_overrides: "{{ ceilometer_policy_overrides }}"
config_type: "json" config_type: "json"

View File

@ -51,7 +51,7 @@
owner: "{{ cinder_system_user_name }}" owner: "{{ cinder_system_user_name }}"
group: "{{ cinder_system_group_name }}" group: "{{ cinder_system_group_name }}"
with_items: with_items:
- { src: "volume.filters", dest: "/etc/cinder/rootwrap.d/volume.filters" } - { src: "rootwrap.d/volume.filters", dest: "/etc/cinder/rootwrap.d/volume.filters" }
notify: notify:
- Restart cinder services - Restart cinder services
tags: tags:

View File

@ -20,6 +20,7 @@
ONLINE_BRANCH=${ONLINE_BRANCH:-"master"} ONLINE_BRANCH=${ONLINE_BRANCH:-"master"}
SERVICE_FILE=${SERVICE_FILE:-"playbooks/defaults/repo_packages/openstack_services.yml"} SERVICE_FILE=${SERVICE_FILE:-"playbooks/defaults/repo_packages/openstack_services.yml"}
OPENSTACK_SERVICE_LIST=${OPENSTACK_SERVICE_LIST:-"aodh ceilometer cinder glance heat keystone neutron nova"}
IFS=$'\n' IFS=$'\n'
@ -51,20 +52,82 @@ shift
done done
# Iterate through the service file # Iterate through the service file
for repo in $(grep 'git_repo\:' ${SERVICE_FILE});do for repo in $(grep 'git_repo\:' ${SERVICE_FILE}); do
echo -e "\nInspecting ${repo}..."
# Set the repo name # Set the repo name
repo_name=$(echo "${repo}" | sed 's/_git_repo\:.*//g') repo_name=$(echo "${repo}" | sed 's/_git_repo\:.*//g')
# Set the repo address
repo_address=$(echo ${repo} | awk '{print $2}')
# Get the branch data # Get the branch data
branch_data=$(git ls-remote "$(echo ${repo} | awk '{print $2}')" | grep "${ONLINE_BRANCH}$") branch_data=$(git ls-remote ${repo_address} | grep "${ONLINE_BRANCH}$")
# If there is branch data continue # If there is branch data continue
if [ ! -z "${branch_data}" ];then if [ ! -z "${branch_data}" ];then
# Set the branch sha for the head of the branch # Set the branch sha for the head of the branch
branch_sha=$(echo "${branch_data}" | awk '{print $1}') branch_sha=$(echo "${branch_data}" | awk '{print $1}')
# Set the branch entry # Set the branch entry
branch_entry="${branch_sha} # HEAD of \"$ONLINE_BRANCH\" as of $(date +%d.%m.%Y)" branch_entry="${branch_sha} # HEAD of \"$ONLINE_BRANCH\" as of $(date +%d.%m.%Y)"
# Write the branch entry
# Write the branch entry into the repo_packages file
sed -i.bak "s|${repo_name}_git_install_branch:.*|${repo_name}_git_install_branch: $branch_entry|" ${SERVICE_FILE} sed -i.bak "s|${repo_name}_git_install_branch:.*|${repo_name}_git_install_branch: $branch_entry|" ${SERVICE_FILE}
echo "processed $repo_name @ $branch_entry"
# If the repo is in the specified list, then action the additional updates
if [[ "${OPENSTACK_SERVICE_LIST}" =~ "${repo_name}" ]]; then
repo_tmp_path="/tmp/${repo_name}"
# Ensure that the temp path doesn't exist
rm -rf ${repo_tmp_path}
# Do a shallow clone of the repo to work with
git clone --quiet --depth=1 --origin ${branch_sha} ${repo_address} ${repo_tmp_path}
# Update the policy files
find ${repo_tmp_path}/etc -name "policy.json" -exec \
cp {} "playbooks/roles/os_${repo_name}/templates/policy.json.j2" \;
# Tweak the paste files
find ${repo_tmp_path}/etc -name "*-paste.ini" -exec \
sed -i.bak "s|hmac_keys = SECRET_KEY|hmac_keys = {{ ${repo_name}_profiler_hmac_key }}|" {} \;
# Update the paste files
find ${repo_tmp_path}/etc -name "*-paste.ini" -exec \
bash -c "name=\"{}\"; cp \${name} \"playbooks/roles/os_${repo_name}/templates/\$(basename \${name}).j2\"" \;
# Tweak the rootwrap conf files
find ${repo_tmp_path}/etc -name "rootwrap.conf" -exec \
sed -i.bak "s|exec_dirs=|exec_dirs={{ ${repo_name}_bin }},|" {} \;
# Update the rootwrap conf files
find ${repo_tmp_path}/etc -name "rootwrap.conf" -exec \
cp {} "playbooks/roles/os_${repo_name}/templates/rootwrap.conf.j2" \;
# Update the rootwrap filters
find ${repo_tmp_path}/etc -name "*.filters" -exec \
bash -c "name=\"{}\"; cp \${name} \"playbooks/roles/os_${repo_name}/files/rootwrap.d/\$(basename \${name})\"" \;
# Update the yaml files for Ceilometer
if [ "${repo_name}" = "ceilometer" ]; then
find ${repo_tmp_path}/etc -name "*.yaml" -exec \
bash -c "name=\"{}\"; cp \${name} \"playbooks/roles/os_${repo_name}/templates/\$(basename \${name}).j2\"" \;
fi
# Update the yaml files for Heat
if [ "${repo_name}" = "heat" ]; then
find ${repo_tmp_path}/etc -name "*.yaml" -exec \
bash -c "name=\"{}\"; cp \${name} \"playbooks/roles/os_${repo_name}/templates/\$(echo \${name} | rev | cut -sd / -f -2 | rev).j2\"" \;
fi
# Clean up the temporary files
rm -rf ${repo_tmp_path}
fi
fi fi
echo -e "Processed $repo_name @ $branch_entry\n"
done done