From d8e9734fa4d2039cf4f6e03a4006f8cfdc8439bd Mon Sep 17 00:00:00 2001 From: Mario Lubenka Date: Mon, 27 Nov 2023 14:28:37 +0100 Subject: [PATCH] fix: ignore empty stash Ignore "No stash entries found." when stashing is enabled but no files were actually stashed. Resolves: #55 --- src/perform-backmerge.test.ts | 43 +++++++++++++++++++++++++++++++++++ src/perform-backmerge.ts | 8 ++++++- 2 files changed, 50 insertions(+), 1 deletion(-) diff --git a/src/perform-backmerge.test.ts b/src/perform-backmerge.test.ts index 72ef0ab..9290e0d 100644 --- a/src/perform-backmerge.test.ts +++ b/src/perform-backmerge.test.ts @@ -247,6 +247,49 @@ describe("perform-backmerge", () => { verify(mockedGit.unstash()).calledAfter(pushAction); }); + it("stash and unstash with empty stash", async () => { + const mockedGit = mock(Git); + const mockedLogger = mock(NullLogger); + when(mockedGit.checkout(anyString())).thenResolve(); + when(mockedGit.configFetchAllRemotes()).thenResolve(); + when(mockedGit.getModifiedFiles()) + .thenReturn(new Promise(resolve => resolve([]))); + when(mockedGit.fetch()).thenResolve(); + when(mockedGit.commit(anyString())).thenResolve(); + when(mockedGit.rebase(anyString())).thenResolve(); + const makeError = require('execa/lib/error') + when(mockedGit.unstash()).thenThrow(makeError({ + stderr: 'No stash entries found.', + parsed: {options:{timeout: 0}} + })); + when(mockedGit.push(anyString(), anyString(), anything())).thenResolve(); + + const context = {logger: instance(mockedLogger), branch: {name: 'master'}, options: {repositoryUrl: 'my-repo'}} as Context; + + await performBackmerge( + instance(mockedGit), + { + backmergeBranches: ['develop'], + clearWorkspace: true, + restoreWorkspace: true + }, + context + ); + verify(mockedLogger.log('Performing back-merge into develop branch "develop".')).once(); + verify(mockedGit.checkout('master')).once(); + verify(mockedGit.configFetchAllRemotes()).once(); + verify(mockedGit.fetch(context.options!.repositoryUrl)).once(); + + const checkoutDevelopAction = mockedGit.checkout('develop'); + verify(mockedGit.stash()).calledBefore(checkoutDevelopAction); + verify(checkoutDevelopAction).once(); + verify(mockedGit.rebase('master')).once(); + + const pushAction = mockedGit.push('my-repo', 'develop', false) + verify(pushAction).once(); + verify(mockedGit.unstash()).calledAfter(pushAction); + }); + it("merge as backmerge strategy", async () => { const mockedGit = mock(Git); const mockedLogger = mock(NullLogger); diff --git a/src/perform-backmerge.ts b/src/perform-backmerge.ts index fd33ec2..e7681e8 100644 --- a/src/perform-backmerge.ts +++ b/src/perform-backmerge.ts @@ -130,7 +130,13 @@ export async function performBackmerge(git: Git, pluginConfig: Partial, if (options.restoreWorkspace) { context.logger.log('Restoring stashed files to Git workspace.'); - await git.unstash(); + try { + await git.unstash(); + } catch (error: any) { + if (error?.stderr !== 'No stash entries found.') { + throw error; + } + } } }