-
Notifications
You must be signed in to change notification settings - Fork 3
119 lines (103 loc) · 3.08 KB
/
ci-config.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
name: GitHub CI
on:
push:
branches:
- main
- trellis-extensions-[0-9]+.[0-9]+.x
pull_request:
branches:
- main
jobs:
validation:
name: Validation
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: gradle/wrapper-validation-action@v3
build:
needs: [validation]
runs-on: ubuntu-latest
strategy:
matrix:
java: [11]
name: Java ${{ matrix.java }} environment
steps:
- uses: actions/checkout@v4
- name: Set up JDK ${{ matrix.java }}
uses: actions/setup-java@v4
with:
distribution: 'adopt'
java-version: ${{ matrix.java }}
- name: Cache
uses: actions/cache@v4
with:
path: ~/.gradle/caches
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle') }}
restore-keys: |
${{ runner.os }}-gradle-
- name: Build with Gradle
run: ./gradlew check assemble javadoc -x pmdMain
security:
needs: [validation]
runs-on: ubuntu-latest
name: Security analysis
steps:
- uses: actions/checkout@v4
- name: Run Snyk to check for vulnerabilities
# Only run security scans for push events
if: github.event_name == 'push'
env:
PROJECT_PATH: /project/trellis-extensions
SNYK_ORG: ${{ secrets.SNYK_ORG }}
SNYK_TOKEN: ${{ secrets.SNYK_TOKEN }}
# Skip this analysis if the integration isn't set up
run: |
if [ "$SNYK_ORG" != "" ]; then
# Don't fail on snyk scans
docker run --name snyk -e SNYK_TOKEN -e PROJECT_PATH -v "/home/runner/work/trellis-extensions":"/project" snyk/snyk-cli:gradle-5.4 "monitor --all-sub-projects --org=$SNYK_ORG" || true
fi
windows:
needs: [validation]
runs-on: windows-latest
name: Java 11 Windows environment
steps:
- uses: actions/checkout@v4
- name: Set up JDK 11
uses: actions/setup-java@v4
with:
distribution: 'adopt'
java-version: 11
- name: Cache
uses: actions/cache@v4
with:
path: ~/.gradle/caches
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle') }}
restore-keys: |
${{ runner.os }}-gradle-
- name: Build with Gradle
shell: bash
run: ./gradlew.bat -x pmdMain check
cassandra:
needs: [validation]
runs-on: ubuntu-latest
name: Java 11 (cassandra) environment
services:
cassandra:
image: cassandra:3.11
ports:
- 9042:9042
- 9160:9160
options: --name cassandra -v /home/runner/work:/workspace
steps:
- uses: actions/checkout@v4
- name: Set up JDK 11
uses: actions/setup-java@v4
with:
distribution: 'adopt'
java-version: 11
- name: "Java 11 (Quarkus Cassandra)"
run: |
docker exec cassandra sh -c "/workspace/trellis-extensions/trellis-extensions/buildtools/src/main/resources/cassandra/initialize.sh /workspace/trellis-extensions/trellis-extensions/cassandra/src/main/resources"
./gradlew check -x pmdMain install --scan
env:
TEST_CASSANDRA: true