fix: drop unnecessary fetch with unshallow on push-to-fork (#2849)
This commit is contained in:
parent
6ce4eca6b6
commit
c55203cfde
14
dist/index.js
vendored
14
dist/index.js
vendored
|
@ -164,20 +164,12 @@ function createOrUpdateBranch(git, commitMessage, base, branch, branchRemoteName
|
||||||
}
|
}
|
||||||
// Stash any uncommitted tracked and untracked changes
|
// Stash any uncommitted tracked and untracked changes
|
||||||
const stashed = yield git.stashPush(['--include-untracked']);
|
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
|
// Commits made during the workflow will be removed
|
||||||
if (workingBaseType == WorkingBaseType.Branch) {
|
if (workingBaseType == WorkingBaseType.Branch) {
|
||||||
core.info(`Resetting working base branch '${workingBase}'`);
|
core.info(`Resetting working base branch '${workingBase}'`);
|
||||||
if (branchRemoteName == 'fork') {
|
yield git.checkout(workingBase);
|
||||||
// If pushing to a fork we must fetch with 'unshallow' to avoid the following error on git push
|
yield git.exec(['reset', '--hard', `${baseRemote}/${workingBase}`]);
|
||||||
// ! [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}`]);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
// If the working base is not the base, rebase the temp branch commits
|
// 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
|
// This will also be true if the working base type is a commit
|
||||||
|
|
|
@ -173,24 +173,12 @@ export async function createOrUpdateBranch(
|
||||||
// Stash any uncommitted tracked and untracked changes
|
// Stash any uncommitted tracked and untracked changes
|
||||||
const stashed = await git.stashPush(['--include-untracked'])
|
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
|
// Commits made during the workflow will be removed
|
||||||
if (workingBaseType == WorkingBaseType.Branch) {
|
if (workingBaseType == WorkingBaseType.Branch) {
|
||||||
core.info(`Resetting working base branch '${workingBase}'`)
|
core.info(`Resetting working base branch '${workingBase}'`)
|
||||||
if (branchRemoteName == 'fork') {
|
await git.checkout(workingBase)
|
||||||
// If pushing to a fork we must fetch with 'unshallow' to avoid the following error on git push
|
await git.exec(['reset', '--hard', `${baseRemote}/${workingBase}`])
|
||||||
// ! [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}`])
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// If the working base is not the base, rebase the temp branch commits
|
// If the working base is not the base, rebase the temp branch commits
|
||||||
|
|
Loading…
Reference in a new issue