-
Notifications
You must be signed in to change notification settings - Fork 0
70 lines (64 loc) · 2.19 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
name: CI
on:
push:
branches: [ main ]
tags-ignore:
- '**'
pull_request:
branches: [ main ]
# Cancel in-progress jobs or runs for the current workflow
concurrency:
group: ${{ github.workflow }}-${{ github.head_ref || github.ref }}
cancel-in-progress: true
# Set environment variables available in all jobs and steps
env:
go_version: "1.23.3"
python_version: "3.9"
jobs:
# Check that a news file has been added to this branch when a PR is created
assert-news:
name: Assert news files (See CONTRIBUTING.md)
runs-on: ubuntu-latest
steps:
# Checkout with full history for to allow compare with base branch
- uses: actions/checkout@v4
with:
fetch-depth: 0
- uses: actions/setup-python@v5
with:
python-version: ${{ env.python_version }}
- name: Install CI/CD tools
run: pip install continuous-delivery-scripts && pip list
- name: Assert news
run: bash ./scripts/setup_github.sh && cd-assert-news -b $GIT_BRANCH
env:
GIT_TOKEN: ${{ secrets.GIT_SECRET }}
GIT_BRANCH: ${{ github.head_ref || github.ref }}
- name: Report failure if needed
if: ${{ failure() }}
run: |
echo "::error:: News file missing (See CONTRIBUTING.md guide for details)."
detect-secrets:
name: Check for secrets
runs-on: ubuntu-latest
steps:
- uses: actions/setup-python@v5
- name: Install tools
run: pip install detect-secrets==1.0.3 && pip list
- uses: actions/checkout@v4
with:
fetch-depth: 0
# FIXME: GitLeaks requires a licence now
#- name: Check for secrets using gitleaks
# uses: gitleaks/gitleaks-action@v2
# with:
# config-path: .gitleaks.toml
- name: Check for secrets using detect-secrets
run: git ls-files -z | xargs -0 detect-secrets-hook --baseline .secrets.baseline --exclude-files '.*go\.sum$' --exclude-files '.*\.html$' --exclude-files '.*\.properties$' --exclude-files 'ci.yml'
working-directory: .
build-and-test:
uses: ./.github/workflows/update-utils.yml
needs: [assert-news, detect-secrets]
secrets: inherit
with:
branch: ${{ github.head_ref || github.ref }}