Skip to content

Commit 0a3ebb4

Browse files
committed
Add integration test
1 parent 0b56c87 commit 0a3ebb4

File tree

3 files changed

+94
-2
lines changed

3 files changed

+94
-2
lines changed
Lines changed: 91 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,91 @@
1+
name: Integration tests
2+
3+
on:
4+
push:
5+
branches: ["**"]
6+
7+
concurrency:
8+
group: integration-test-${{ github.ref }}
9+
cancel-in-progress: true
10+
11+
env:
12+
split-total: 4
13+
14+
jobs:
15+
generate-split-index-json:
16+
name: Generate split indexes
17+
runs-on: ubuntu-latest
18+
outputs:
19+
json: ${{ steps.generate.outputs.split-index-json }}
20+
steps:
21+
- name: Generate split index list
22+
id: generate
23+
uses: donnerbart/split-tests-java-action/generate-split-index-json@11efbe6f3e414504547447682e5b7eef6ac3e860 # v1
24+
with:
25+
split-total: ${{ env.split-total }}
26+
27+
integration-test:
28+
name: "Test #${{ matrix.split-index }}"
29+
runs-on: ubuntu-latest
30+
needs:
31+
- generate-split-index-json
32+
permissions:
33+
contents: read
34+
checks: write
35+
strategy:
36+
fail-fast: false
37+
matrix:
38+
split-index: ${{ fromjson(needs.generate-split-index-json.outputs.json) }}
39+
steps:
40+
- name: Checkout split-test-java
41+
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4
42+
43+
- name: Set up JDK 21
44+
uses: actions/setup-java@3a4f6e1af504cf6a31855fa899c6aa5355ba6c12 # v4
45+
with:
46+
distribution: temurin
47+
java-version: 21
48+
49+
- name: Split tests
50+
id: split-tests
51+
uses: donnerbart/split-tests-java-action@11efbe6f3e414504547447682e5b7eef6ac3e860 # v1
52+
with:
53+
split-index: ${{ matrix.split-index }}
54+
split-total: ${{ env.split-total }}
55+
glob: '**/src/test/resources/tests/*Test.java'
56+
exclude-glob: '**/NoClassNameTest.java'
57+
junit-glob: '**/src/test/resources/reports/*.xml'
58+
format: 'list'
59+
new-test-time: 'average'
60+
calculate-optimal-total-split: true
61+
debug: true
62+
63+
- name: Assert split tests
64+
env:
65+
SPLIT_INDEX: ${{ matrix.split-index }}
66+
ACTUAL: ${{ steps.split-tests.outputs.test-suite }}
67+
run: |
68+
case "$SPLIT_INDEX" in
69+
"0")
70+
EXPECTED="de.donnerbart.example.SlowestTest"
71+
;;
72+
"1")
73+
EXPECTED="NoPackageTest de.donnerbart.example.ThirdPartyLibraryTest"
74+
;;
75+
"2")
76+
EXPECTED="de.donnerbart.example.NoTimingOneTest de.donnerbart.example.WhitespaceClassDefinitionTest"
77+
;;
78+
"3")
79+
EXPECTED="de.donnerbart.example.NoTimingTwoTest de.donnerbart.example.SlowTest de.donnerbart.example.FastTest"
80+
;;
81+
*)
82+
echo "Unexpected split index"
83+
exit 1
84+
;;
85+
esac
86+
echo "Expected: $EXPECTED"
87+
echo "Actual: $ACTUAL"
88+
if [ "$ACTUAL" != "$EXPECTED" ]; then
89+
echo "The split tests are not matching"
90+
exit 1
91+
fi
Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
name: CI Check
1+
name: Unit tests
22

33
on:
44
push:

README.md

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,5 @@
1-
[![CI Check](https://github.com/Donnerbart/split-tests-java/actions/workflows/check.yml/badge.svg)](https://github.com/Donnerbart/split-tests-java/actions/workflows/check.yml)
1+
[![Unit tests](https://github.com/Donnerbart/split-tests-java/actions/workflows/unit-test.yml/badge.svg)](https://github.com/Donnerbart/split-tests-java/actions/workflows/unit-test.yml)
2+
[![Integration tests](https://github.com/Donnerbart/split-tests-java/actions/workflows/integration-test.yml/badge.svg)](https://github.com/Donnerbart/split-tests-java/actions/workflows/integration-test.yml)
23
[![Release](https://github.com/Donnerbart/split-tests-java/actions/workflows/release.yml/badge.svg)](https://github.com/Donnerbart/split-tests-java/actions/workflows/release.yml)
34

45
# Split Tests Java

0 commit comments

Comments
 (0)