mirror of https://github.com/mpv-player/mpv
workflows/comment: refactor comment workflow to not use github-script
It is not actively maintained, third-party, javascript wrapper for GitHub API. The v7 version has issues and most importantly, we don't need a JavaScript interface to create a comment. Use the first-party CLI tool and jq. Sort artifacts by name while at it.
This commit is contained in:
parent
d3800a67fc
commit
2697a8c362
|
@ -2,64 +2,45 @@ name: comment
|
||||||
|
|
||||||
on:
|
on:
|
||||||
workflow_run:
|
workflow_run:
|
||||||
workflows: ["build"]
|
workflows: [build]
|
||||||
types: [completed]
|
types: [completed]
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
pr_comment:
|
pr_comment:
|
||||||
if: github.event.workflow_run.event == 'pull_request' && github.event.workflow_run.conclusion == 'success'
|
if: github.event.workflow_run.event == 'pull_request' &&
|
||||||
|
github.event.workflow_run.conclusion == 'success'
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/github-script@v6
|
- env:
|
||||||
with:
|
GH_REPO: ${{ github.repository }}
|
||||||
script: |
|
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
const { owner, repo } = context.repo;
|
run: |
|
||||||
const run_id = ${{ github.event.workflow_run.id }};
|
pr=$(gh pr list --state open --json headRefOid,number \
|
||||||
const pull_head_sha = '${{github.event.workflow_run.head_sha}}';
|
--jq '.[] | select(.headRefOid == "${{ github.event.workflow_run.head_sha }}") | .number')
|
||||||
|
if [ -z "$pr" ]; then
|
||||||
|
echo "No matching pull request found"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
const issue_number = await(async () => {
|
artifacts=$(gh api repos/{owner}/{repo}/actions/runs/${{ github.event.workflow_run.id }}/artifacts --jq '.artifacts')
|
||||||
const pulls = await github.rest.pulls.list({ owner, repo });
|
if [ "$(echo "$artifacts" | jq 'length')" -eq 0 ]; then
|
||||||
for await (const { data } of github.paginate.iterator(pulls)) {
|
echo "No artifacts found"
|
||||||
for (const pull of data) {
|
exit 0
|
||||||
if (pull.head.sha === pull_head_sha) {
|
fi
|
||||||
return pull.number;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})();
|
|
||||||
if (issue_number) {
|
|
||||||
core.info(`Using pull request ${issue_number}`);
|
|
||||||
} else {
|
|
||||||
return core.error(`No matching pull request found`);
|
|
||||||
}
|
|
||||||
|
|
||||||
const { data: { artifacts } } = await github.rest.actions.listWorkflowRunArtifacts({ owner, repo, run_id });
|
body=$(echo "$artifacts" | jq -r '
|
||||||
if (!artifacts.length) {
|
def link: "https://nightly.link/${{ github.repository_owner }}/${{ github.repository }}/actions/artifacts/\(.id).zip";
|
||||||
return core.error(`No artifacts found`);
|
def entry: "* [\(.name)](link)";
|
||||||
}
|
"Download the artifacts for this pull request:\n\n<details><summary>Windows</summary>\n" +
|
||||||
|
(sort_by(.name) | map(select(.name | test("w64|msvc")) | entry) | join("\n")) +
|
||||||
|
"\n</details>\n\n<details><summary>macOS</summary>\n" +
|
||||||
|
(sort_by(.name) | map(select(.name | test("macos")) | entry) | join("\n")) +
|
||||||
|
"\n</details>"
|
||||||
|
')
|
||||||
|
|
||||||
let body = `Download the artifacts for this pull request:\n\n<details><summary>Windows</summary>\n`;
|
comment_id=$(gh issue view $pr --json comments \
|
||||||
for (const art of artifacts) {
|
--jq '.comments[] | select(.author.login == "github-actions") | .id')
|
||||||
const art_link = `https://nightly.link/${owner}/${repo}/actions/artifacts/${art.id}.zip`;
|
if [ -n "$comment_id" ]; then
|
||||||
if (art.name.includes('w64') || art.name.includes('msvc')) {
|
edit=--edit-last
|
||||||
body += `\n* [${art.name}](${art_link})`;
|
fi
|
||||||
}
|
gh pr comment $pr --body "$body" $edit
|
||||||
}
|
|
||||||
body += `\n</details>\n\n<details><summary>macOS</summary>\n`;
|
|
||||||
for (const art of artifacts) {
|
|
||||||
const art_link = `https://nightly.link/${owner}/${repo}/actions/artifacts/${art.id}.zip`;
|
|
||||||
if (art.name.includes('macos')) {
|
|
||||||
body += `\n* [${art.name}](${art_link})`;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
body += `\n</details>`;
|
|
||||||
|
|
||||||
const { data: comments } = await github.rest.issues.listComments({ repo, owner, issue_number });
|
|
||||||
const existing_comment = comments.find((c) => c.user.login === 'github-actions[bot]');
|
|
||||||
if (existing_comment) {
|
|
||||||
core.info(`Updating comment ${existing_comment.id}`);
|
|
||||||
await github.rest.issues.updateComment({ repo, owner, comment_id: existing_comment.id, body });
|
|
||||||
} else {
|
|
||||||
core.info(`Creating a comment`);
|
|
||||||
await github.rest.issues.createComment({ repo, owner, issue_number, body });
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in New Issue