-
Notifications
You must be signed in to change notification settings - Fork 28
112 lines (93 loc) · 3.08 KB
/
ci.yaml
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
name: Java CI
on: [push, pull_request]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: szenius/set-timezone@v1.0
with:
timezoneLinux: "Europe/Paris"
- uses: mirromutth/mysql-action@v1.1
with:
mysql version: '5.7'
mysql database: 'araknemu'
mysql user: 'araknemu'
mysql password: 'araknemu'
mysql root password: 'root'
- name: Reset mysql password
run: |
while :
do
sleep 1
mysql -h 127.0.0.1 -u root --password=root -e 'select version()' && break
done
cat <<EOF | mysql -h 127.0.0.1 -u root --password=root
CREATE USER 'araknemu'@'%';
GRANT ALL PRIVILEGES ON *.* TO 'araknemu'@'%';
UPDATE mysql.user SET authentication_string = null WHERE user = 'araknemu';
FLUSH PRIVILEGES;
EOF
- name: Set up JDK 8
uses: actions/setup-java@v2
with:
java-version: '8'
distribution: 'adopt'
- name: Build with Maven
run: mvn --batch-mode --update-snapshots -P '!checkerframework,!checkerframework-jdk8,!checkerframework-jdk9orlater' verify
- name: Upload coverage to Codecov
uses: codecov/codecov-action@v3
with:
token: ${{ secrets.CODECOV_TOKEN }}
files: target/site/jacoco/jacoco.xml
java_compatibility:
runs-on: ubuntu-latest
strategy:
matrix:
java_version: [8, 11, 14, 17]
steps:
- uses: actions/checkout@v2
- uses: szenius/set-timezone@v1.0
with:
timezoneLinux: "Europe/Paris"
- uses: mirromutth/mysql-action@v1.1
with:
mysql version: '5.7'
mysql database: 'araknemu'
mysql user: 'araknemu'
mysql password: 'araknemu'
mysql root password: 'root'
- name: Reset mysql password
run: |
while :
do
sleep 1
mysql -h 127.0.0.1 -u root --password=root -e 'select version()' && break
done
cat <<EOF | mysql -h 127.0.0.1 -u root --password=root
CREATE USER 'araknemu'@'%';
GRANT ALL PRIVILEGES ON *.* TO 'araknemu'@'%';
UPDATE mysql.user SET authentication_string = null WHERE user = 'araknemu';
FLUSH PRIVILEGES;
EOF
- name: Set up JDK ${{ matrix.java_version }}
uses: actions/setup-java@v2
with:
java-version: ${{ matrix.java_version }}
distribution: 'adopt'
- name: Run tests
run: mvn --batch-mode -Djacoco.skip=true -P '!checkerframework,!checkerframework-jdk8,!checkerframework-jdk9orlater' test
static_analysis:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: szenius/set-timezone@v1.0
with:
timezoneLinux: "Europe/Paris"
- name: Set up JDK 11
uses: actions/setup-java@v2
with:
java-version: 11
distribution: 'adopt'
- name: Run tests
run: mvn clean compile