fix: prune stale remote ref for self-hosted runners

This commit is contained in:
Peter Evans 2020-11-24 12:34:54 +09:00
parent ff0beed1b2
commit 9984f611a7
2 changed files with 12 additions and 0 deletions

6
dist/index.js vendored
View file

@ -315,6 +315,12 @@ function createPullRequest(inputs) {
if (branchRemoteName == 'origin' && base == inputs.branch) { if (branchRemoteName == 'origin' && base == inputs.branch) {
throw new Error(`The 'base' and 'branch' for a pull request must be different branches. Unable to continue.`); throw new Error(`The 'base' and 'branch' for a pull request must be different branches. Unable to continue.`);
} }
// For self-hosted runners the repository state persists between runs.
// This command prunes the stale remote ref when the pull request branch was
// deleted after being merged or closed. Without this the push using
// '--force-with-lease' fails due to "stale info."
// https://github.com/peter-evans/create-pull-request/issues/633
yield git.exec(['remote', 'prune', branchRemoteName]);
core.endGroup(); core.endGroup();
// Apply the branch suffix if set // Apply the branch suffix if set
if (inputs.branchSuffix) { if (inputs.branchSuffix) {

View file

@ -106,6 +106,12 @@ export async function createPullRequest(inputs: Inputs): Promise<void> {
`The 'base' and 'branch' for a pull request must be different branches. Unable to continue.` `The 'base' and 'branch' for a pull request must be different branches. Unable to continue.`
) )
} }
// For self-hosted runners the repository state persists between runs.
// This command prunes the stale remote ref when the pull request branch was
// deleted after being merged or closed. Without this the push using
// '--force-with-lease' fails due to "stale info."
// https://github.com/peter-evans/create-pull-request/issues/633
await git.exec(['remote', 'prune', branchRemoteName])
core.endGroup() core.endGroup()
// Apply the branch suffix if set // Apply the branch suffix if set