Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

PR review companion seems flaky? #4972

Closed
Tracked by #5179 ...
schalkneethling opened this issue Nov 21, 2021 · 10 comments
Closed
Tracked by #5179 ...

PR review companion seems flaky? #4972

schalkneethling opened this issue Nov 21, 2021 · 10 comments
Labels
idle p3 We don't have visibility when this will be addressed. pr-companion PR review companion for content PRs

Comments

@schalkneethling
Copy link

On this build the PR review companion keep failing with the following stack:

Run actions/github-script@v5
  with:
    script: var artifacts = await github.rest.actions.listWorkflowRunArtifacts({
     owner: context.repo.owner,
     repo: context.repo.repo,
     run_id: 1480759121,
  });
  var matchArtifacts = artifacts.data.artifacts.filter((artifact) => {
    return artifact.name == "build"
  });
  if (matchArtifacts.length === 0) {
    console.warn(
      'No artifacts to download probably just means nothing ' +
      'was built in the "PR test" workflow. That\'s OK. ' +
      'This is actually not a genuine CI error.'
    );
    throw new Error(
      'No matched build artifacts. ' +
      'Perhaps nothing built in the "PR test" workflow'
    );
  }
  var matchArtifact = matchArtifacts[0];
  var download = await github.rest.actions.downloadArtifact({
      owner: context.repo.owner,
      repo: context.repo.repo,
      artifact_id: matchArtifact.id,
      archive_format: 'zip',
  });
  var fs = require('fs');
  fs.writeFileSync('/home/runner/work/content/content/build.zip', Buffer.from(download.data));
  
    github-token: ***
    debug: false
    user-agent: actions/github-script
    result-encoding: json
(node:1562) [DEP0005] DeprecationWarning: Buffer() is deprecated due to security and usability issues. Please use the Buffer.alloc(), Buffer.allocUnsafe(), or Buffer.from() methods instead.
No artifacts to download probably just means nothing was built in the "PR test" workflow. That's OK. This is actually not a genuine CI error.
Error: No matched build artifacts. Perhaps nothing built in the "PR test" workflow
    at eval (eval at callAsyncFunction (/home/runner/work/_actions/actions/github-script/v5/dist/index.js:4942:56), <anonymous>:17:9)
    at processTicksAndRejections (internal/process/task_queues.js:93:5)
    at async main (/home/runner/work/_actions/actions/github-script/v5/dist/index.js:4997:20)
Error: Unhandled error: Error: No matched build artifacts. Perhaps nothing built in the "PR test" workflow

We recently changes github.actions.listWorkflowRunArtifacts to github.rest.actions.listWorkflowRunArtifacts because of the breaking change in the underlying GitHub action. The same change was made by @SphinxKnight on translated-content. It looks like the error is not related to the change, but based on the fact that there was no artefacts. However, there is this console.warn in the code:

console.warn(
      'No artifacts to download probably just means nothing ' +
      'was built in the "PR test" workflow. That\'s OK. ' +
      'This is actually not a genuine CI error.'
    );

There is also this run that did not error. We will need to have a look at what the actual cause is and resolve the issue.

@wbamberg
Copy link
Collaborator

FWIW I'm also not seeing built pages for mdn/content#10646 (the first time it worked, but after review the author made some changes, and those I am not seeing).

@schalkneethling schalkneethling self-assigned this Nov 24, 2021
@schalkneethling schalkneethling added the p1 We will address this soon and will provide capacity from our team for it in the next few releases. label Nov 24, 2021
@schalkneethling
Copy link
Author

I have not kept an eye on this one. @wbamberg, @SphinxKnight, or @ddbeck, is this still behaving inconsistently?

@SphinxKnight
Copy link
Member

SphinxKnight commented Feb 16, 2022

@ddbeck
Copy link
Contributor

ddbeck commented Feb 17, 2022

Yes, I think the PR review companion workflow is prone to failure. But because of the way the PR companion is wired up, it's not very obvious when it has failed, why it has failed, or what PR it failed for.

For reasons unknown to me, it's triggered by the completion of the PR Test workflow completion, instead of being a second (dependent) job in the same workflow as the PR Test job. This creates a few problems:

  • Companion reviews are invisible. Since it's triggered by another workflow, the companion doesn't show up in the "Checks" tab for any particular PR. Here's an example, where the companion ran, but you have no indication of such in the "Checks" tab; you only get a comment on the PR.
  • Failures are difficult to investigate. There's no way to see, in the list of Actions runs, which PR a companion run is associated with (the # is the workflow run count, not a PR number). Sometimes I have received emails about companion failures long enough after opening a PR that I have no idea which PR or commit caused it or why.
  • Failures are difficult to recover from. For example, if the PR companion gets stuck, you can't re-run it from the "Checks" tab. I think the only way to re-run the PR companion is to push a new commit, though I've never investigated this closely.

I think the first step would be to combine the PR Test and PR review companion workflows, with two dependent jobs. That will probably give us some better information on why the companion is misbehaving.

(There's also some other suspect stuff in those workflows, but I've been reluctant to mess with them since I'd have no way of knowing if or why they'd fail.)

@schalkneethling schalkneethling removed the p1 We will address this soon and will provide capacity from our team for it in the next few releases. label Mar 2, 2022
@github-actions github-actions bot added the idle label Apr 15, 2022
@schalkneethling schalkneethling removed their assignment Apr 18, 2022
@github-actions github-actions bot added the 🐌 idle Issues and PRs without recent activity. Flagged for maintainer follow-up. label May 28, 2022
@awxiaoxian2020
Copy link
Contributor

@github-actions github-actions bot removed the 🐌 idle Issues and PRs without recent activity. Flagged for maintainer follow-up. label Aug 21, 2022
@github-actions github-actions bot added the 🐌 idle Issues and PRs without recent activity. Flagged for maintainer follow-up. label Sep 27, 2022
@caugner caugner added 🐛 bug Something isn't working, or isn't working as expected p2 We want to address this but may have other higher priority items. pr-companion PR review companion for content PRs and removed 🚉 platform keeping the platform healthy labels Nov 15, 2022
@caugner
Copy link
Contributor

caugner commented Nov 15, 2022

I quickly looked into this and the "PR review companion" workflow seems to fail if the "PR Test" did not upload any artifact, especially ...

  1. if the "PR Test" workflow failed, or
  2. if the "PR Test" ran on a PR that didn't change any page.

Example for 1:

Example for 2:

  • The occurrence mentioned by @awxiaoxian2020, i.e. "PR review companion" run 2896760814 mentions run 2896757290.
  • That run succeeded BUT does not (seem to) have any artifact.
  • 💡 Probably the reason is that it didn't change any index.md, so it didn't build any page.

@caugner
Copy link
Contributor

caugner commented Nov 15, 2022

To fix case 1, we could run the "PR review companion" workflow conditionally only if the "PR Test" workflow run concluded with "success":

if: ${{ github.event.workflow_run.conclusion == 'success' }}
Source: https://docs.github.com/en/actions/using-workflows/events-that-trigger-workflows#running-a-workflow-based-on-the-conclusion-of-another-workflow

🤔 However, it should already do that, see: https://github.com/mdn/content/blame/d987faaf1b65fbc11323327d82ce13a004cb96d4/.github/workflows/pr-review-companion.yml#L18-L20

To fix case 2, we could modify the "PR Test" workflow to ...

  • conditionally run only if anything inside files/ was changed, and/or
  • always upload an artifact (and optionally suppress the warning).

@caugner caugner added p3 We don't have visibility when this will be addressed. and removed 🐛 bug Something isn't working, or isn't working as expected p2 We want to address this but may have other higher priority items. labels Nov 15, 2022
@caugner
Copy link
Contributor

caugner commented Nov 15, 2022

Decreased priority, because it's just annoying, not really a problem that the workflow fails.

@github-actions github-actions bot removed the 🐌 idle Issues and PRs without recent activity. Flagged for maintainer follow-up. label Nov 15, 2022
@github-actions github-actions bot added the idle label Dec 21, 2022
@bsmth
Copy link
Member

bsmth commented Feb 9, 2024

I think it's safe to close this for now as there's been multiple refactoring efforts completed on these workflows; a significant one being the following that's landed in content and translated content:

A few things that add stability:

And there are a number of other small but important fixes:

Related issues:

@github-actions github-actions bot removed the idle label Feb 9, 2024
@github-actions github-actions bot added the idle label Mar 10, 2024
@caugner
Copy link
Contributor

caugner commented Jun 24, 2024

Closing as suggested by Brian in #4972 (comment).

@caugner caugner closed this as completed Jun 24, 2024
@github-project-automation github-project-automation bot moved this from Backlog to Done in Yari Platform Engineering Jun 24, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
idle p3 We don't have visibility when this will be addressed. pr-companion PR review companion for content PRs
Projects
Development

No branches or pull requests

7 participants