git: support git checkout for a commit hash

git_clone assumes a branch or a tag is passed as the last argument, and
it fails when a commit hash is passed, as in:

timeout -s SIGINT 0 git clone https://github.com/ovn-org/ovn.git
/opt/stack/ovn --branch 36e3ab9b47e93af0599a818e9d6b2930e49473f0
Cloning into '/opt/stack/ovn'...
fatal: Remote branch 36e3ab9b47e93af0599a818e9d6b2930e49473f0 not found
in upstream origin

Change-Id: Id1328d7cba418fa7c227ae9db4fe83c09fd06035
This commit is contained in:
Ihar Hrachyshka 2023-04-19 16:57:44 -04:00
parent b33ec4bf1b
commit e8915786e1

View File

@ -609,8 +609,9 @@ function git_clone {
echo "the project to the \$PROJECTS variable in the job definition." echo "the project to the \$PROJECTS variable in the job definition."
die $LINENO "ERROR_ON_CLONE is set to True so cloning not allowed in this configuration" die $LINENO "ERROR_ON_CLONE is set to True so cloning not allowed in this configuration"
fi fi
# '--branch' can also take tags git_timed clone $git_clone_flags $git_remote $git_dest
git_timed clone $git_clone_flags $git_remote $git_dest --branch $git_ref cd $git_dest
git checkout $git_ref
elif [[ "$RECLONE" = "True" ]]; then elif [[ "$RECLONE" = "True" ]]; then
# if it does exist then simulate what clone does if asked to RECLONE # if it does exist then simulate what clone does if asked to RECLONE
cd $git_dest cd $git_dest