-
Notifications
You must be signed in to change notification settings - Fork 5
111 lines (97 loc) · 3.55 KB
/
integration.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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
# Run secret-dependent integration tests only after /ok-to-test approval
on:
push:
branches: [ "main", "renovate/**" ]
pull_request:
repository_dispatch:
types: [ "ok-to-test-command" ]
name: Integration Tests
jobs:
# Branch-based pull request
integration-trusted:
runs-on: ubuntu-latest
permissions:
id-token: write
if: |
github.event_name == 'pull_request' && github.event.pull_request.head.repo.full_name == github.repository ||
github.event_name == 'push' && (github.event.ref == 'refs/heads/main' || startsWith(github.event.ref, 'refs/heads/renovate'))
steps:
- uses: actions/checkout@v4
- name: Set up Go
uses: actions/setup-go@v5
with:
go-version: '1.22'
- name: Configure AWS Credentials
uses: aws-actions/configure-aws-credentials@v4
with:
aws-region: us-east-1
role-to-assume: arn:aws:iam::520156417308:role/github-action-auth-Role-MJSGfkUydl2D
- name: Integration Test
run: >-
AWS_REGION=us-east-1
BUCKET_NAME=sqsec-integration-bucket
QUEUE_URL=https://sqs.us-east-1.amazonaws.com/520156417308/sqsec-integration-queue
go test -v ./... -run Integration
# Repo owner has commented /ok-to-test on a (fork-based) pull request
integration-fork:
runs-on: ubuntu-latest
permissions:
pull-requests: write
checks: write
id-token: write
if: |
github.event_name == 'repository_dispatch' &&
github.event.client_payload.slash_command.args.named.sha != '' &&
contains(
github.event.client_payload.pull_request.head.sha,
github.event.client_payload.slash_command.args.named.sha
)
steps:
- name: Fork based /ok-to-test checkout
uses: actions/checkout@v4
with:
ref: 'refs/pull/${{ github.event.client_payload.pull_request.number }}/merge'
- name: Set up Go
uses: actions/setup-go@v5
with:
go-version: '1.22'
- name: Configure AWS Credentials
uses: aws-actions/configure-aws-credentials@v4
with:
aws-region: us-east-1
role-to-assume: arn:aws:iam::520156417308:role/github-action-auth-Role-MJSGfkUydl2D
- name: Integration Test
run: >-
AWS_REGION=us-east-1
BUCKET_NAME=sqsec-integration-bucket
QUEUE_URL=https://sqs.us-east-1.amazonaws.com/520156417308/sqsec-integration-queue
go test -v ./... -run Integration
# Update check run called "integration-fork"
- uses: actions/github-script@v7
id: update-check-run
if: ${{ always() }}
env:
number: ${{ github.event.client_payload.pull_request.number }}
job: ${{ github.job }}
# Conveniently, job.status maps to https://developer.github.com/v3/checks/runs/#update-a-check-run
conclusion: ${{ job.status }}
with:
github-token: ${{ secrets.GITHUB_TOKEN }}
script: |
const { data: pull } = await github.rest.pulls.get({
...context.repo,
pull_number: process.env.number
});
const ref = pull.head.sha;
const { data: checks } = await github.rest.checks.listForRef({
...context.repo,
ref
});
const check = checks.check_runs.filter(c => c.name === process.env.job);
const { data: result } = await github.rest.checks.update({
...context.repo,
check_run_id: check[0].id,
status: 'completed',
conclusion: process.env.conclusion
});
return result;