fix: error fetch remote ref when using fetch depth of 1 (#996)
This commit is contained in:
		
							parent
							
								
									063e674726
								
							
						
					
					
						commit
						23e3c4300c
					
				| @ -439,16 +439,9 @@ jobs: | |||||||
|         with: |         with: | ||||||
|           fetch-depth: 0 |           fetch-depth: 0 | ||||||
| 
 | 
 | ||||||
|       - name: Get Base SHA |  | ||||||
|         id: get-base-sha |  | ||||||
|         run: | |  | ||||||
|           echo "base_sha=$(git rev-parse "$(git tag --sort=-v:refname | head -n 2 | tail -n 1)")" >> $GITHUB_OUTPUT |  | ||||||
| 
 |  | ||||||
|       - name: Get changed files |       - name: Get changed files | ||||||
|         id: changed-files |         id: changed-files | ||||||
|         uses: tj-actions/changed-files@v35 |         uses: tj-actions/changed-files@v35 | ||||||
|         with: |  | ||||||
|           base_sha: ${{ steps.get-base-sha.outputs.base_sha }} |  | ||||||
| 
 | 
 | ||||||
|       - name: Get changed files in the .github folder |       - name: Get changed files in the .github folder | ||||||
|         id: changed-files-specific |         id: changed-files-specific | ||||||
|  | |||||||
| @ -187,6 +187,7 @@ runs: | |||||||
|         GITHUB_REF: ${{ github.ref }} |         GITHUB_REF: ${{ github.ref }} | ||||||
|         GITHUB_SHA: ${{ github.sha }} |         GITHUB_SHA: ${{ github.sha }} | ||||||
|         GITHUB_WORKSPACE: ${{ github.workspace }} |         GITHUB_WORKSPACE: ${{ github.workspace }} | ||||||
|  |         GITHUB_EVENT_BASE_REF: ${{ github.event.base_ref }} | ||||||
|         GITHUB_EVENT_HEAD_REPO_FORK: ${{ github.event.pull_request.head.repo.fork }} |         GITHUB_EVENT_HEAD_REPO_FORK: ${{ github.event.pull_request.head.repo.fork }} | ||||||
|         GITHUB_EVENT_PULL_REQUEST_NUMBER: ${{ github.event.pull_request.number }} |         GITHUB_EVENT_PULL_REQUEST_NUMBER: ${{ github.event.pull_request.number }} | ||||||
|         GITHUB_EVENT_PULL_REQUEST_BASE_REF: ${{ github.event.pull_request.base.ref }} |         GITHUB_EVENT_PULL_REQUEST_BASE_REF: ${{ github.event.pull_request.base.ref }} | ||||||
|  | |||||||
							
								
								
									
										31
									
								
								diff-sha.sh
									
									
									
									
									
								
							
							
						
						
									
										31
									
								
								diff-sha.sh
									
									
									
									
									
								
							| @ -9,10 +9,12 @@ PREVIOUS_SHA="" | |||||||
| CURRENT_SHA="" | CURRENT_SHA="" | ||||||
| DIFF="..." | DIFF="..." | ||||||
| IS_TAG="false" | IS_TAG="false" | ||||||
|  | SOURCE_BRANCH="" | ||||||
| 
 | 
 | ||||||
| if [[ "$GITHUB_REF" == "refs/tags/"* ]]; then | if [[ "$GITHUB_REF" == "refs/tags/"* ]]; then | ||||||
|   IS_TAG="true" |   IS_TAG="true" | ||||||
|   EXTRA_ARGS="--prune --no-recurse-submodules" |   EXTRA_ARGS="--prune --no-recurse-submodules" | ||||||
|  |   SOURCE_BRANCH=${GITHUB_EVENT_BASE_REF#refs/heads/} | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| if [[ -z $GITHUB_EVENT_PULL_REQUEST_BASE_REF || "$GITHUB_EVENT_HEAD_REPO_FORK" == "true" ]]; then | if [[ -z $GITHUB_EVENT_PULL_REQUEST_BASE_REF || "$GITHUB_EVENT_HEAD_REPO_FORK" == "true" ]]; then | ||||||
| @ -52,15 +54,27 @@ else | |||||||
|   echo "Valid git version found: ($GIT_VERSION)" |   echo "Valid git version found: ($GIT_VERSION)" | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
|  | IS_SHALLOW=$(git rev-parse --is-shallow-repository) && exit_status=$? || exit_status=$? | ||||||
|  | 
 | ||||||
|  | if [[ $exit_status -ne 0 ]]; then | ||||||
|  |   echo "::error::Unable to determine if the repository is shallow" | ||||||
|  |   exit 1 | ||||||
|  | fi | ||||||
|  | 
 | ||||||
| if [[ -z $GITHUB_EVENT_PULL_REQUEST_BASE_REF ]]; then | if [[ -z $GITHUB_EVENT_PULL_REQUEST_BASE_REF ]]; then | ||||||
|   echo "Running on a push event..." |   echo "Running on a push event..." | ||||||
|   TARGET_BRANCH=$GITHUB_REFNAME |   TARGET_BRANCH=$GITHUB_REFNAME | ||||||
|   CURRENT_BRANCH=$TARGET_BRANCH |   CURRENT_BRANCH=$TARGET_BRANCH | ||||||
| 
 | 
 | ||||||
|   if $(git rev-parse --is-shallow-repository); then |   if [[ "$IS_SHALLOW" == "true" ]]; then | ||||||
|     echo "Fetching remote refs..." |     echo "Fetching remote refs..." | ||||||
|     # shellcheck disable=SC2086 |     if [[ "$IS_TAG" == "false" ]]; then | ||||||
|     git fetch $EXTRA_ARGS -u --progress --deepen="$INPUT_FETCH_DEPTH" origin +refs/heads/"$CURRENT_BRANCH":refs/remotes/origin/"$CURRENT_BRANCH" 1>/dev/null |       # shellcheck disable=SC2086 | ||||||
|  |       git fetch $EXTRA_ARGS -u --progress --deepen="$INPUT_FETCH_DEPTH" origin +refs/heads/"$CURRENT_BRANCH":refs/remotes/origin/"$CURRENT_BRANCH" 1>/dev/null | ||||||
|  |     elif [[ "$SOURCE_BRANCH" != "" ]]; then | ||||||
|  |       # shellcheck disable=SC2086 | ||||||
|  |       git fetch $EXTRA_ARGS -u --progress --deepen="$INPUT_FETCH_DEPTH" origin +refs/heads/"$SOURCE_BRANCH":refs/remotes/origin/"$SOURCE_BRANCH" 1>/dev/null | ||||||
|  |     fi | ||||||
|     # shellcheck disable=SC2086 |     # shellcheck disable=SC2086 | ||||||
|     git submodule foreach git fetch $EXTRA_ARGS -u --progress --deepen="$INPUT_FETCH_DEPTH" || true |     git submodule foreach git fetch $EXTRA_ARGS -u --progress --deepen="$INPUT_FETCH_DEPTH" || true | ||||||
|   fi |   fi | ||||||
| @ -102,6 +116,13 @@ if [[ -z $GITHUB_EVENT_PULL_REQUEST_BASE_REF ]]; then | |||||||
|         echo "::error::Unable to locate a previous commit for the specified date: $INPUT_SINCE" |         echo "::error::Unable to locate a previous commit for the specified date: $INPUT_SINCE" | ||||||
|         exit 1 |         exit 1 | ||||||
|       fi |       fi | ||||||
|  |     elif [[ "$IS_TAG" == "true" ]]; then | ||||||
|  |       PREVIOUS_SHA=$(git rev-parse "$(git tag --sort=-v:refname | head -n 2 | tail -n 1)") && exit_status=$? || exit_status=$? | ||||||
|  | 
 | ||||||
|  |       if [[ -z "$PREVIOUS_SHA" ]]; then | ||||||
|  |         echo "::error::Unable to locate a previous commit for the specified tag: $GITHUB_REF" | ||||||
|  |         exit 1 | ||||||
|  |       fi | ||||||
|     else |     else | ||||||
|       if [[ "$INPUT_SINCE_LAST_REMOTE_COMMIT" == "true" ]]; then |       if [[ "$INPUT_SINCE_LAST_REMOTE_COMMIT" == "true" ]]; then | ||||||
|         PREVIOUS_SHA="" |         PREVIOUS_SHA="" | ||||||
| @ -162,7 +183,7 @@ else | |||||||
|     TARGET_BRANCH=$CURRENT_BRANCH |     TARGET_BRANCH=$CURRENT_BRANCH | ||||||
|   fi |   fi | ||||||
| 
 | 
 | ||||||
|   if $(git rev-parse --is-shallow-repository); then |   if [[ "$IS_SHALLOW" == "true" ]]; then | ||||||
|     echo "Fetching remote refs..." |     echo "Fetching remote refs..." | ||||||
|     # shellcheck disable=SC2086 |     # shellcheck disable=SC2086 | ||||||
|     git fetch $EXTRA_ARGS -u --progress origin pull/"$GITHUB_EVENT_PULL_REQUEST_NUMBER"/head:"$CURRENT_BRANCH" 1>/dev/null |     git fetch $EXTRA_ARGS -u --progress origin pull/"$GITHUB_EVENT_PULL_REQUEST_NUMBER"/head:"$CURRENT_BRANCH" 1>/dev/null | ||||||
| @ -213,7 +234,7 @@ else | |||||||
|     else |     else | ||||||
|       PREVIOUS_SHA=$(git rev-parse origin/"$TARGET_BRANCH") && exit_status=$? || exit_status=$? |       PREVIOUS_SHA=$(git rev-parse origin/"$TARGET_BRANCH") && exit_status=$? || exit_status=$? | ||||||
| 
 | 
 | ||||||
|       if $(git rev-parse --is-shallow-repository); then |       if [[ "$IS_SHALLOW" == "true" ]]; then | ||||||
|         # check if the merge base is in the local history |         # check if the merge base is in the local history | ||||||
|         if ! git merge-base "$PREVIOUS_SHA" "$CURRENT_SHA" 1>/dev/null 2>&1; then |         if ! git merge-base "$PREVIOUS_SHA" "$CURRENT_SHA" 1>/dev/null 2>&1; then | ||||||
|           echo "::debug::Merge base is not in the local history, fetching remote target branch..." |           echo "::debug::Merge base is not in the local history, fetching remote target branch..." | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Tonye Jack
						Tonye Jack