9620683a66
Currently we're running propose-updates forrequirements-constraints under python 3.5 (on xenial). We take the results of freezing the constraints fro 3.5 and emit them as 3.4 constraints also. In the near term[1] we'd like to use the same technique to generate 3.6 constraints. With the inclusion of I8784509bc162eb6f2e80261bc2d81dbe63ce7989, and knowing that we no longer run on trusty node, we can now clone the 3.5 constraints freeze to both 3.4 and 3.6. However given that soon we'll be moving from xenial to bionic this introduces debt that will need to be fixed after the August release. Instead just move propose-updates for requirements-constraints job to bionic now and start cloning 3.6 to 3.5 and 3.4. Several jobs use propose-updates as a parent so I've made this change specifically where we call the propose-updates job specifically for requirements-constraints Note: This may feel very familiar if you reviewed I541b64afaee3bf466ff1a461fd2cb472657c4986, The aim is the same but I mis-understood what propose-update-constraints was doing and it wasn't the right job and was reverted in I75280b23e2e60800af45dc2343c82008ec9971a9 [1] See re-design discussion: http://lists.openstack.org/pipermail/openstack-dev/2018-July/132152.html Change-Id: I1874d4f20a6d69a881f0d9407e159c35ab21542d
206 lines
7.0 KiB
Bash
Executable File
206 lines
7.0 KiB
Bash
Executable File
#!/bin/bash -xe
|
|
|
|
# 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.
|
|
|
|
SCRIPTSDIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
|
source $SCRIPTSDIR/common.sh
|
|
|
|
OWN_PROJECT=$1
|
|
if [ -z "$OWN_PROJECT" ] ; then
|
|
echo "usage: $0 project"
|
|
exit 1
|
|
fi
|
|
|
|
if [ "$OWN_PROJECT" == "openstack-manuals" ] ; then
|
|
INITIAL_COMMIT_MSG="Updated from openstack-manuals"
|
|
TOPIC="openstack/openstack-manuals"
|
|
PROJECTS=$(cat projects.txt)
|
|
function update {
|
|
bash -xe tools/sync-projects.sh $1
|
|
}
|
|
elif [ "$OWN_PROJECT" == "requirements-constraints" ] ; then
|
|
INITIAL_COMMIT_MSG="Updated from generate-constraints"
|
|
TOPIC="openstack/requirements/constraints"
|
|
PROJECTS=openstack/requirements
|
|
VENV=$(mktemp -d)
|
|
trap "rm -rf $VENV" EXIT
|
|
virtualenv $VENV
|
|
$VENV/bin/pip install -e .
|
|
function update {
|
|
$VENV/bin/generate-constraints -b blacklist.txt -p /usr/bin/python2.7 \
|
|
-p /usr/bin/python3.6 -r global-requirements.txt \
|
|
--version-map 3.6:3.4 --version-map 3.6:3.5 \
|
|
> $1/upper-constraints.txt
|
|
}
|
|
elif [ "$OWN_PROJECT" == "devstack-plugins-list" ] ; then
|
|
INITIAL_COMMIT_MSG="Updated from generate-devstack-plugins-list"
|
|
TOPIC="openstack/devstack/plugins"
|
|
PROJECTS=openstack-dev/devstack
|
|
function update {
|
|
bash -ex tools/generate-devstack-plugins-list.sh $1
|
|
}
|
|
elif [ "$OWN_PROJECT" == "puppet-openstack-constraints" ] ; then
|
|
INITIAL_COMMIT_MSG="Updated from Puppet OpenStack modules constraints"
|
|
TOPIC="openstack/puppet/constraints"
|
|
PROJECTS=openstack/puppet-openstack-integration
|
|
function update {
|
|
bash /home/zuul/scripts/generate_puppetfile.sh
|
|
}
|
|
elif [ "$OWN_PROJECT" == "openstack-ansible-tests" ] ; then
|
|
INITIAL_COMMIT_MSG="Updated from OpenStack Ansible Tests"
|
|
TOPIC="openstack/openstack-ansible-tests/sync-tests"
|
|
PROJECTS=$(./gen-projects-list.sh)
|
|
function update {
|
|
bash /home/zuul/scripts/sync_openstack_ansible_common_files.sh $1
|
|
}
|
|
elif [ "$OWN_PROJECT" == "os-service-types" ] ; then
|
|
INITIAL_COMMIT_MSG="Updated from OpenStack Service Type Authority"
|
|
TOPIC="openstack/os-service-types/sync-service-types-authority"
|
|
PROJECTS="openstack/os-service-types"
|
|
function update {
|
|
pushd $1
|
|
curl https://service-types.openstack.org/service-types.json > os_service_types/data/service-types.json
|
|
popd
|
|
}
|
|
else
|
|
echo "Unknown project $1" >2
|
|
exit 1
|
|
fi
|
|
USERNAME="proposal-bot"
|
|
ALL_SUCCESS=0
|
|
|
|
# In periodic pipelines, ZUUL_REFNAME is not set, use BRANCH_NAME
|
|
# instead here. The JJB scripts in v2 set always ZUUL_REFNAME, in v3
|
|
# we pass in the branch as additional parameter.
|
|
if [ -z "$ZUUL_REFNAME" ] ; then
|
|
BRANCH_NAME=$2
|
|
if [ -z "$BRANCH_NAME" ] ; then
|
|
echo "usage: $0 project branch"
|
|
exit 1
|
|
fi
|
|
ZUUL_REFNAME=$BRANCH_NAME
|
|
fi
|
|
# Zuul v3 adds refs/heads, remove that to get the branch
|
|
ZUUL_REFNAME=${ZUUL_REFNAME#refs/heads/}
|
|
|
|
setup_git
|
|
|
|
for PROJECT in $PROJECTS; do
|
|
|
|
PROJECT_DIR=$(basename $PROJECT)
|
|
rm -rf $PROJECT_DIR
|
|
|
|
# Don't short circuit when one project fails to clone, just report the
|
|
# error and move onto the next project.
|
|
#
|
|
# TODO(fungi): switch to zuul-cloner once we add a persistent git cache
|
|
# to proposal.slave.openstack.org
|
|
if ! git clone https://git.openstack.org/$PROJECT.git; then
|
|
# ALL_SUCCESS is being set to 1, which means that a failure condition
|
|
# has been detected. The job will end in failure once it finishes
|
|
# cycling through the remaining projects.
|
|
ALL_SUCCESS=1
|
|
echo "Error in git clone: Ignoring $PROJECT"
|
|
continue
|
|
fi
|
|
pushd $PROJECT_DIR
|
|
|
|
# check whether the project has this branch or a suitable fallback
|
|
BRANCH=""
|
|
if git branch -a | grep -q "^ remotes/origin/$ZUUL_REFNAME$" ; then
|
|
BRANCH=$ZUUL_REFNAME
|
|
fi
|
|
|
|
# don't bother with this project if there's not a usable branch
|
|
if [ -n "$BRANCH" ] ; then
|
|
|
|
# Function setup_commit_message will set CHANGE_ID and CHANGE_NUM if a
|
|
# change exists and will always set COMMIT_MSG.
|
|
setup_commit_message $PROJECT $USERNAME $BRANCH $TOPIC "$INITIAL_COMMIT_MSG"
|
|
|
|
git checkout -B ${BRANCH} -t origin/${BRANCH}
|
|
# Need to set the git config in each repo as we shouldn't
|
|
# set it globally for the Jenkins user on the slaves.
|
|
setup_git
|
|
# Do error checking manually to continue with the next project
|
|
# in case of failures like a broken .gitreview file.
|
|
set +e
|
|
git review -s
|
|
RET=$?
|
|
set -e
|
|
popd
|
|
if [ "$RET" -ne "0" ] ; then
|
|
ALL_SUCCESS=1
|
|
echo "Error in git review -s: Ignoring $PROJECT"
|
|
continue
|
|
fi
|
|
|
|
pushd $PROJECT_DIR
|
|
# If a change already exists, let's pull it in and compute the
|
|
# 'git patch-id' of it.
|
|
PREV_PATCH_ID=""
|
|
if [[ -n ${CHANGE_NUM} ]]; then
|
|
# Ignore errors we get in case we can't download the patch with
|
|
# git-review. If that happens then we will submit a new patch.
|
|
set +e
|
|
git review -d ${CHANGE_NUM}
|
|
RET=$?
|
|
if [[ "$RET" -eq 0 ]]; then
|
|
PREV_PATCH_ID=$(git show | git patch-id | awk '{print $1}')
|
|
fi
|
|
set -e
|
|
# The git review changed our branch, go back to our correct branch
|
|
git checkout -f ${BRANCH}
|
|
fi
|
|
popd
|
|
|
|
# Don't short circuit when one project fails to sync.
|
|
set +e
|
|
update $PROJECT_DIR
|
|
RET=$?
|
|
set -e
|
|
if [ "$RET" -ne "0" ] ; then
|
|
ALL_SUCCESS=1
|
|
echo "Error in syncing: Ignoring $PROJECT"
|
|
continue
|
|
fi
|
|
|
|
pushd $PROJECT_DIR
|
|
if ! git diff --stat --exit-code HEAD ; then
|
|
# Commit and review
|
|
git_args="-a -F-"
|
|
git commit $git_args <<EOF
|
|
$COMMIT_MSG
|
|
EOF
|
|
# Do error checking manually to ignore one class of failure.
|
|
CUR_PATCH_ID=$(git show | git patch-id | awk '{print $1}')
|
|
# Don't submit if we have the same patch id of previously submitted
|
|
# patchset
|
|
if [[ "${PREV_PATCH_ID}" != "${CUR_PATCH_ID}" ]]; then
|
|
set +e
|
|
OUTPUT=$(git review -t $TOPIC $BRANCH)
|
|
RET=$?
|
|
[[ "$RET" -eq "0" || "$OUTPUT" =~ "no new changes" || "$OUTPUT" =~ "no changes made" ]]
|
|
SUCCESS=$?
|
|
[[ "$SUCCESS" -eq "0" && "$ALL_SUCCESS" -eq "0" ]]
|
|
ALL_SUCCESS=$?
|
|
set -e
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
popd
|
|
done
|
|
|
|
exit $ALL_SUCCESS
|