From 632bbf948d6a24127c937b0b90b206b0eb18516f Mon Sep 17 00:00:00 2001 From: Shelley Vohr Date: Sun, 16 Jun 2019 20:56:43 -0700 Subject: [PATCH] build: get current release branch from commit (#18810) When we blast off again, we check out a commit so the current branch ends up being incorrect and is HEAD rather than X-Y-Z. This therefore no longer just runs git rev-parse --abbrev-ref HEAD; it instead checks to ensure that the result of that call matches the release branch pattern. If it doesn't, it fetches the containing branch for the commit. Since we only ever blast off from bump commits, we can safely assume that only one release branch will ever contain the bump commit and therefore be the one we want to use when tagging the release on npm. --- script/lib/utils.js | 25 ++++++++++++++++--------- 1 file changed, 16 insertions(+), 9 deletions(-) diff --git a/script/lib/utils.js b/script/lib/utils.js index 8343e2613fcb..bb098351ece9 100644 --- a/script/lib/utils.js +++ b/script/lib/utils.js @@ -25,20 +25,27 @@ function getAbsoluteElectronExec () { return path.resolve(__dirname, '../../..', getElectronExec()) } -async function getCurrentBranch (gitDir) { - const gitArgs = ['rev-parse', '--abbrev-ref', 'HEAD'] - const branchDetails = await GitProcess.exec(gitArgs, gitDir) - if (branchDetails.exitCode === 0) { - const currentBranch = branchDetails.stdout.trim() - console.log(`${pass} current git branch is: ${currentBranch}`) - return currentBranch +async function handleGitCall (args, gitDir) { + const details = await GitProcess.exec(args, gitDir) + if (details.exitCode === 0) { + return details.stdout.trim() } else { - const error = GitProcess.parseError(branchDetails.stderr) - console.log(`${fail} couldn't get details current branch: `, error) + const error = GitProcess.parseError(details.stderr) + console.log(`${fail} couldn't parse git process call: `, error) process.exit(1) } } +async function getCurrentBranch (gitDir) { + let branch = await handleGitCall(['rev-parse', '--abbrev-ref', 'HEAD'], gitDir) + if (!branch.match(/[0-9]+-[0-9]+-x/)) { + const lastCommit = await handleGitCall(['rev-parse', 'HEAD'], gitDir) + const branches = (await handleGitCall(['branch', '--contains', lastCommit], gitDir)).split('\n') + branch = branches.filter(b => b.match(/[0-9]+-[0-9]+-x/))[0].trim() + } + return branch +} + module.exports = { getCurrentBranch, getElectronExec,