-
Notifications
You must be signed in to change notification settings - Fork 16
145 lines (124 loc) · 4.04 KB
/
ci.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
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
name: CI
on:
workflow_dispatch: {}
push:
branches:
- main
paths-ignore:
- "Jenkinsfile"
- ".git**"
pull_request:
jobs:
codeql-sast:
name: CodeQL SAST scan
uses: alphagov/govuk-infrastructure/.github/workflows/codeql-analysis.yml@main
permissions:
security-events: write
dependency-review:
name: Dependency Review scan
uses: alphagov/govuk-infrastructure/.github/workflows/dependency-review.yml@main
security-analysis:
name: Security Analysis
uses: alphagov/govuk-infrastructure/.github/workflows/brakeman.yml@main
lint-ruby:
name: Lint Ruby
uses: alphagov/govuk-infrastructure/.github/workflows/rubocop.yml@main
run-gds-api-adapters-pact-tests:
name: Run GDS API Adapter Pact tests
uses: ./.github/workflows/pact-verify.yml
with:
ref: ${{ github.ref }}
test-ruby:
name: Test Ruby
runs-on: ubuntu-latest
steps:
- name: Setup Postgres
id: setup-postgres
uses: alphagov/govuk-infrastructure/.github/actions/setup-postgres@main
- name: Setup Redis
uses: alphagov/govuk-infrastructure/.github/actions/setup-redis@main
- name: Checkout repository
uses: actions/checkout@v3
- name: Setup Ruby
uses: ruby/setup-ruby@v1
with:
bundler-cache: true
- name: Initialize database
env:
RAILS_ENV: test
TEST_DATABASE_URL: ${{ steps.setup-postgres.outputs.db-url }}
run: bundle exec rails db:setup
- name: Run RSpec
env:
RAILS_ENV: test
TEST_DATABASE_URL: ${{ steps.setup-postgres.outputs.db-url }}
run: bundle exec rake spec
# We upload the generated pact tests so they can be used in a later action
- name: Create and upload pact test artifact
uses: actions/upload-artifact@v3
with:
name: pacts
path: spec/pacts/*.json
check-schemas-build:
name: Check content schemas are built
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v3
- name: Setup Ruby
uses: ruby/setup-ruby@v1
with:
bundler-cache: true
- name: Build content schemas
run: bundle exec rake build_schemas
- name: Check for uncommited changes
run: |
if git diff --exit-code; then
echo "No uncommit changes detected."
else
echo "::error title=Uncommited changes to content schemas::If these are your changes, build the content schemas and commit the changes."
exit 1
fi
run-content-store-pact-tests:
name: Run Content Store Pact tests
needs: test-ruby
uses: alphagov/content-store/.github/workflows/verify-pact.yml@main
with:
ref: main
pact_artifact: pacts
publish-pacts:
needs:
- test-ruby
if: ${{ github.ref == 'refs/heads/main' }}
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: ruby/setup-ruby@v1
with:
bundler-cache: true
- uses: actions/download-artifact@v3
with:
name: pacts
path: tmp/pacts
- run: bundle exec rake pact:publish
env:
PACT_CONSUMER_VERSION: branch-${{ github.ref_name }}
PACT_BROKER_BASE_URL: https://govuk-pact-broker-6991351eca05.herokuapp.com
PACT_BROKER_USERNAME: ${{ secrets.GOVUK_PACT_BROKER_USERNAME }}
PACT_BROKER_PASSWORD: ${{ secrets.GOVUK_PACT_BROKER_PASSWORD }}
PACT_PATTERN: tmp/pacts/*.json
delete-pact-artifact:
name: Delete Pact artifact
needs:
- test-ruby
- run-content-store-pact-tests
- publish-pacts
# Run whenever test-ruby is a success regardless of run-content-store-pact-tests outcome
if: ${{ needs.test-ruby.result == 'success' && always() }}
runs-on: ubuntu-latest
steps:
# As of Jan 2023, GitHub doesn't provide a delete artifact equivalent to
# their upload / download ones
- uses: geekyeggo/delete-artifact@v2
with:
name: pacts