-
Notifications
You must be signed in to change notification settings - Fork 0
80 lines (76 loc) · 2.1 KB
/
pr.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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
name: PR
on:
pull_request:
types:
- opened
- edited
- synchronize
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
# Sets the GITHUB_TOKEN permissions to allow deployment to GitHub Pages
permissions:
id-token: write
contents: write
issues: write
pull-requests: write
jobs:
test_server:
name: Server
runs-on: ubuntu-latest
environment: testing
steps:
- name: 👌🏻 Checkout
uses: actions/checkout@v3
- name: 👌🏻 Setup mongodb
run: |
cd server
docker-compose up -d
- name: 👌🏻 Run server
run: |
cd server
npm ci
npm run start &
test_client:
name: Client
runs-on: ubuntu-latest
environment: testing
needs: [test_server]
steps:
- name: 👌🏻 Checkout
uses: actions/checkout@v3
- name: 👌🏻 Setup and build
run: |
cd client
npm ci
npm run build
npm run preview &
- name: 🔎 Run tests
run: |
cd client
npm run test
dependabot_automerge:
name: Approve and automerge (only dependanbot PRs)
runs-on: ubuntu-latest
needs: [test_client]
environment: testing
if: ${{ github.actor == 'dependabot[bot]' }}
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Dependabot metadata
id: dependabot-metadata
uses: dependabot/[email protected]
with:
github-token: "${{ secrets.GITHUB_TOKEN }}"
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Approve a PR
run: gh pr review --approve "$PR_URL"
env:
PR_URL: ${{github.event.pull_request.html_url}}
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Enable auto-merge for Dependabot PRs
if: ${{ steps.dependabot-metadata.outputs.update-type != 'version-update:semver-major' }}
run: gh pr merge --auto --merge "$PR_URL"
env:
PR_URL: ${{ github.event.pull_request.html_url }}
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}