From d48f432cf1d927ad0134ce1077f36e96f713092a Mon Sep 17 00:00:00 2001 From: Michael Heap Date: Tue, 17 Sep 2024 15:23:41 +0100 Subject: [PATCH] Add support for merge_queue events --- index.js | 9 ++++++++- index.test.js | 25 ++++++++++++++++++++++++- 2 files changed, 32 insertions(+), 2 deletions(-) diff --git a/index.js b/index.js index 1d47e69..112eaa1 100644 --- a/index.js +++ b/index.js @@ -14,9 +14,16 @@ async function action() { const skipRegexFlags = core.getInput("skipDescriptionRegexFlags"); const skipDescriptionRegex = !!skipRegexPattern ? new RegExp(skipRegexPattern, skipRegexFlags) : false; - const issueNumber = + let issueNumber = core.getInput("issueNumber") || github.context.issue?.number; + if (!issueNumber && github.context.eventName == "merge_queue") { + // Parse out of the ref for merge queue + // e.g. refs/heads/gh-readonly-queue/main/pr-17-a3c310584587d4b97c2df0cb46fe050cc46a15d6 + const lastPart = github.context.ref.split("/").pop(); + issueNumber = lastPart.match(/pr-(\d+)-/)[1]; + } + core.debug(`issue number: ${issueNumber}`); if (!issueNumber) { diff --git a/index.test.js b/index.test.js index 89e6927..1b178b3 100644 --- a/index.test.js +++ b/index.test.js @@ -24,6 +24,24 @@ describe("Require Checklist", () => { }); }); + it.only("parses the issue number out of the ref for merge_queue runs", async () => { + delete process.env.INPUT_ISSUENUMBER; + process.env.INPUT_REQUIRECHECKLIST = "false"; + + const runTools = mockEvent("merge_queue", {}, { + ref: "refs/heads/gh-readonly-queue/main/pr-17-a3c310584587d4b97c2df0cb46fe050cc46a15d6" + }); + + mockIssueBody("No checklist in the body"); + mockIssueComments(["Or in the comments"]); + + console.log = jest.fn(); + await action(runTools); + expect(console.log).toBeCalledWith( + "There are no incomplete task list items" + ); + }); + it("handles issues with no checklist, requireChecklist disabled", async () => { process.env.INPUT_REQUIRECHECKLIST = "false"; @@ -332,8 +350,13 @@ function mockIssueComments(comments, issueNumber = 17) { ); } -function mockEvent(name, mockPayload) { +function mockEvent(name, mockPayload, additionalContext = {}) { github.context.payload = mockPayload; + github.context.eventName = name; + + for (const key in additionalContext) { + github.context[key] = additionalContext[key]; + } process.env.GITHUB_EVENT_NAME = name; process.env.GITHUB_EVENT_PATH = "/github/workspace/event.json";