generated from opensafely-core/repo-template
-
Notifications
You must be signed in to change notification settings - Fork 3
55 lines (47 loc) · 2.02 KB
/
update-external-studies.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
---
name: "Create PR to update `external_studies` test code"
on:
workflow_dispatch:
# Once a week on Sunday afternoon
schedule:
- cron: "21 17 * * 0"
jobs:
create_external_studies_pr:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: opensafely-core/setup-action@v1
with:
install-just: true
python-version: "3.11"
- name: Update vendored copies of external study code
run: just update-external-studies
# These are problematic (in particular the flake8 hook doesn't respect
# the `.flake8` config file) and unnecessary as all the checks will get
# run on the PR anyway
- name: Disable pre-commit hooks
run: git config core.hooksPath /dev/null
- name: Generate app token
uses: actions/create-github-app-token@v1
id: generate-token
with:
app-id: 1031449 # opensafely-core Create PR app
private-key: ${{ secrets.CREATE_PR_APP_PRIVATE_KEY }}
- name: Create a Pull Request if there are any changes
id: create_pr
uses: peter-evans/create-pull-request@67ccf781d68cd99b580ae25a5c18a1cc84ffff1f # v7.0.6
with:
add-paths: tests/acceptance/external_studies/*
branch: bot/update-external-studies
base: main
author: "opensafely-github-bot <[email protected]>"
committer: "opensafely-github-bot <[email protected]>"
commit-message: "chore: Update `external_studies` test code"
title: "Update `external_studies` test code"
token: ${{ steps.generate-token.outputs.token }}
# The PR will still require manual approval, this just reduces it to a one-click process
- name: Enable automerge
if: steps.create_pr.outputs.pull-request-operation == 'created'
run: gh pr merge --auto --squash ${{ steps.create_pr.outputs.pull-request-number }}
env:
GH_TOKEN: ${{ steps.generate-token.outputs.token }}