nightly_pr_comment.yml 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. name: Comment PR artifacts links
  2. on:
  3. workflow_run:
  4. workflows: ['Build job']
  5. types: [completed]
  6. jobs:
  7. pr_comment:
  8. if: github.event.workflow_run.event == 'pull_request' && github.event.workflow_run.conclusion == 'success'
  9. runs-on: ubuntu-latest
  10. timeout-minutes: ${{ fromJSON(vars.JOB_TIMEOUT) }}
  11. steps:
  12. - uses: actions/github-script@v6
  13. with:
  14. script: |
  15. const {owner, repo} = context.repo;
  16. const run_id = ${{github.event.workflow_run.id}};
  17. const pull_head_sha = '${{github.event.workflow_run.head_sha}}';
  18. const issue_number = await (async () => {
  19. const pulls = await github.rest.pulls.list({owner, repo});
  20. for await (const {data} of github.paginate.iterator(pulls)) {
  21. for (const pull of data) {
  22. if (pull.head.sha === pull_head_sha) {
  23. return pull.number;
  24. }
  25. }
  26. }
  27. })();
  28. if (issue_number) {
  29. core.info(`Using pull request ${issue_number}`);
  30. } else {
  31. return core.error(`No matching pull request found`);
  32. }
  33. const {data: {artifacts}} = await github.rest.actions.listWorkflowRunArtifacts({owner, repo, run_id});
  34. if (!artifacts.length) {
  35. return core.error(`No artifacts found`);
  36. }
  37. let body = `Download the artifacts for this pull request:\n`;
  38. let hidden_avalonia_artifacts = `\n\n <details><summary>Experimental GUI (Avalonia)</summary>\n`;
  39. let hidden_headless_artifacts = `\n\n <details><summary>GUI-less (SDL2)</summary>\n`;
  40. let hidden_debug_artifacts = `\n\n <details><summary>Only for Developers</summary>\n`;
  41. for (const art of artifacts) {
  42. if(art.name.includes('Debug')) {
  43. hidden_debug_artifacts += `\n* [${art.name}](https://nightly.link/${owner}/${repo}/actions/artifacts/${art.id}.zip)`;
  44. } else if(art.name.includes('ava-ryujinx')) {
  45. hidden_avalonia_artifacts += `\n* [${art.name}](https://nightly.link/${owner}/${repo}/actions/artifacts/${art.id}.zip)`;
  46. } else if(art.name.includes('sdl2-ryujinx-headless')) {
  47. hidden_headless_artifacts += `\n* [${art.name}](https://nightly.link/${owner}/${repo}/actions/artifacts/${art.id}.zip)`;
  48. } else {
  49. body += `\n* [${art.name}](https://nightly.link/${owner}/${repo}/actions/artifacts/${art.id}.zip)`;
  50. }
  51. }
  52. hidden_avalonia_artifacts += `\n</details>`;
  53. hidden_headless_artifacts += `\n</details>`;
  54. hidden_debug_artifacts += `\n</details>`;
  55. body += hidden_avalonia_artifacts;
  56. body += hidden_headless_artifacts;
  57. body += hidden_debug_artifacts;
  58. const {data: comments} = await github.rest.issues.listComments({repo, owner, issue_number});
  59. const existing_comment = comments.find((c) => c.user.login === 'github-actions[bot]');
  60. if (existing_comment) {
  61. core.info(`Updating comment ${existing_comment.id}`);
  62. await github.rest.issues.updateComment({repo, owner, comment_id: existing_comment.id, body});
  63. } else {
  64. core.info(`Creating a comment`);
  65. await github.rest.issues.createComment({repo, owner, issue_number, body});
  66. }