Merge pull request #503 from peter-evans/not-updated-fix

Fix pr create/update for already up to date branches
This commit is contained in:
Peter Evans 2020-08-19 17:37:01 +09:00 committed by GitHub
commit 5893420513
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 4309 additions and 929 deletions

View file

@ -343,7 +343,7 @@ describe('create-or-update-branch tests', () => {
REMOTE_NAME,
false
)
expect(_result.action).toEqual('none')
expect(_result.action).toEqual('not-updated')
expect(await getFileContent(TRACKED_FILE)).toEqual(changes.tracked)
expect(await getFileContent(UNTRACKED_FILE)).toEqual(changes.untracked)
expect(
@ -993,7 +993,7 @@ describe('create-or-update-branch tests', () => {
REMOTE_NAME,
false
)
expect(_result.action).toEqual('none')
expect(_result.action).toEqual('not-updated')
expect(await getFileContent(TRACKED_FILE)).toEqual(changes.tracked)
expect(await getFileContent(UNTRACKED_FILE)).toEqual(changes.untracked)
expect(

5209
dist/index.js vendored

File diff suppressed because it is too large Load diff

View file

@ -178,6 +178,7 @@ export async function createOrUpdateBranch(
result.action = 'updated'
core.info(`Updated branch '${branch}'`)
} else {
result.action = 'not-updated'
core.info(
`Branch '${branch}' is even with its remote and will not be updated`
)

View file

@ -185,19 +185,21 @@ export async function createPullRequest(inputs: Inputs): Promise<void> {
`HEAD:refs/heads/${inputs.branch}`
])
core.endGroup()
}
// Set the base. It would have been '' if not specified as an input
inputs.base = result.base
// Set the base. It would have been '' if not specified as an input
inputs.base = result.base
if (result.hasDiffWithBase) {
// Create or update the pull request
await githubHelper.createOrUpdatePullRequest(
inputs,
baseRemote.repository,
branchRepository
)
} else {
// If there is no longer a diff with the base delete the branch
if (result.hasDiffWithBase) {
// Create or update the pull request
await githubHelper.createOrUpdatePullRequest(
inputs,
baseRemote.repository,
branchRepository
)
} else {
// If there is no longer a diff with the base delete the branch
if (['updated', 'not-updated'].includes(result.action)) {
core.info(
`Branch '${inputs.branch}' no longer differs from base branch '${inputs.base}'`
)