name: Coverage on: pull_request: push: paths-ignore: - '.github/workflows/linux-build.yml' - '.github/workflows/macos-build.yml' - '.github/workflows/msys2-build.yml' - '.github/workflows/wasm-build.yml' - '.github/workflows/windows-build.yml' - '.gitignore' - 'LICENSE' - 'CHANGELOG.md' - 'README.md' - 'README_en.md' - 'README_fr.md' jobs: build: strategy: matrix: config: - { name: "Windows", os: windows-latest, arch: x64 } - { name: "Ubuntu", os: ubuntu-latest, arch: x86_64 } name: ${{ matrix.config.name }} runs-on: ${{ matrix.config.os }} if: ${{ !contains(github.event.head_commit.message, 'coverage skip') }} steps: - name: Get current date as package key id: cache_key run: echo "key=$(date +'%W')" >> $GITHUB_OUTPUT shell: bash - name: Checkout repository uses: actions/checkout@v4 # Install system dependencies - name: Install system dependencies (Linux) if: runner.os == 'Linux' run: | sudo apt-get update sudo apt-get -y install mesa-common-dev gcovr - name: Install OpenCppCoverage (Windows) if: runner.os == 'Windows' run: | choco install -y OpenCppCoverage # Force xmake to a specific folder (for cache) - name: Set xmake env (Linux) if: runner.os == 'Linux' run: echo "XMAKE_GLOBALDIR=${{ runner.workspace }}/xmake-global" >> $GITHUB_ENV - name: Set xmake env (Windows) if: runner.os == 'Windows' run: echo "XMAKE_GLOBALDIR=${{ runner.workspace }}/xmake-global" | Out-File -FilePath $env:GITHUB_ENV -Encoding utf8 -Append # Install xmake - name: Setup xmake uses: xmake-io/github-action-setup-xmake@v1 with: xmake-version: branch@dev actions-cache-folder: .xmake-cache-W${{ steps.cache_key.outputs.key }} # Update xmake repository (in order to have the file that will be cached) - name: Update xmake repository run: xmake repo --update # Fetch xmake dephash - name: Retrieve dependencies hash id: dephash run: echo "hash=$(xmake l utils.ci.packageskey)" >> $GITHUB_OUTPUT shell: bash # Cache xmake dependencies - name: Restore cached xmake dependencies id: restore-depcache uses: actions/cache/restore@v4 with: path: ${{ env.XMAKE_GLOBALDIR }}/.xmake/packages key: ${{ matrix.config.name}}-${{ matrix.config.arch }}-coverage-${{ steps.dephash.outputs.hash }}-W${{ steps.cache_key.outputs.key }} # Setup compilation mode and install project dependencies - name: Configure xmake and install dependencies run: xmake config --arch=${{ matrix.config.arch }} --mode=coverage --ccache=n --ffmpeg=y --shadernodes=y --tests=y --unitybuild=y --yes # Save dependencies - name: Save cached xmake dependencies if: ${{ !steps.restore-depcache.outputs.cache-hit }} uses: actions/cache/save@v4 with: path: ${{ env.XMAKE_GLOBALDIR }}/.xmake/packages key: ${{ steps.restore-depcache.outputs.cache-primary-key }} # Cache assets downloading - name: Restore cached assets id: restore-assets uses: actions/cache/restore@v4 with: path: assets key: assets-${{ hashFiles('assets/examples_version.txt', 'assets/unittests_version.txt') }} # Build the engine - name: Build Nazara run: xmake --yes - name: Save downloaded assets if: ${{ !steps.restore-assets.outputs.cache-hit }} uses: actions/cache/save@v4 with: path: assets key: ${{ steps.restore-assets.outputs.cache-primary-key }} # Run unit tests to generate coverage reports - name: Run unit tests and generate coverage output (Linux) if: runner.os == 'Linux' run: | xmake run UnitTests gcovr -x coverage.out -s -f 'include/Nazara/.*' -f 'src/Nazara/.*' build/.objs/ - name: Run unit tests and generate coverage output (Windows) if: runner.os == 'Windows' shell: cmd run: | "C:\Program Files\OpenCppCoverage\OpenCppCoverage.exe" --export_type cobertura:coverage.out --sources "NazaraEngine\include\Nazara\*" --sources "NazaraEngine\src\Nazara\*" --modules "NazaraEngine\bin\*" --cover_children -- xmake run UnitTests - name: Upload Coverage Report to Codecov uses: codecov/codecov-action@v4 with: files: ./coverage.out fail_ci_if_error: true token: ${{ secrets.CODECOV_TOKEN }}