2024-08-16 12:00:10 +02:00
|
|
|
name: Build repo
|
2023-12-30 03:59:36 +01:00
|
|
|
|
|
|
|
on:
|
2024-08-16 12:09:17 +02:00
|
|
|
push:
|
|
|
|
branches: ["main"]
|
2024-08-16 12:44:49 +02:00
|
|
|
pull_request:
|
|
|
|
branches: ["main"]
|
2023-12-30 03:59:36 +01:00
|
|
|
|
2025-01-02 19:22:14 +01:00
|
|
|
permissions:
|
|
|
|
contents: read
|
2024-12-21 13:28:35 +01:00
|
|
|
|
2023-12-30 03:59:36 +01:00
|
|
|
jobs:
|
|
|
|
build:
|
2024-08-16 12:00:10 +02:00
|
|
|
runs-on: ubuntu-latest
|
2024-12-21 23:47:53 +01:00
|
|
|
|
|
|
|
permissions:
|
2025-01-02 19:22:14 +01:00
|
|
|
actions: read
|
2024-12-21 23:47:53 +01:00
|
|
|
security-events: write
|
|
|
|
|
2024-08-16 12:09:17 +02:00
|
|
|
strategy:
|
|
|
|
fail-fast: false
|
|
|
|
matrix:
|
|
|
|
jdk-version: [17, 21]
|
|
|
|
|
2023-12-30 03:59:36 +01:00
|
|
|
steps:
|
2024-12-21 13:28:35 +01:00
|
|
|
- name: Harden Runner
|
|
|
|
uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f # v2.10.2
|
|
|
|
with:
|
|
|
|
egress-policy: audit
|
|
|
|
|
2024-04-21 17:30:17 +02:00
|
|
|
- name: Checkout repository
|
2024-12-21 13:28:35 +01:00
|
|
|
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
2024-04-21 17:30:17 +02:00
|
|
|
|
2024-08-16 12:00:10 +02:00
|
|
|
- name: Set up JDK ${{ matrix.jdk-version }}
|
2024-12-21 13:28:35 +01:00
|
|
|
uses: actions/setup-java@7a6d8a8234af8eb26422e24e3006232cccaa061b # v4.6.0
|
2024-04-21 17:30:17 +02:00
|
|
|
with:
|
2024-08-16 12:00:10 +02:00
|
|
|
java-version: ${{ matrix.jdk-version }}
|
2024-04-21 17:30:17 +02:00
|
|
|
distribution: "temurin"
|
|
|
|
|
2024-12-26 12:13:41 +01:00
|
|
|
- name: Build with Gradle and no spring security
|
|
|
|
run: ./gradlew clean build
|
|
|
|
env:
|
|
|
|
DOCKER_ENABLE_SECURITY: false
|
|
|
|
|
|
|
|
- name: Build with Gradle and with spring security
|
|
|
|
run: ./gradlew clean build
|
|
|
|
env:
|
|
|
|
DOCKER_ENABLE_SECURITY: true
|
2025-01-02 19:22:14 +01:00
|
|
|
|
2025-01-06 13:41:30 +01:00
|
|
|
- name: Upload Test Reports
|
|
|
|
if: always()
|
2025-01-08 21:12:11 +01:00
|
|
|
uses: actions/upload-artifact@6f51ac03b9356f520e9adb1b1b7802705f340c2b # v4.5.0
|
2025-01-06 13:41:30 +01:00
|
|
|
with:
|
|
|
|
name: test-reports-jdk-${{ matrix.jdk-version }}
|
|
|
|
path: |
|
|
|
|
build/reports/tests/
|
|
|
|
build/test-results/
|
|
|
|
build/reports/problems/
|
|
|
|
retention-days: 3
|
2025-01-08 21:12:11 +01:00
|
|
|
|
2024-08-16 12:00:10 +02:00
|
|
|
docker-compose-tests:
|
2024-08-18 14:07:14 +02:00
|
|
|
# if: github.event_name == 'push' && github.ref == 'refs/heads/main' ||
|
2024-08-16 12:44:49 +02:00
|
|
|
# (github.event_name == 'pull_request' &&
|
|
|
|
# contains(github.event.pull_request.labels.*.name, 'licenses') == false &&
|
|
|
|
# (
|
|
|
|
# contains(github.event.pull_request.labels.*.name, 'Front End') ||
|
|
|
|
# contains(github.event.pull_request.labels.*.name, 'Java') ||
|
|
|
|
# contains(github.event.pull_request.labels.*.name, 'Back End') ||
|
|
|
|
# contains(github.event.pull_request.labels.*.name, 'Security') ||
|
|
|
|
# contains(github.event.pull_request.labels.*.name, 'API') ||
|
|
|
|
# contains(github.event.pull_request.labels.*.name, 'Docker') ||
|
|
|
|
# contains(github.event.pull_request.labels.*.name, 'Test')
|
|
|
|
# )
|
|
|
|
# )
|
2024-08-16 12:00:10 +02:00
|
|
|
|
|
|
|
runs-on: ubuntu-latest
|
|
|
|
|
|
|
|
steps:
|
2024-12-21 13:28:35 +01:00
|
|
|
- name: Harden Runner
|
|
|
|
uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f # v2.10.2
|
|
|
|
with:
|
|
|
|
egress-policy: audit
|
|
|
|
|
2024-08-16 12:00:10 +02:00
|
|
|
- name: Checkout Repository
|
2024-12-21 13:28:35 +01:00
|
|
|
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
|
2024-08-16 12:00:10 +02:00
|
|
|
|
|
|
|
- name: Set up Java 17
|
2024-12-21 13:28:35 +01:00
|
|
|
uses: actions/setup-java@7a6d8a8234af8eb26422e24e3006232cccaa061b # v4.6.0
|
2024-08-16 12:00:10 +02:00
|
|
|
with:
|
|
|
|
java-version: "17"
|
|
|
|
distribution: "adopt"
|
|
|
|
|
|
|
|
- name: Set up Docker Buildx
|
2024-12-21 13:28:35 +01:00
|
|
|
uses: docker/setup-buildx-action@6524bf65af31da8d45b59e8c27de4bd072b392f5 # v3.8.0
|
2024-08-16 12:00:10 +02:00
|
|
|
|
|
|
|
- name: Install Docker Compose
|
|
|
|
run: |
|
2025-01-04 19:06:51 +01:00
|
|
|
sudo curl -SL "https://github.com/docker/compose/releases/download/v2.32.1/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
|
2024-08-16 12:00:10 +02:00
|
|
|
sudo chmod +x /usr/local/bin/docker-compose
|
|
|
|
|
|
|
|
- name: Set up Python
|
2024-12-21 13:28:35 +01:00
|
|
|
uses: actions/setup-python@0b93645e9fea7318ecaed2b359559ac225c90a2b # v5.3.0
|
2024-08-16 12:00:10 +02:00
|
|
|
with:
|
2024-12-16 21:59:47 +01:00
|
|
|
python-version: "3.12"
|
2024-08-18 14:07:14 +02:00
|
|
|
|
2024-08-16 12:00:10 +02:00
|
|
|
- name: Pip requirements
|
|
|
|
run: |
|
2025-01-08 21:16:13 +01:00
|
|
|
pip install --require-hashes -r ./cucumber/requirements.txt
|
2024-08-18 14:07:14 +02:00
|
|
|
|
2024-08-16 12:00:10 +02:00
|
|
|
- name: Run Docker Compose Tests
|
|
|
|
run: |
|
|
|
|
chmod +x ./test.sh
|
|
|
|
./test.sh
|