From c55203cfde3e5c11a452d352b4393e68b85b4533 Mon Sep 17 00:00:00 2001 From: Peter Evans <18365890+peter-evans@users.noreply.github.com> Date: Fri, 12 Apr 2024 18:18:19 +0900 Subject: [PATCH] fix: drop unnecessary fetch with unshallow on push-to-fork (#2849) --- dist/index.js | 14 +++----------- src/create-or-update-branch.ts | 18 +++--------------- 2 files changed, 6 insertions(+), 26 deletions(-) diff --git a/dist/index.js b/dist/index.js index 57130a6..b410e36 100644 --- a/dist/index.js +++ b/dist/index.js @@ -164,20 +164,12 @@ function createOrUpdateBranch(git, commitMessage, base, branch, branchRemoteName } // Stash any uncommitted tracked and untracked changes const stashed = yield git.stashPush(['--include-untracked']); - // Perform fetch and reset the working base + // Reset the working base // Commits made during the workflow will be removed if (workingBaseType == WorkingBaseType.Branch) { core.info(`Resetting working base branch '${workingBase}'`); - if (branchRemoteName == 'fork') { - // If pushing to a fork we must fetch with 'unshallow' to avoid the following error on git push - // ! [remote rejected] HEAD -> tests/push-branch-to-fork (shallow update not allowed) - yield git.fetch([`${workingBase}:${workingBase}`], baseRemote, ['--force'], true); - } - else { - // If the remote is 'origin' we can git reset - yield git.checkout(workingBase); - yield git.exec(['reset', '--hard', `${baseRemote}/${workingBase}`]); - } + yield git.checkout(workingBase); + yield git.exec(['reset', '--hard', `${baseRemote}/${workingBase}`]); } // If the working base is not the base, rebase the temp branch commits // This will also be true if the working base type is a commit diff --git a/src/create-or-update-branch.ts b/src/create-or-update-branch.ts index 000dc51..4d489dd 100644 --- a/src/create-or-update-branch.ts +++ b/src/create-or-update-branch.ts @@ -173,24 +173,12 @@ export async function createOrUpdateBranch( // Stash any uncommitted tracked and untracked changes const stashed = await git.stashPush(['--include-untracked']) - // Perform fetch and reset the working base + // Reset the working base // Commits made during the workflow will be removed if (workingBaseType == WorkingBaseType.Branch) { core.info(`Resetting working base branch '${workingBase}'`) - if (branchRemoteName == 'fork') { - // If pushing to a fork we must fetch with 'unshallow' to avoid the following error on git push - // ! [remote rejected] HEAD -> tests/push-branch-to-fork (shallow update not allowed) - await git.fetch( - [`${workingBase}:${workingBase}`], - baseRemote, - ['--force'], - true - ) - } else { - // If the remote is 'origin' we can git reset - await git.checkout(workingBase) - await git.exec(['reset', '--hard', `${baseRemote}/${workingBase}`]) - } + await git.checkout(workingBase) + await git.exec(['reset', '--hard', `${baseRemote}/${workingBase}`]) } // If the working base is not the base, rebase the temp branch commits