diff --git a/.github/workflows/issue-comment-test.yml b/.github/workflows/issue-comment-test.yml index d5eab243..b721fada 100644 --- a/.github/workflows/issue-comment-test.yml +++ b/.github/workflows/issue-comment-test.yml @@ -34,6 +34,59 @@ jobs: shell: bash + - name: Run changed-files for old new filenames test rename + id: changed-files-all-old-new-renamed-files + uses: ./ + with: + base_sha: d1c0ee4 + sha: 4d04215 + fetch_depth: 60000 + include_all_old_new_renamed_files: true + + - name: Show output + run: | + echo '${{ toJSON(steps.changed-files-all-old-new-renamed-files.outputs) }}' + shell: + bash + + - name: Show output + run: | + echo '${{ toJSON(steps.changed-files-all-old-new-renamed-files.outputs) }}' + shell: + bash + + - name: Check all_old_new_renamed_files output on non windows platform + if: "!contains(steps.changed-files-all-old-new-renamed-files.outputs.all_old_new_renamed_files, 'test/test rename 1.txt,test/test rename-1.txt') && runner.os != 'Windows'" + run: | + echo "Invalid output: Expected to include (test/test rename 1.txt,test/test rename-1.txt) got (${{ steps.changed-files-all-old-new-renamed-files.outputs.all_old_new_renamed_files }})" + exit 1 + shell: + bash + + - name: Check all_old_new_renamed_files output on windows platform + if: "!contains(steps.changed-files-all-old-new-renamed-files.outputs.all_old_new_renamed_files, 'test\\test rename 1.txt,test\\test rename-1.txt') && runner.os == 'Windows'" + run: | + echo "Invalid output: Expected to not include (test\\test rename 1.txt,test\\test rename-1.txt) got (${{ steps.changed-files-all-old-new-renamed-files.outputs.all_old_new_renamed_files }})" + exit 1 + shell: + bash + + - name: Check the renamed_files output on non windows platform + if: "!contains(steps.changed-files-all-old-new-renamed-files.outputs.renamed_files, 'test/test rename-1.txt') && runner.os != 'Windows'" + run: | + echo "Invalid output: Expected to include (test/test rename-1.txt) got (${{ steps.changed-files-all-old-new-renamed-files.outputs.renamed_files }})" + exit 1 + shell: + bash + + - name: Check the renamed_files output on windows platform + if: "!contains(steps.changed-files-all-old-new-renamed-files.outputs.renamed_files, 'test\\test rename-1.txt') && runner.os == 'Windows'" + run: | + echo "Invalid output: Expected to not include (test\\test rename-1.txt) got (${{ steps.changed-files-all-old-new-renamed-files.outputs.renamed_files }})" + exit 1 + shell: + bash + issue_commented: # This job only runs for issue comments name: Issue comment @@ -63,4 +116,57 @@ jobs: run: | echo '${{ toJSON(steps.changed-files.outputs) }}' shell: - bash \ No newline at end of file + bash + + - name: Run changed-files for old new filenames test rename + id: changed-files-all-old-new-renamed-files + uses: ./ + with: + base_sha: d1c0ee4 + sha: 4d04215 + fetch_depth: 60000 + include_all_old_new_renamed_files: true + + - name: Show output + run: | + echo '${{ toJSON(steps.changed-files-all-old-new-renamed-files.outputs) }}' + shell: + bash + + - name: Show output + run: | + echo '${{ toJSON(steps.changed-files-all-old-new-renamed-files.outputs) }}' + shell: + bash + + - name: Check all_old_new_renamed_files output on non windows platform + if: "!contains(steps.changed-files-all-old-new-renamed-files.outputs.all_old_new_renamed_files, 'test/test rename 1.txt,test/test rename-1.txt') && runner.os != 'Windows'" + run: | + echo "Invalid output: Expected to include (test/test rename 1.txt,test/test rename-1.txt) got (${{ steps.changed-files-all-old-new-renamed-files.outputs.all_old_new_renamed_files }})" + exit 1 + shell: + bash + + - name: Check all_old_new_renamed_files output on windows platform + if: "!contains(steps.changed-files-all-old-new-renamed-files.outputs.all_old_new_renamed_files, 'test\\test rename 1.txt,test\\test rename-1.txt') && runner.os == 'Windows'" + run: | + echo "Invalid output: Expected to not include (test\\test rename 1.txt,test\\test rename-1.txt) got (${{ steps.changed-files-all-old-new-renamed-files.outputs.all_old_new_renamed_files }})" + exit 1 + shell: + bash + + - name: Check the renamed_files output on non windows platform + if: "!contains(steps.changed-files-all-old-new-renamed-files.outputs.renamed_files, 'test/test rename-1.txt') && runner.os != 'Windows'" + run: | + echo "Invalid output: Expected to include (test/test rename-1.txt) got (${{ steps.changed-files-all-old-new-renamed-files.outputs.renamed_files }})" + exit 1 + shell: + bash + + - name: Check the renamed_files output on windows platform + if: "!contains(steps.changed-files-all-old-new-renamed-files.outputs.renamed_files, 'test\\test rename-1.txt') && runner.os == 'Windows'" + run: | + echo "Invalid output: Expected to not include (test\\test rename-1.txt) got (${{ steps.changed-files-all-old-new-renamed-files.outputs.renamed_files }})" + exit 1 + shell: + bash diff --git a/dist/index.js b/dist/index.js index b3fcbce5..85e6abbf 100644 Binary files a/dist/index.js and b/dist/index.js differ diff --git a/dist/index.js.map b/dist/index.js.map index 077b8fd7..746242f7 100644 Binary files a/dist/index.js.map and b/dist/index.js.map differ diff --git a/src/commitSha.ts b/src/commitSha.ts index fa9ec0fe..17ca5bcb 100644 --- a/src/commitSha.ts +++ b/src/commitSha.ts @@ -5,6 +5,7 @@ import {Env} from './env' import {Inputs} from './inputs' import { canDiffCommits, + getCurrentBranchName, getHeadSha, getParentSha, getPreviousGitTag, @@ -90,7 +91,7 @@ export const getSHAForNonPullRequestEvent = async ( isTag: boolean ): Promise => { let targetBranch = env.GITHUB_REF_NAME - const currentBranch = targetBranch + let currentBranch = targetBranch let initialCommit = false if (!inputs.skipInitialFetch) { @@ -163,6 +164,16 @@ export const getSHAForNonPullRequestEvent = async ( const currentSha = await getCurrentSHA({inputs, workingDirectory}) let previousSha = inputs.baseSha const diff = '..' + const currentBranchName = await getCurrentBranchName({cwd: workingDirectory}) + + if ( + currentBranchName && + currentBranchName !== 'HEAD' && + (currentBranchName !== targetBranch || currentBranchName !== currentBranch) + ) { + targetBranch = currentBranchName + currentBranch = currentBranchName + } if (previousSha && currentSha && currentBranch && targetBranch) { if (previousSha === currentSha) { diff --git a/src/utils.ts b/src/utils.ts index 2e01a4ee..9e3138cd 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -696,6 +696,28 @@ export const getRemoteBranchHeadSha = async ({ return stdout.trim() } +export const getCurrentBranchName = async ({ + cwd +}: { + cwd: string +}): Promise => { + const {stdout, exitCode} = await exec.getExecOutput( + 'git', + ['rev-parse', '--abbrev-ref', 'HEAD'], + { + cwd, + ignoreReturnCode: true, + silent: !core.isDebug() + } + ) + + if (exitCode !== 0) { + return '' + } + + return stdout.trim() +} + export const getParentSha = async ({cwd}: {cwd: string}): Promise => { const {stdout, exitCode} = await exec.getExecOutput( 'git',