pr command action fixes (#8591)

This commit is contained in:
Jake Potrebic 2022-11-23 19:14:41 -08:00 committed by GitHub
parent 8aff07afb0
commit b8919a7cc1
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 26 additions and 14 deletions

View file

@ -16,8 +16,8 @@ on:
jobs: jobs:
build: build:
# Only run on PRs if the source branch is on someone else's repo and the pr is not labeled with `build-pr-jar` # Run on all label events (won't be duplicated) or all push events or on PR syncs not from the same repo
if: github.event_name != 'pull_request' || github.repository != github.event.pull_request.head.repo.full_name if: (github.event_name == 'pull_request' && github.event.action == 'labeled') || github.event_name != 'pull_request' || github.repository != github.event.pull_request.head.repo.full_name
runs-on: ubuntu-latest runs-on: ubuntu-latest
strategy: strategy:
matrix: matrix:

View file

@ -24,8 +24,8 @@ jobs:
# Modified extensively by Machine_Maker # Modified extensively by Machine_Maker
script: | script: |
async function updatePR(owner, repo, issue_number, purpose, body) { async function updatePR(owner, repo, issue_number, purpose, body) {
const { data } = await github.rest.issues.get({owner, repo, issue_number}); const { data } = await github.rest.issues.get({ owner, repo, issue_number });
core.info(JSON.stringify(data, null, 2)); core.debug(JSON.stringify(data, null, 2));
const marker = `<!-- bot: ${purpose} -->`; const marker = `<!-- bot: ${purpose} -->`;
@ -37,23 +37,35 @@ jobs:
} }
core.info(`Updating the text body of PR #${issue_number} in ${owner}/${repo}`); core.info(`Updating the text body of PR #${issue_number} in ${owner}/${repo}`);
await github.rest.issues.update({owner, repo, issue_number, body: new_body}); await github.rest.issues.update({ owner, repo, issue_number, body: new_body });
} }
const {owner, repo} = context.repo; const { owner, repo } = context.repo;
const run_id = ${{github.event.workflow_run.id}}; const run_id = ${{ github.event.workflow_run.id }};
const repo_id = ${{ github.event.repository.id }}; const repo_id = ${{ github.event.repository.id }};
let pulls = [];
const event_type = "${{ github.event.workflow_run.event}}";
if (event_type === "push") { // if push, it's from the same repo which means `pull_requests` is populated
pulls = ${{ toJSON(github.event.workflow_run.pull_requests) }};
} else {
const pr_branch = "${{ github.event.workflow_run.head_branch }}";
const pr_sha = "${{ github.event.workflow_run.head_sha }}";
const pr_owner = "${{ github.event.workflow_run.head_repository.owner.login }}";
const { data } = await github.rest.pulls.list({ owner, repo, head: `${pr_owner}:${pr_branch}`, state: "open" });
core.debug(JSON.stringify(data, null, 2));
pulls = data.filter((pr) => pr.head.sha === pr_sha && pr.labels.find((l) => l.name === "build-pr-jar"));
}
const pull_requests = ${{ toJSON(github.event.workflow_run.pull_requests) }}; if (!pulls.length) {
if (!pull_requests.length) {
return core.notice("This workflow doesn't have any pull requests!"); return core.notice("This workflow doesn't have any pull requests!");
} else if (pulls.length > 1) {
core.info(JSON.stringify(pulls, null, 2));
return core.error("Found multiple matching PRs");
} }
const pull_request = pull_requests.find((pr) => pr.base.repo.id === repo_id); const pull_request = pulls[0];
if (!pull_request) {
return core.notice("This workflow doesn't match any pull request!");
}
const artifacts = await github.paginate(github.rest.actions.listWorkflowRunArtifacts, {owner, repo, run_id}); const artifacts = await github.paginate(github.rest.actions.listWorkflowRunArtifacts, { owner, repo, run_id });
if (!artifacts.length) { if (!artifacts.length) {
return core.info("Skipping comment due to no artifact found"); return core.info("Skipping comment due to no artifact found");
} }