Merge pull request #806 from tj-actions/fix/bug-with-retrieving-the-last-remote-commit
fix: bug with retrieving the last remote commit
This commit is contained in:
		
						commit
						ef0a29048c
					
				
							
								
								
									
										3
									
								
								.github/workflows/sync-release-version.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.github/workflows/sync-release-version.yml
									
									
									
									
										vendored
									
									
								
							| @ -1,8 +1,5 @@ | |||||||
| name: Update release version. | name: Update release version. | ||||||
| on: | on: | ||||||
|   push: |  | ||||||
|     tags: |  | ||||||
|       - '**' |  | ||||||
|   release: |   release: | ||||||
|     types: [published] |     types: [published] | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										4
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/test.yml
									
									
									
									
										vendored
									
									
								
							| @ -27,6 +27,8 @@ jobs: | |||||||
|         uses: actions/checkout@v3 |         uses: actions/checkout@v3 | ||||||
|       - name: shellcheck |       - name: shellcheck | ||||||
|         uses: reviewdog/action-shellcheck@v1.15 |         uses: reviewdog/action-shellcheck@v1.15 | ||||||
|  |         with: | ||||||
|  |           github_token: ${{ secrets.PAT_TOKEN }} | ||||||
| 
 | 
 | ||||||
|   test-multiple-repositories: |   test-multiple-repositories: | ||||||
|     name: Test with multiple repositories |     name: Test with multiple repositories | ||||||
| @ -929,7 +931,7 @@ jobs: | |||||||
|         with: |         with: | ||||||
|           branch: ${{ steps.branch-name.outputs.base_ref_branch }} |           branch: ${{ steps.branch-name.outputs.base_ref_branch }} | ||||||
|           workflow_id: 'test.yml' |           workflow_id: 'test.yml' | ||||||
|           github_token: ${{ secrets.GITHUB_TOKEN }} |           github_token: ${{ secrets.PAT_TOKEN }} | ||||||
|       - name: Run changed-files with a custom base sha |       - name: Run changed-files with a custom base sha | ||||||
|         if: github.event_name == 'pull_request' && github.event.action != 'closed' |         if: github.event_name == 'pull_request' && github.event.action != 'closed' | ||||||
|         id: changed-files-custom-base-sha |         id: changed-files-custom-base-sha | ||||||
|  | |||||||
							
								
								
									
										17
									
								
								diff-sha.sh
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								diff-sha.sh
									
									
									
									
									
								
							| @ -187,11 +187,8 @@ else | |||||||
|       PREVIOUS_SHA=$GITHUB_EVENT_BEFORE |       PREVIOUS_SHA=$GITHUB_EVENT_BEFORE | ||||||
| 
 | 
 | ||||||
|       if ! git rev-parse --quiet --verify "$PREVIOUS_SHA^{commit}" 1>/dev/null 2>&1; then |       if ! git rev-parse --quiet --verify "$PREVIOUS_SHA^{commit}" 1>/dev/null 2>&1; then | ||||||
|         PREVIOUS_SHA=$(git rev-list -n 1 "$TARGET_BRANCH" 2>&1) && exit_status=$? || exit_status=$? |         # shellcheck disable=SC2046 | ||||||
|       fi |         PREVIOUS_SHA=$(git rev-parse $(git branch -r --sort=-committerdate | head -1) 2>&1) && exit_status=$? || exit_status=$? | ||||||
| 
 |  | ||||||
|       if [[ -z "$PREVIOUS_SHA" || "$PREVIOUS_SHA" == "0000000000000000000000000000000000000000" ]]; then |  | ||||||
|         PREVIOUS_SHA=$(git rev-list -n 1 "$TARGET_BRANCH" 2>&1) && exit_status=$? || exit_status=$? |  | ||||||
|       fi |       fi | ||||||
|     else |     else | ||||||
|       PREVIOUS_SHA=$(git rev-list -n 1 "$TARGET_BRANCH" 2>&1) && exit_status=$? || exit_status=$? |       PREVIOUS_SHA=$(git rev-list -n 1 "$TARGET_BRANCH" 2>&1) && exit_status=$? || exit_status=$? | ||||||
| @ -214,16 +211,18 @@ else | |||||||
|       depth=$INPUT_FETCH_DEPTH |       depth=$INPUT_FETCH_DEPTH | ||||||
|       max_depth=$INPUT_MAX_FETCH_DEPTH |       max_depth=$INPUT_MAX_FETCH_DEPTH | ||||||
| 
 | 
 | ||||||
|       while [ -z "$( git merge-base --fork-point "$TARGET_BRANCH" "$CURRENT_SHA" )" ] || [ -z "$(git merge-base "$TARGET_BRANCH" "$CURRENT_SHA")" ] || [ -z "$(git diff --name-only --ignore-submodules=all "$PREVIOUS_SHA"..."$CURRENT_SHA" | head -1)" ]; do |       while ! git diff --name-only --ignore-submodules=all "$PREVIOUS_SHA"..."$CURRENT_SHA" 1>/dev/null; do | ||||||
|         depth=$((depth + 300)) |         echo "Fetching $depth commits..." | ||||||
| 
 | 
 | ||||||
|         # shellcheck disable=SC2086 |         # shellcheck disable=SC2086 | ||||||
|         git fetch $EXTRA_ARGS --deepen="$depth" origin "$TARGET_BRANCH" HEAD; |         git fetch $EXTRA_ARGS --deepen="$depth" origin "$TARGET_BRANCH" "$CURRENT_SHA"; | ||||||
| 
 | 
 | ||||||
|         if [[ $depth -gt $max_depth ]]; then |         if [[ $depth -gt $max_depth ]]; then | ||||||
|           echo "::error::Unable to locate a common ancestor between $TARGET_BRANCH and HEAD" |           echo "::error::Unable to locate a common ancestor between $TARGET_BRANCH and $CURRENT_SHA" | ||||||
|           exit 1 |           exit 1 | ||||||
|         fi |         fi | ||||||
|  |          | ||||||
|  |         depth=$((depth + 300)) | ||||||
|       done |       done | ||||||
|     else |     else | ||||||
|       echo "::debug::Not a shallow clone, skipping merge-base check." |       echo "::debug::Not a shallow clone, skipping merge-base check." | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	![39074581+repo-ranger[bot]@users.noreply.github.com](/assets/img/avatar_default.png) repo-ranger[bot]
						repo-ranger[bot]