project-config/roles/copy-release-tools-scripts/files/release-tools/make_branch.sh
Riccardo Pittau 8d4315ec47 Do not update upper constraints for intermediate branches
They should use the current upper constraints.

Change-Id: If6d2d747c1db2b905e89354930647955aece9202
2020-08-17 17:28:17 +02:00

89 lines
2.6 KiB
Bash
Executable File

#!/bin/bash
#
# Script to create branches for a project
#
# All Rights Reserved.
#
# 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.
set -e
set -x
if [[ $# -lt 3 ]]; then
echo "Usage: $0 repo_name branch_name git_reference"
echo
echo "Example: $0 openstack/oslo.config stable/kilo 1.9.2"
exit 2
fi
TOOLSDIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
source $TOOLSDIR/functions
REPO=$1
NEW_BRANCH=$2
START_POINT=$3
MASTER_BRANCH_NAME=${4:-}
LPROJECT="$PROJECT"
PROJECT=$(basename $REPO)
branch_as_path_entry=$(echo $NEW_BRANCH | sed -s 's|/|-|g')
setup_temp_space branch-$PROJECT-$branch_as_path_entry
clone_repo $REPO
cd $REPO
if $(git branch -r | grep $NEW_BRANCH > /dev/null); then
echo "A $NEW_BRANCH branch already exists !"
cd ../..
rm -rf $MYTMPDIR
exit 0
fi
# NOTE(dhellmann): We wait to set up git-review until after we have
# checked for the branch and then check out the tagged point to create
# the branch in case the master branch has been retired since then and
# there is no longer a .gitreview file there.
LANG=C git checkout $START_POINT
LANG=C git review -s
echo "Creating $NEW_BRANCH from $START_POINT"
git branch $NEW_BRANCH $START_POINT
REALSHA=`git show-ref -s $NEW_BRANCH`
git push gerrit $NEW_BRANCH
update_gitreview "$NEW_BRANCH"
# Do not update upper constraints on driverfixes or intermediate branches
if [[ ! $NEW_BRANCH =~ driverfixes/|bugfix/ ]]; then
update_upper_constraints "$NEW_BRANCH"
fi
if [[ $NEW_BRANCH =~ stable/ ]]; then
series=$(echo $NEW_BRANCH | cut -f2 -d/)
if [[ -d releasenotes/source ]]; then
# Also update the reno settings, in master, to add the new
# series page and bump the SemVer value for feature work.
echo "Updating reno and semver"
git checkout master
$TOOLSDIR/add_release_note_page.sh $series .
else
echo "$REPO does not use reno, no update needed"
fi
# Now propose master branch changes with the new branchname
# according to PTI.
if [[ ! -z "${MASTER_BRANCH_NAME}" ]]; then
$TOOLSDIR/add_master_python3_jobs.sh ${NEW_BRANCH} ${MASTER_BRANCH_NAME} .
fi
fi