8d4315ec47
They should use the current upper constraints. Change-Id: If6d2d747c1db2b905e89354930647955aece9202
89 lines
2.6 KiB
Bash
Executable File
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
|