2023-01-11 11:33:53 +00:00
|
|
|
name: Issue Analyzer
|
|
|
|
|
|
|
|
permissions: read-all
|
|
|
|
|
|
|
|
on:
|
|
|
|
issues:
|
|
|
|
types: [opened, reopened, edited]
|
|
|
|
|
|
|
|
concurrency:
|
2023-07-04 12:17:25 +00:00
|
|
|
group: issue-${{ format('issue-{0}', github.event.issue.number) }}
|
2023-01-11 11:33:53 +00:00
|
|
|
cancel-in-progress: true
|
|
|
|
|
|
|
|
jobs:
|
|
|
|
analyze-issue:
|
|
|
|
name: Analyze Issues
|
|
|
|
runs-on: ubuntu-latest
|
2023-07-12 07:14:30 +00:00
|
|
|
if: ${{ contains(github.event.issue.labels.*.name, 'bug') && !contains(github.event.issue.labels.*.name, 'disable-analyzer') && !contains(github.event.issue.labels.*.name, 'confirmed') && !contains(github.event.issue.labels.*.name, '@puppeteer/browsers') && github.event.issue.number > 9481 }}
|
2023-01-11 11:33:53 +00:00
|
|
|
env:
|
|
|
|
ISSUE_BODY: ${{ toJson(github.event.issue.body) }}
|
|
|
|
outputs:
|
|
|
|
runsOn: ${{ steps.issue-analysis.outputs.runsOn }}
|
|
|
|
nodeVersion: ${{ steps.issue-analysis.outputs.nodeVersion }}
|
|
|
|
packageManager: ${{ steps.issue-analysis.outputs.packageManager }}
|
|
|
|
errorMessage: ${{ steps.issue-analysis.outputs.errorMessage }}
|
|
|
|
permissions:
|
|
|
|
issues: write
|
|
|
|
steps:
|
|
|
|
- name: Remove labels
|
2023-06-02 09:52:21 +00:00
|
|
|
uses: actions/github-script@d7906e4ad0b1822421a7e6a35d5ca353c962f410 # v6.4.1
|
2023-01-11 11:33:53 +00:00
|
|
|
with:
|
|
|
|
script: |
|
|
|
|
if (${{ contains(github.event.issue.labels.*.name, 'not-reproducible') }}) {
|
|
|
|
github.rest.issues.removeLabel({
|
|
|
|
issue_number: context.issue.number,
|
|
|
|
owner: context.repo.owner,
|
|
|
|
repo: context.repo.repo,
|
|
|
|
name: ["not-reproducible"]
|
|
|
|
})
|
|
|
|
}
|
|
|
|
if (${{ contains(github.event.issue.labels.*.name, 'needs-feedback') }}) {
|
|
|
|
github.rest.issues.removeLabel({
|
|
|
|
issue_number: context.issue.number,
|
|
|
|
owner: context.repo.owner,
|
|
|
|
repo: context.repo.repo,
|
|
|
|
name: ["needs-feedback"]
|
|
|
|
})
|
|
|
|
}
|
|
|
|
if (${{ contains(github.event.issue.labels.*.name, 'invalid') }}) {
|
|
|
|
github.rest.issues.removeLabel({
|
|
|
|
issue_number: context.issue.number,
|
|
|
|
owner: context.repo.owner,
|
|
|
|
repo: context.repo.repo,
|
|
|
|
name: ["invalid"]
|
|
|
|
})
|
|
|
|
}
|
|
|
|
- name: Check out repository
|
2023-10-19 09:46:32 +00:00
|
|
|
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
|
2023-01-11 11:33:53 +00:00
|
|
|
- name: Set up Node.js
|
2023-08-21 11:03:43 +00:00
|
|
|
uses: actions/setup-node@5e21ff4d9bc1a8cf6de233a3057d20ec6b3fb69d # v3.8.1
|
2023-01-11 11:33:53 +00:00
|
|
|
with:
|
2023-03-15 12:59:42 +00:00
|
|
|
node-version: lts/*
|
2023-01-11 11:33:53 +00:00
|
|
|
- name: Install dependencies
|
2023-06-14 07:59:01 +00:00
|
|
|
run: npm ci
|
2023-01-11 11:33:53 +00:00
|
|
|
- name: Analyze issue
|
|
|
|
id: issue-analysis
|
2023-01-11 11:41:14 +00:00
|
|
|
run: echo $ISSUE_BODY | ./tools/analyze_issue.mjs >> $GITHUB_OUTPUT
|
2023-09-13 08:23:15 +00:00
|
|
|
- uses: actions/upload-artifact@a8a3f3ad30e3422c9c7b888a15615d19a852ae32 # v3.1.3
|
2023-01-11 11:33:53 +00:00
|
|
|
with:
|
|
|
|
name: issue-files
|
|
|
|
path: out/
|
|
|
|
|
|
|
|
verify-issue:
|
|
|
|
name: Verify Issue
|
|
|
|
needs: analyze-issue
|
|
|
|
runs-on: ${{ needs.analyze-issue.outputs.runsOn }}
|
|
|
|
permissions:
|
|
|
|
issues: write
|
|
|
|
env:
|
|
|
|
PACKAGE_MANAGER: ${{ needs.analyze-issue.outputs.packageManager }}
|
|
|
|
NODE_VERSION: ${{ needs.analyze-issue.outputs.nodeVersion }}
|
|
|
|
steps:
|
2023-06-02 09:52:21 +00:00
|
|
|
- uses: actions/download-artifact@9bc31d5ccc31df68ecc42ccf4149144866c47d8a # v3.0.2
|
2023-01-11 11:33:53 +00:00
|
|
|
with:
|
|
|
|
name: issue-files
|
|
|
|
path: '.'
|
|
|
|
- name: Set up Node.js
|
2023-08-21 11:03:43 +00:00
|
|
|
uses: actions/setup-node@5e21ff4d9bc1a8cf6de233a3057d20ec6b3fb69d # v3.8.1
|
2023-01-11 11:33:53 +00:00
|
|
|
with:
|
|
|
|
node-version: ${{ env.NODE_VERSION }}
|
|
|
|
- name: Enable corepack
|
|
|
|
run: corepack enable
|
|
|
|
- name: Install dependencies
|
|
|
|
run: ${{ env.PACKAGE_MANAGER }} install
|
2023-03-06 10:39:53 +00:00
|
|
|
env:
|
|
|
|
YARN_ENABLE_IMMUTABLE_INSTALLS: false
|
2023-03-15 14:34:25 +00:00
|
|
|
- name: Install dependencies Firefox
|
2023-09-22 11:48:31 +00:00
|
|
|
run: node ./node_modules/puppeteer/install.mjs
|
2023-03-15 14:34:25 +00:00
|
|
|
env:
|
|
|
|
PUPPETEER_PRODUCT: firefox
|
2023-01-11 11:33:53 +00:00
|
|
|
- name: Verify issue
|
|
|
|
timeout-minutes: 10
|
|
|
|
run: ${{ env.PACKAGE_MANAGER }} run verify
|
2023-05-19 13:10:43 +00:00
|
|
|
env:
|
|
|
|
DEBUG: 'puppeteer:*'
|
2023-09-13 08:23:15 +00:00
|
|
|
- uses: actions/upload-artifact@a8a3f3ad30e3422c9c7b888a15615d19a852ae32 # v3.1.3
|
2023-01-11 11:33:53 +00:00
|
|
|
if: success() || failure()
|
|
|
|
with:
|
|
|
|
name: runtime-output
|
|
|
|
path: |
|
|
|
|
*.log
|
|
|
|
**/*.pdf
|
|
|
|
if-no-files-found: error
|
|
|
|
|
|
|
|
label-verified-issue:
|
|
|
|
needs: [verify-issue]
|
|
|
|
if: success()
|
|
|
|
name: Label verified issue
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
permissions:
|
|
|
|
issues: write
|
|
|
|
steps:
|
|
|
|
- name: Add labels
|
2023-06-02 09:52:21 +00:00
|
|
|
uses: actions/github-script@d7906e4ad0b1822421a7e6a35d5ca353c962f410 # v6.4.1
|
2023-01-11 11:33:53 +00:00
|
|
|
with:
|
|
|
|
script: |
|
|
|
|
github.rest.issues.addLabels({
|
|
|
|
issue_number: context.issue.number,
|
|
|
|
owner: context.repo.owner,
|
|
|
|
repo: context.repo.repo,
|
|
|
|
labels: ["confirmed"]
|
|
|
|
})
|
2023-02-09 14:27:23 +00:00
|
|
|
- name: Find Comment Id
|
2023-06-02 09:52:21 +00:00
|
|
|
uses: peter-evans/find-comment@a54c31d7fa095754bfef525c0c8e5e5674c4b4b1 # v2.4.0
|
2023-02-09 14:27:23 +00:00
|
|
|
id: find-comment-id
|
|
|
|
with:
|
|
|
|
issue-number: ${{ github.event.issue.number }}
|
|
|
|
comment-author: 'github-actions[bot]'
|
|
|
|
- name: Upsert comment
|
2023-10-20 09:02:51 +00:00
|
|
|
uses: peter-evans/create-or-update-comment@23ff15729ef2fc348714a3bb66d2f655ca9066f2 # v3.1.0
|
2023-02-09 14:27:23 +00:00
|
|
|
with:
|
|
|
|
comment-id: ${{ steps.find-comment-id.outputs.comment-id }}
|
|
|
|
issue-number: ${{ github.event.issue.number }}
|
|
|
|
edit-mode: replace
|
|
|
|
body: |
|
|
|
|
The issue has been labeled as **confirmed** by the automatic analyser.
|
|
|
|
Someone from the Puppeteer team will take a look soon!
|
2023-02-17 18:19:06 +00:00
|
|
|
|
2023-02-17 14:18:52 +00:00
|
|
|
---
|
|
|
|
[Analyzer run](${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }})
|
2023-01-11 11:33:53 +00:00
|
|
|
|
|
|
|
label-invalid-issue:
|
|
|
|
needs: [analyze-issue]
|
|
|
|
if: failure() && needs.analyze-issue.outputs.errorMessage != ''
|
|
|
|
name: Label invalid issue
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
permissions:
|
|
|
|
issues: write
|
|
|
|
steps:
|
|
|
|
- name: Add labels
|
2023-06-02 09:52:21 +00:00
|
|
|
uses: actions/github-script@d7906e4ad0b1822421a7e6a35d5ca353c962f410 # v6.4.1
|
2023-01-11 11:33:53 +00:00
|
|
|
with:
|
|
|
|
script: |
|
|
|
|
github.rest.issues.addLabels({
|
|
|
|
issue_number: context.issue.number,
|
|
|
|
owner: context.repo.owner,
|
|
|
|
repo: context.repo.repo,
|
|
|
|
labels: ["invalid"]
|
|
|
|
})
|
2023-01-19 13:06:37 +00:00
|
|
|
- name: Find Comment Id
|
2023-06-02 09:52:21 +00:00
|
|
|
uses: peter-evans/find-comment@a54c31d7fa095754bfef525c0c8e5e5674c4b4b1 # v2.4.0
|
2023-01-19 13:06:37 +00:00
|
|
|
id: find-comment-id
|
|
|
|
with:
|
|
|
|
issue-number: ${{ github.event.issue.number }}
|
|
|
|
comment-author: 'github-actions[bot]'
|
|
|
|
- name: Upsert comment
|
2023-10-20 09:02:51 +00:00
|
|
|
uses: peter-evans/create-or-update-comment@23ff15729ef2fc348714a3bb66d2f655ca9066f2 # v3.1.0
|
2023-01-11 11:33:53 +00:00
|
|
|
with:
|
2023-01-19 13:06:37 +00:00
|
|
|
comment-id: ${{ steps.find-comment-id.outputs.comment-id }}
|
2023-01-11 11:33:53 +00:00
|
|
|
issue-number: ${{ github.event.issue.number }}
|
2023-01-24 18:11:33 +00:00
|
|
|
edit-mode: replace
|
2023-02-17 14:18:52 +00:00
|
|
|
body: |
|
|
|
|
${{ needs.analyze-issue.outputs.errorMessage }}
|
2023-02-17 18:19:06 +00:00
|
|
|
|
2023-02-17 14:18:52 +00:00
|
|
|
---
|
|
|
|
[Analyzer run](${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }})
|
2023-01-11 11:33:53 +00:00
|
|
|
|
|
|
|
label-unverifiable-issue:
|
|
|
|
needs: [analyze-issue, verify-issue]
|
|
|
|
if: failure() && needs.analyze-issue.outputs.errorMessage == ''
|
|
|
|
name: Label unverifiable issue
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
permissions:
|
|
|
|
issues: write
|
|
|
|
steps:
|
|
|
|
- name: Add labels
|
2023-06-02 09:52:21 +00:00
|
|
|
uses: actions/github-script@d7906e4ad0b1822421a7e6a35d5ca353c962f410 # v6.4.1
|
2023-01-11 11:33:53 +00:00
|
|
|
with:
|
|
|
|
script: |
|
|
|
|
github.rest.issues.addLabels({
|
|
|
|
issue_number: context.issue.number,
|
|
|
|
owner: context.repo.owner,
|
|
|
|
repo: context.repo.repo,
|
|
|
|
labels: ["not-reproducible", "needs-feedback"]
|
|
|
|
})
|
2023-01-19 13:06:37 +00:00
|
|
|
- name: Find Comment Id
|
2023-06-02 09:52:21 +00:00
|
|
|
uses: peter-evans/find-comment@a54c31d7fa095754bfef525c0c8e5e5674c4b4b1 # v2.4.0
|
2023-01-19 13:06:37 +00:00
|
|
|
id: find-comment-id
|
|
|
|
with:
|
|
|
|
issue-number: ${{ github.event.issue.number }}
|
|
|
|
comment-author: 'github-actions[bot]'
|
|
|
|
- name: Upsert comment
|
2023-10-20 09:02:51 +00:00
|
|
|
uses: peter-evans/create-or-update-comment@23ff15729ef2fc348714a3bb66d2f655ca9066f2 # v3.1.0
|
2023-01-11 11:33:53 +00:00
|
|
|
with:
|
2023-01-19 13:06:37 +00:00
|
|
|
comment-id: ${{ steps.find-comment-id.outputs.comment-id }}
|
2023-01-11 11:33:53 +00:00
|
|
|
issue-number: ${{ github.event.issue.number }}
|
2023-01-24 18:11:33 +00:00
|
|
|
edit-mode: replace
|
2023-01-11 11:33:53 +00:00
|
|
|
body: |
|
|
|
|
This issue was not reproducible. Please check that your example runs locally and the following:
|
|
|
|
|
|
|
|
- Ensure the script does not rely on dependencies outside of `puppeteer` and `puppeteer-core`.
|
|
|
|
- Ensure the error string is just the error message.
|
|
|
|
- Bad:
|
|
|
|
|
|
|
|
```ts
|
|
|
|
Error: something went wrong
|
|
|
|
at Object.<anonymous> (/Users/username/repository/script.js:2:1)
|
|
|
|
at Module._compile (node:internal/modules/cjs/loader:1159:14)
|
|
|
|
at Module._extensions..js (node:internal/modules/cjs/loader:1213:10)
|
|
|
|
at Module.load (node:internal/modules/cjs/loader:1037:32)
|
|
|
|
at Module._load (node:internal/modules/cjs/loader:878:12)
|
|
|
|
at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:81:12)
|
|
|
|
at node:internal/main/run_main_module:23:47
|
|
|
|
```
|
|
|
|
|
|
|
|
- Good: `Error: something went wrong`.
|
|
|
|
- Ensure your configuration file (if applicable) is valid.
|
|
|
|
- If the issue is flaky (does not reproduce all the time), make sure 'Flaky' is checked.
|
|
|
|
- If the issue is not expected to error, make sure to write 'no error'.
|
|
|
|
|
|
|
|
Once the above checks are satisfied, please edit your issue with the changes and we will
|
|
|
|
try to reproduce the bug again.
|
2023-02-17 18:19:06 +00:00
|
|
|
|
2023-02-17 14:18:52 +00:00
|
|
|
---
|
|
|
|
[Analyzer run](${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }})
|