diff --git a/.github/workflows/third_party_checks.yml b/.github/workflows/third_party_checks.yml new file mode 100644 index 0000000..63756ff --- /dev/null +++ b/.github/workflows/third_party_checks.yml @@ -0,0 +1,83 @@ +--- +name: third_party_checks + +'on': + workflow_dispatch: + push: + branches: + - main + pull_request: + +jobs: + generate_and_upload_coverage_data: + name: generate_and_upload_coverage_data + runs-on: ubuntu-latest + steps: + - name: Checkout + uses: actions/checkout@v4 + with: + fetch-depth: 0 + + - name: Validate codecov.yml file + run: | + ./validate_codecov_yml.sh + - name: Set up Python + uses: actions/setup-python@v5 + with: + python-version: "3.10" + + - name: Install dependencies + run: | + curl -sSL https://install.python-poetry.org | python3 - + poetry install --with dev + + - name: Generate coverage data + run: | + ./generate_coverage_data.sh + + - name: Fix code coverage paths for SonarCloud + # yamllint disable rule:line-length + run: | + cp coverage.xml coverage_for_sonarcloud.xml + sed -i 's/\/home\/runner\/work\/puzzle_generator\/puzzle_generator/\/github\/workspace/g' coverage_for_sonarcloud.xml + # yamllint enable rule:line-length + + - name: SonarCloud Scan + if: "! github.event.pull_request.head.repo.fork " + uses: SonarSource/sonarcloud-github-action@v2 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }} + + - name: Upload coverage report to Codecov + if: "! github.event.pull_request.head.repo.fork " + uses: codecov/codecov-action@v4 + with: + token: ${{ secrets.CODECOV_TOKEN }} + fail_ci_if_error: true + + - name: Upload coverage report to Codecov (tokenless) + if: >- + github.event_name == 'pull_request' && + github.event.pull_request.head.repo.full_name != github.repository + uses: codecov/codecov-action@v4 + with: + fail_ci_if_error: true + + - name: Upload coverage report to Codacy + if: "! github.event.pull_request.head.repo.fork " + uses: codacy/codacy-coverage-reporter-action@v1 + with: + project-token: ${{ secrets.CODACY_PROJECT_TOKEN }} + coverage-reports: coverage.xml + + - name: Upload coverage report as an artifact + uses: actions/upload-artifact@v4 + with: + name: coverage_report + path: | + coverage.xml + htmlcov + if-no-files-found: error + retention-days: 5 +... diff --git a/codecov.yml b/codecov.yml new file mode 100644 index 0000000..514344e --- /dev/null +++ b/codecov.yml @@ -0,0 +1,4 @@ +--- +ignore: + - 'tests' +... diff --git a/generate_coverage_data.sh b/generate_coverage_data.sh new file mode 100755 index 0000000..a403d9b --- /dev/null +++ b/generate_coverage_data.sh @@ -0,0 +1,11 @@ +#!/usr/bin/env bash + +set -euo pipefail + +omitted_paths="tests/*" +readonly omitted_paths + +poetry run coverage run --branch -m pytest +poetry run coverage xml --omit="${omitted_paths}" +poetry run coverage html --omit="${omitted_paths}" +poetry run coverage report --omit="${omitted_paths}" diff --git a/sonar-project.properties b/sonar-project.properties new file mode 100644 index 0000000..c0d0334 --- /dev/null +++ b/sonar-project.properties @@ -0,0 +1,7 @@ +sonar.projectKey=vil02_puzzle_generator +sonar.organization=vil02 + +sonar.exclusions=coverage_for_sonarcloud.xml +sonar.coverage.exclusions=**/tests/** +sonar.python.coverage.reportPaths=coverage_for_sonarcloud.xml +sonar.python.version=3.10, 3.11 diff --git a/validate_codecov_yml.sh b/validate_codecov_yml.sh new file mode 100644 index 0000000..0070d1b --- /dev/null +++ b/validate_codecov_yml.sh @@ -0,0 +1,10 @@ +#!/usr/bin/env bash + +set -euo pipefail + +status=$(curl -s -X POST --data-binary @codecov.yml https://codecov.io/validate) +if [[ "${status}" == *Error* ]]; +then + printf "%s\n" "${status}" + exit 1 +fi