Replace system test docker on windows with process #231
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: system-test | |
on: | |
push: | |
workflow_dispatch: | |
jobs: | |
waitForNative: | |
uses: ./.github/workflows/buildNative.yml | |
buildMockserver: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
name: "Check out source" | |
with: | |
# Check out last 15 commits | |
fetch-depth: 15 | |
- name: "Get changed files in core module" | |
id: changed-files-specific | |
uses: tj-actions/changed-files@v35 | |
with: | |
since_last_remote_commit: true | |
files: | | |
other/mockserver/** | |
- if: steps.changed-files-specific.outputs.any_changed == 'true' | |
run: | | |
echo "::notice::Will build new mock server container. Changed files since last push:" | |
echo "${{ steps.changed-files-specific.outputs.all_changed_files }}" | |
- if: steps.changed-files-specific.outputs.any_changed == 'false' | |
run: | | |
echo "::notice::Will skip build of new mock server container. No changed files since last push." | |
- name: Set up JDK 17 | |
if: steps.changed-files-specific.outputs.any_changed == 'true' | |
uses: actions/setup-java@v3 | |
with: | |
java-version: '17' | |
distribution: 'adopt' | |
cache: 'maven' | |
- name: "Login to GitHub Container Registry" | |
if: steps.changed-files-specific.outputs.any_changed == 'true' | |
uses: docker/login-action@v2 | |
with: | |
registry: ghcr.io | |
username: ${{ github.actor }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: "Build and push mockserver container" | |
if: steps.changed-files-specific.outputs.any_changed == 'true' | |
run: | | |
mvn --batch-mode install -DskipTests -T 1C | |
cd other/mockserver/ | |
mvn --batch-mode spring-boot:build-image | |
docker tag mockserver:3.1.0 ghcr.io/theotherp/mockserver:3.1.0 | |
docker push ghcr.io/theotherp/mockserver:3.1.0 | |
runSystemTestsLinux: | |
needs: [ waitForNative, buildMockserver ] | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
test: [ { port: 5076, name: core }, { port: 5077, name: v1Migration } ] | |
env: | |
spring_profiles_active: build,systemtest,${{ matrix.test.name }} | |
nzbhydra_port: ${{ matrix.test.port }} | |
nzbhydra.port: ${{ matrix.test.port }} | |
nzbhydra_name: ${{ matrix.test.name }} | |
NZBHYDRANAME: ${{ matrix.test.name }} | |
nzbhydra.name: ${{ matrix.test.name }} | |
steps: | |
- run: echo Running test ${{ matrix.test.name }} with port ${{ matrix.test.port }} | |
- uses: actions/checkout@v3 | |
name: "Check out source" | |
- name: Set up JDK 17 | |
uses: actions/setup-java@v3 | |
with: | |
java-version: '17' | |
distribution: 'adopt' | |
cache: 'maven' | |
- name: "Install maven" | |
run: mvn --batch-mode clean install -DskipTests -pl org.nzbhydra:nzbhydra2,org.nzbhydra:shared,org.nzbhydra:mapping,org.nzbhydra:assertions | |
- name: "Create docker network" | |
run: docker network create systemtest | |
- name: "Copy v1Migration docker data" | |
run: | | |
mkdir -p /tmp/hydra/v1MigrationDataFolder | |
cp -R tests/system/instanceData/v1Migration/* /tmp/hydra/v1MigrationDataFolder/ | |
- name: "Run docker compose" | |
run: | | |
cd docker/docker-compose-systemtest/linux | |
docker-compose up -d | |
cd ../../.. | |
- name: "Wait for healthy containers" | |
run: | | |
docker ps | |
sleep 10 | |
docker ps | |
sleep 10 | |
docker ps | |
echo "Core container mounts:" | |
docker container inspect -f '{{ .Mounts}}' core | |
echo "v1Migration container mounts:" | |
docker container inspect -f '{{ .Mounts}}' v1Migration | |
- name: "Run tests" | |
run: mvn --batch-mode test -pl org.nzbhydra.tests:system -DtrimStackTrace=false | |
- name: "Write docker-compose logs" | |
if: always() | |
run: | | |
cd docker/docker-compose-systemtest/linux | |
echo "Writing docker compose logs to files" | |
docker-compose logs --no-color radarr > docker-compose-radarr.log | |
docker-compose logs --no-color sonarr > docker-compose-sonarr.log | |
docker-compose logs --no-color mockserver > docker-compose-mockserver.log | |
docker-compose logs --no-color core > docker-compose-core.log | |
docker-compose logs --no-color v1Migration > docker-compose-v1Migration.log | |
echo "Found log files:" | |
find . -name "*.log" | |
cd ../../.. | |
- name: "Truncate large log files" | |
if: always() | |
# If the logs are larger than 1MB there's probably something wrong | |
run: | | |
shopt -s globstar | |
for d in ./**/*.log ; do (truncate --size=1M $d); done | |
- name: "Upload data folder artifact" | |
uses: actions/upload-artifact@v3 | |
if: always() | |
with: | |
name: dataLinux | |
path: /tmp/hydra | |
- name: "Upload test logs artifact" | |
uses: actions/upload-artifact@v3 | |
if: always() | |
with: | |
name: ${{ matrix.test.name }}-test-logs | |
path: tests/**/*.log | |
- name: "Upload docker logs artifact" | |
uses: actions/upload-artifact@v3 | |
if: always() | |
with: | |
name: ${{ matrix.test.name }}-docker-logs | |
path: docker/docker-compose-systemtest/linux/*.log | |
- name: "Create test Report" | |
uses: dorny/test-reporter@v1 | |
if: always() | |
continue-on-error: true | |
with: | |
name: System test report ${{ matrix.test.name }} | |
path: "**/surefire-reports/*.xml" | |
reporter: java-junit | |
runSystemTestsWindows: | |
needs: [ waitForNative, buildMockserver ] | |
runs-on: windows-latest | |
env: | |
spring_profiles_active: build,systemtest,core | |
nzbhydra_port: 5076 | |
nzbhydra.port: 5076 | |
nzbhydra_name: windows | |
NZBHYDRANAME: windows | |
nzbhydra.name: windows | |
steps: | |
- uses: actions/checkout@v3 | |
name: "Check out source" | |
- name: "Download windows artifact (from this or previous workflow)" | |
uses: dawidd6/action-download-artifact@v2 | |
with: | |
name: coreWindows | |
- name: "Start NZBHydra" | |
# Produces "The specified executable is not a valid application for this OS platform." on GH runner. | |
# Start-Process .\NZBHydra2.exe | |
run: | | |
$Env:SPRING_PROFILES_ACTIVE= "build,systemtest,core" | |
Start-Process .\core.exe directstart | |
- name: Set up JDK 17 | |
uses: actions/setup-java@v3 | |
with: | |
java-version: '17' | |
distribution: 'adopt' | |
cache: 'maven' | |
- name: "Install maven" | |
run: mvn --batch-mode clean install -DskipTests -pl org.nzbhydra:nzbhydra2,org.nzbhydra:shared,org.nzbhydra:mapping,org.nzbhydra:assertions,org.nzbhydra:mockserver | |
- name: "Start Mockserver" | |
run: | | |
$Env:SPRING_PROFILES_ACTIVE= "build,systemtest" | |
copy other/mockserver/target/*-exec.jar other/mockserver/target/exec.jar | |
Start-Process java -ArgumentList "-jar other/mockserver/target/exec.jar" | |
- name: "Run tests" | |
run: mvn --batch-mode test -pl org.nzbhydra.tests:system -DtrimStackTrace=false | |
- name: "Upload data folder artifact" | |
uses: actions/upload-artifact@v3 | |
if: always() | |
with: | |
name: dataWindows | |
path: data | |
- name: "Upload test logs artifact" | |
uses: actions/upload-artifact@v3 | |
if: always() | |
with: | |
name: windows-test-logs | |
path: tests/**/*.log | |
- name: "Upload docker logs artifact" | |
uses: actions/upload-artifact@v3 | |
if: always() | |
with: | |
name: windows-docker-logs | |
path: docker/*.log | |
- name: "Create test Report" | |
uses: dorny/test-reporter@v1 | |
if: always() | |
continue-on-error: true | |
with: | |
name: System test report windows | |
path: "**/surefire-reports/*.xml" | |
reporter: java-junit |