git: git checkout for a commit hash combinated with depth argument

This patch: https://review.opendev.org/c/openstack/devstack/+/882299
provides functionality, that commit hash can be passed as last arugment,
however when GIT_DEPTH is set, it fails, as in:

timeout -s SIGINT 0 git clone https://github.com/ovn-org/ovn.git ./ovn
--depth 1 --branch 03b95a4566a15f7544f4cdf35629dacede4dcf55
fatal: Remote branch 03b95a4566a15f7544f4cdf35629dacede4dcf55
not found in upstream origin

Closes-Bug: #2023020
Change-Id: I748354964a133e028e12458cc9014d6d014cbdb9
This commit is contained in:
jskunda 2023-07-18 09:32:05 +02:00
parent e261bd809e
commit 770352beb0

View File

@ -609,9 +609,10 @@ 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
git_timed clone $git_clone_flags $git_remote $git_dest git_timed clone --no-checkout $git_clone_flags $git_remote $git_dest
cd $git_dest cd $git_dest
git checkout $git_ref git_timed fetch $git_clone_flags origin $git_ref
git_timed checkout FETCH_HEAD
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