f635e090bd
This patch includes updates of all SHA's and pip, wheel and setuptools pins. Due to Bug #1561947, the backend glance store has been changed from swift to file in the AIO gate. This has been done becuase the glance store project has an issue with session that causes it to be incompatible with swift. Being that the master integration gate is depending on this change to go it is needed to temporarily disable the swift image store in glance until this issue is fixed. The branch updater sciprt was modified to search for and update roles if they're found within the default or user provided role path. This change is resolving bash errors that happen when the script is run in mitaka+. Related-Bug: 1561947 Change-Id: I2e09e3e0abb61f5e97e2af7b283f0aed6dadd853 Signed-off-by: Kevin Carter <kevin.carter@rackspace.com>
165 lines
5.9 KiB
Bash
Executable File
165 lines
5.9 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
# Copyright 2015, Rackspace US, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
# This script was created to rapidly interate through a repo_package file
|
|
# that contains git sources and set the various repositories inside to
|
|
# the head of given branch via the SHA. This makes it possible to update
|
|
# all of the services that we support in an "automated" fashion.
|
|
|
|
ONLINE_BRANCH=${ONLINE_BRANCH:-"master"}
|
|
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"}
|
|
OSA_ROLE_PATH="${OSA_ROLE_PATH:-playbooks/roles}"
|
|
OSA_ROLE_PREFIX="${OSA_ROLE_PREFIX:-os}"
|
|
OSA_ROLE_LOCAL="${OSA_ROLE_PATH}/${OSA_ROLE_PREFIX}"
|
|
|
|
IFS=$'\n'
|
|
|
|
if echo "$@" | grep -e '-h' -e '--help';then
|
|
echo "
|
|
Options:
|
|
-b|--branch (name of branch, eg: stable/liberty)
|
|
-s|--service-file (path to service yaml file to parse)
|
|
-r|--osa-role-path (path to stored roles to update, eg: 'playbooks/roles')
|
|
-p|--osa-role-prefix (the prefix in front of OpenStack service roles, eg: 'os')
|
|
"
|
|
exit 0
|
|
fi
|
|
|
|
# Provide some CLI options
|
|
while [[ $# > 1 ]]; do
|
|
key="$1"
|
|
case $key in
|
|
-b|--branch)
|
|
ONLINE_BRANCH="$2"
|
|
shift
|
|
;;
|
|
-s|--service-file)
|
|
SERVICE_FILE="$2"
|
|
shift
|
|
;;
|
|
-r|--osa-role-path)
|
|
OSA_ROLE_PATH="$2"
|
|
shift
|
|
;;
|
|
-p|--osa-role-prefix)
|
|
OSA_ROLE_PREFIX="$2"
|
|
shift
|
|
;;
|
|
*)
|
|
;;
|
|
esac
|
|
shift
|
|
done
|
|
|
|
# Iterate through the service file
|
|
for repo in $(grep 'git_repo\:' ${SERVICE_FILE}); do
|
|
|
|
echo -e "\nInspecting ${repo}..."
|
|
|
|
# Set the repo name
|
|
repo_name=$(echo "${repo}" | sed 's/_git_repo\:.*//g')
|
|
|
|
# Set the repo address
|
|
repo_address=$(echo ${repo} | awk '{print $2}')
|
|
|
|
# Get the branch data
|
|
branch_data=$(git ls-remote ${repo_address} | grep "${ONLINE_BRANCH}$")
|
|
|
|
# If there is branch data continue
|
|
if [ ! -z "${branch_data}" ];then
|
|
|
|
# Set the branch sha for the head of the branch
|
|
branch_sha=$(echo "${branch_data}" | awk '{print $1}')
|
|
|
|
# Set the branch entry
|
|
branch_entry="${branch_sha} # HEAD of \"$ONLINE_BRANCH\" as of $(date +%d.%m.%Y)"
|
|
|
|
# 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}
|
|
|
|
# If the repo is in the specified list, then action the additional updates
|
|
if [[ "${OPENSTACK_SERVICE_LIST}" =~ "${repo_name}" ]]; then
|
|
if [[ -d "${OSA_ROLE_LOCAL}_${repo_name}" ]]; then
|
|
repo_tmp_path="/tmp/${repo_name}"
|
|
|
|
# Ensure that the temp path doesn't exist
|
|
[[ -d "repo_tmp_path" ]] && rm -rf "${repo_tmp_path}"
|
|
|
|
# Do a shallow clone of the repo to work with
|
|
git clone --quiet --depth=5 --branch ${ONLINE_BRANCH} --no-checkout --single-branch ${repo_address} "${repo_tmp_path}"
|
|
pushd ${repo_tmp_path} > /dev/null
|
|
git checkout --quiet "${branch_sha}"
|
|
popd > /dev/null
|
|
|
|
# Update the policy files
|
|
find ${repo_tmp_path}/etc -name "policy.json" -exec \
|
|
cp {} "${OSA_ROLE_LOCAL}_${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} \"${OSA_ROLE_LOCAL}_${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 {} "${OSA_ROLE_LOCAL}_${repo_name}/templates/rootwrap.conf.j2" \;
|
|
|
|
# Update the rootwrap filters
|
|
find ${repo_tmp_path}/etc -name "*.filters" -exec \
|
|
bash -c "name=\"{}\"; cp \${name} \"${OSA_ROLE_LOCAL}_${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} \"${OSA_ROLE_LOCAL}_${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} \"${OSA_ROLE_LOCAL}_${repo_name}/templates/\$(echo \${name} | rev | cut -sd / -f -2 | rev).j2\"" \;
|
|
fi
|
|
|
|
# Clean up the temporary files
|
|
[[ -d "repo_tmp_path" ]] && rm -rf "${repo_tmp_path}"
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
echo -e "Processed $repo_name @ $branch_entry\n"
|
|
|
|
done
|
|
|
|
unset IFS
|
|
|
|
# Finally, update the PIP_INSTALL_OPTIONS with the current versions of pip, wheel and setuptools
|
|
PIP_CURRENT_OPTIONS=$(./scripts/get-pypi-pkg-version.py -p pip setuptools wheel -l horizontal)
|
|
sed -i.bak "s|^PIP_INSTALL_OPTIONS=.*|PIP_INSTALL_OPTIONS=\$\{PIP_INSTALL_OPTIONS:-'${PIP_CURRENT_OPTIONS}'\}|" scripts/scripts-library.sh
|
|
|
|
for pin in ${PIP_CURRENT_OPTIONS}; do
|
|
sed -i.bak "s|^$(echo ${pin} | cut -f1 -d=).*|${pin}|" *requirements.txt
|
|
sed -i.bak "s|^ - $(echo ${pin} | cut -f1 -d=).*| - ${pin}|" playbooks/inventory/group_vars/hosts.yml
|
|
done
|
|
|
|
echo "Updated pip install options/pins"
|