aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--.github/workflows/labeler.yml19
-rw-r--r--.github/workflows/reviews.yml118
-rw-r--r--ci/reviews.js80
3 files changed, 94 insertions, 123 deletions
diff --git a/.github/workflows/labeler.yml b/.github/workflows/labeler.yml
index 08f0ce1763..736b8ae630 100644
--- a/.github/workflows/labeler.yml
+++ b/.github/workflows/labeler.yml
@@ -31,14 +31,17 @@ jobs:
- name: "Extract commit scope and add as label"
run: gh pr edit "$PR_NUMBER" --add-label "$(echo "$PR_TITLE" | sed -E 's|[[:alpha:]]+\((.+)\)!?:.*|\1|')" || true
- upload-pr-number:
+ request-reviewer:
+ if: github.event.pull_request.state == 'open' && github.event.pull_request.draft == false
runs-on: ubuntu-latest
+ needs: ["triage", "type-scope"]
+ permissions:
+ pull-requests: write
steps:
- - name: Save PR number
- run: |
- mkdir -p pr
- echo ${{ github.event.number }} > pr/pr_number
- - uses: actions/upload-artifact@v2
+ - run: wget https://raw.githubusercontent.com/neovim/neovim/master/ci/reviews.js
+ - name: 'Request reviewers'
+ uses: actions/github-script@v6
with:
- name: pr_number
- path: pr/
+ script: |
+ const script = require('./reviews.js')
+ await script({github, context})
diff --git a/.github/workflows/reviews.yml b/.github/workflows/reviews.yml
index bd2dd8759d..2da7365821 100644
--- a/.github/workflows/reviews.yml
+++ b/.github/workflows/reviews.yml
@@ -2,9 +2,6 @@ name: "Request reviews"
on:
pull_request_target:
types: [labeled, ready_for_review]
- workflow_run:
- workflows: [Pull Request Labeler]
- types: [completed]
jobs:
request-reviewer:
if: github.event.pull_request.state == 'open' && github.event.pull_request.draft == false
@@ -12,119 +9,10 @@ jobs:
permissions:
pull-requests: write
steps:
- - if: github.event_name == 'workflow_run'
- name: 'Download artifact with PR number'
- uses: actions/github-script@v6
- with:
- script: |
- let allArtifacts = await github.rest.actions.listWorkflowRunArtifacts({
- owner: context.repo.owner,
- repo: context.repo.repo,
- run_id: context.payload.workflow_run.id,
- });
- let matchArtifact = allArtifacts.data.artifacts.filter((artifact) => {
- return artifact.name == "pr_number"
- })[0];
- let download = await github.rest.actions.downloadArtifact({
- owner: context.repo.owner,
- repo: context.repo.repo,
- artifact_id: matchArtifact.id,
- archive_format: 'zip',
- });
- let fs = require('fs');
- fs.writeFileSync(`${process.env.GITHUB_WORKSPACE}/pr_number.zip`, Buffer.from(download.data));
-
- - if: github.event_name == 'workflow_run'
- name: 'Unzip artifact'
- run: unzip pr_number.zip
-
+ - run: wget https://raw.githubusercontent.com/neovim/neovim/master/ci/reviews.js
- name: 'Request reviewers'
uses: actions/github-script@v6
with:
script: |
- // The number of the pull request that triggered this run. If label
- // was added manually by a person the number will be stored in current
- // context, otherwise the number will be stored in a text file that
- // was stored as an artifact from previous workflow.
-
- const fs = require('fs')
- const pr_number = context.issue.number || Number(fs.readFileSync('./pr_number'))
-
- const pr_data = await github.rest.pulls.get({
- owner: context.repo.owner,
- repo: context.repo.repo,
- pull_number: pr_number
- })
- const labels = pr_data.data.labels.map(e => e.name)
-
- const reviewers = new Set()
- if (labels.includes('api')) {
- reviewers.add("bfredl")
- reviewers.add("gpanders")
- reviewers.add("muniter")
- }
-
- if (labels.includes('ci')) {
- reviewers.add("jamessan")
- }
-
- if (labels.includes('diagnostic')) {
- reviewers.add("gpanders")
- }
-
- if (labels.includes('distribution')) {
- reviewers.add("jamessan")
- }
-
- if (labels.includes('documentation')) {
- reviewers.add("clason")
- }
-
- if (labels.includes('extmarks')) {
- reviewers.add("bfredl")
- }
-
- if (labels.includes('filetype')) {
- reviewers.add("clason")
- reviewers.add("gpanders")
- }
-
- if (labels.includes('gui')) {
- reviewers.add("glacambre")
- reviewers.add("smolck")
- }
-
- if (labels.includes('lsp')) {
- reviewers.add("mfussenegger")
- reviewers.add("mjlbach")
- }
-
- if (labels.includes('treesitter')) {
- reviewers.add("bfredl")
- reviewers.add("vigoux")
- }
-
- if (labels.includes('typo')) {
- reviewers.add("dundargoc")
- }
-
- if (labels.includes('ui')) {
- reviewers.add("bfredl")
- }
-
- if (labels.includes('vim-patch')) {
- reviewers.add("janlazo")
- reviewers.add("seandewar")
- reviewers.add("zeertzjq")
- }
-
- // Remove person that opened the PR since they can't review themselves
- const pr_opener = pr_data.data.user.login
- reviewers.delete(pr_opener)
-
- github.rest.pulls.requestReviewers({
- owner: context.repo.owner,
- repo: context.repo.repo,
- pull_number: pr_number,
- reviewers: Array.from(reviewers)
- });
+ const script = require('./reviews.js')
+ await script({github, context})
diff --git a/ci/reviews.js b/ci/reviews.js
new file mode 100644
index 0000000000..3e8e07976a
--- /dev/null
+++ b/ci/reviews.js
@@ -0,0 +1,80 @@
+module.exports = async ({github, context}) => {
+ const pr_data = await github.rest.pulls.get({
+ owner: context.repo.owner,
+ repo: context.repo.repo,
+ pull_number: context.issue.number
+ })
+ const labels = pr_data.data.labels.map(e => e.name)
+
+ const reviewers = new Set()
+ if (labels.includes('api')) {
+ reviewers.add("bfredl")
+ reviewers.add("gpanders")
+ reviewers.add("muniter")
+ }
+
+ if (labels.includes('ci')) {
+ reviewers.add("jamessan")
+ }
+
+ if (labels.includes('diagnostic')) {
+ reviewers.add("gpanders")
+ }
+
+ if (labels.includes('distribution')) {
+ reviewers.add("jamessan")
+ }
+
+ if (labels.includes('documentation')) {
+ reviewers.add("clason")
+ }
+
+ if (labels.includes('extmarks')) {
+ reviewers.add("bfredl")
+ }
+
+ if (labels.includes('filetype')) {
+ reviewers.add("clason")
+ reviewers.add("gpanders")
+ }
+
+ if (labels.includes('gui')) {
+ reviewers.add("glacambre")
+ reviewers.add("smolck")
+ }
+
+ if (labels.includes('lsp')) {
+ reviewers.add("mfussenegger")
+ reviewers.add("mjlbach")
+ }
+
+ if (labels.includes('treesitter')) {
+ reviewers.add("bfredl")
+ reviewers.add("vigoux")
+ }
+
+ if (labels.includes('typo')) {
+ reviewers.add("dundargoc")
+ }
+
+ if (labels.includes('ui')) {
+ reviewers.add("bfredl")
+ }
+
+ if (labels.includes('vim-patch')) {
+ reviewers.add("janlazo")
+ reviewers.add("seandewar")
+ reviewers.add("zeertzjq")
+ }
+
+ // Remove person that opened the PR since they can't review themselves
+ const pr_opener = pr_data.data.user.login
+ reviewers.delete(pr_opener)
+
+ github.rest.pulls.requestReviewers({
+ owner: context.repo.owner,
+ repo: context.repo.repo,
+ pull_number: context.issue.number,
+ reviewers: Array.from(reviewers)
+ });
+}