Skip to content

Commit

Permalink
fix: PR lookup for PRs merged to master
Browse files Browse the repository at this point in the history
  • Loading branch information
codebytere committed Dec 15, 2023
1 parent 3696bba commit 4c5fd05
Showing 1 changed file with 19 additions and 21 deletions.
40 changes: 19 additions & 21 deletions src/routes/pr.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
const Handlebars = require('handlebars');
const { Router } = require('express');
const semver = require('semver');
const MarkdownIt = require('markdown-it');
const createDOMPurify = require('dompurify');
const { JSDOM } = require('jsdom');

Expand All @@ -20,35 +19,36 @@ Handlebars.registerHelper('html', (content) => DOMPurify.sanitize(content));
async function getPRReleaseStatus(prNumber) {
const releases = [...(await getReleasesOrUpdate())].reverse();
const [prInfo, comments] = await Promise.all([getPR(prNumber), getPRComments(prNumber)]);

if (!prInfo) return null;

// PR is somehow targetting a repo that isn't in the electron org??
if (prInfo.base.user.login !== 'electron') {
return null;
}
const { base, merged, merged_at, merge_commit_sha } = prInfo;

// PR is somehow targetting a repo that isn't the primary repo??
if (prInfo.base.repo.name !== 'electron') {
// PR is somehow targeting a repo that isn't in the electron org
// or that isn't electron/electron.
if (base.user.login !== 'electron' || base.repo.name !== 'electron') {
return null;
}

if (prInfo.base.ref === prInfo.base.repo.default_branch) {
// PRs merged before we renamed the default branch to main from master
// will have a base.ref of master and a base.repo.default_branch of main.
const primaryPRBeforeRename =
base.ref === 'master' && new Date(base.merged_at) < new Date('June 1 2021');

if (primaryPRBeforeRename || base.ref === base.repo.default_branch) {
const backports = [];
let availableIn = null;

// We've been merged, let's find out if this is available in a nightly
if (prInfo.merged) {
if (merged) {
const allNightlies = releases.filter(
(r) => semver.parse(r.version).prerelease[0] === 'nightly',
);
for (const nightly of allNightlies) {
const dateParts = nightly.date.split('-').map((n) => parseInt(n, 10));
const releaseDate = new Date(dateParts[0], dateParts[1] - 1, dateParts[2] + 1);
if (releaseDate > new Date(prInfo.merged_at)) {
const comparison = await compareTagToCommit(
`v${nightly.version}`,
prInfo.merge_commit_sha,
);
if (releaseDate > new Date(merged_at)) {
const comparison = await compareTagToCommit(`v${nightly.version}`, merge_commit_sha);
if (comparison.status === 'behind') {
availableIn = nightly;
break;
Expand Down Expand Up @@ -132,7 +132,6 @@ async function getPRReleaseStatus(prNumber) {

// This is the primary PR, we can scan from here for backports
return {
highlightPR: prNumber,
primary: {
pr: prInfo,
availableIn,
Expand All @@ -146,19 +145,18 @@ async function getPRReleaseStatus(prNumber) {
};
}

// This is a backport PR, we should scan from here for the primary PR and then re-call getPRReleaseStatus with that primary PR
// This is a backport PR - scan from here for the primary
// PR and then re-call getPRReleaseStatus with that primary PR.

// c.f. https://github.com/electron/trop/blob/master/src/utils/branch-util.ts#L62
// https://github.com/electron/trop/blob/master/src/utils/branch-util.ts#L62
const backportPattern =
/(?:^|\n)(?:manual |manually )?backport (?:of )?(?:#(\d+)|https:\/\/github.com\/.*\/pull\/(\d+))/gim;
const match = backportPattern.exec(prInfo.body);

if (!match) return null;
const parentPRNumber = match[1] ? parseInt(match[1], 10) : parseInt(match[2], 10);

return {
...(await getPRReleaseStatus(parentPRNumber)),
highlightPR: prNumber,
};
return { ...(await getPRReleaseStatus(parentPRNumber)) };
}

router.get(
Expand Down

0 comments on commit 4c5fd05

Please sign in to comment.