mirror of https://github.com/commaai/panda.git
46 lines
1.5 KiB
YAML
46 lines
1.5 KiB
YAML
name: jenkins scan
|
|
|
|
on:
|
|
issue_comment:
|
|
types: [created, edited]
|
|
|
|
jobs:
|
|
# TODO: gc old branches in a separate job in this workflow
|
|
scan-comments:
|
|
runs-on: ubuntu-latest
|
|
if: ${{ github.event.issue.pull_request }}
|
|
steps:
|
|
- name: Check for trigger phrase
|
|
id: check_comment
|
|
uses: actions/github-script@v7
|
|
with:
|
|
script: |
|
|
const triggerPhrase = "trigger-jenkins";
|
|
const comment = context.payload.comment.body;
|
|
const commenter = context.payload.comment.user.login;
|
|
|
|
const { data: permissions } = await github.rest.repos.getCollaboratorPermissionLevel({
|
|
owner: context.repo.owner,
|
|
repo: context.repo.repo,
|
|
username: commenter
|
|
});
|
|
|
|
const hasWriteAccess = permissions.permission === 'write' || permissions.permission === 'admin';
|
|
|
|
return (hasWriteAccess && comment.includes(triggerPhrase));
|
|
result-encoding: json
|
|
|
|
- name: Checkout repository
|
|
if: steps.check_comment.outputs.result == 'true'
|
|
uses: actions/checkout@v4
|
|
with:
|
|
ref: refs/pull/${{ github.event.issue.number }}/head
|
|
|
|
- name: Push to tmp-jenkins branch
|
|
if: steps.check_comment.outputs.result == 'true'
|
|
run: |
|
|
git config --global user.name "github-actions[bot]"
|
|
git config --global user.email "github-actions[bot]@users.noreply.github.com"
|
|
git checkout -b tmp-jenkins-${{ github.event.issue.number }}
|
|
GIT_LFS_SKIP_PUSH=1 git push -f origin tmp-jenkins-${{ github.event.issue.number }}
|