-
Notifications
You must be signed in to change notification settings - Fork 0
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
chore: Update .github/workflows/code-coverage.yaml
in artichoke/roe
#202
Merged
lopopolo
merged 1 commit into
trunk
from
terraform/update-file-.github-workflows-code-coverage.yaml
Feb 2, 2025
Merged
chore: Update .github/workflows/code-coverage.yaml
in artichoke/roe
#202
lopopolo
merged 1 commit into
trunk
from
terraform/update-file-.github-workflows-code-coverage.yaml
Feb 2, 2025
Conversation
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
Managed by Terraform. ## Contents ``` --- name: Code Coverage "on": push: branches: - trunk pull_request: branches: - trunk jobs: generate: name: Generate permissions: id-token: write contents: read runs-on: ubuntu-latest env: RUST_BACKTRACE: 1 CARGO_NET_GIT_FETCH_WITH_CLI: true CARGO_REGISTRIES_CRATES_IO_PROTOCOL: sparse steps: - name: Checkout repository uses: actions/[email protected] with: persist-credentials: false - name: Install nightly Rust toolchain uses: artichoke/setup-rust/[email protected] - name: Setup grcov run: | release_url="$(curl \ --url https://api.github.com/repos/mozilla/grcov/releases \ --header 'authorization: Bearer ${{ secrets.GITHUB_TOKEN }}' \ --header 'content-type: application/json' \ --silent \ --fail \ --retry 5 \ | jq -r '.[0].assets | map(select(.browser_download_url | test(".*x86_64-unknown-linux-musl.tar.bz2$"))) | .[0].browser_download_url' )" curl -sL "$release_url" | sudo tar xvj -C /usr/local/bin/ - name: Show grcov version run: grcov --version - name: Generate coverage env: LLVM_PROFILE_FILE: "roe-%m-%p.profraw" RUSTFLAGS: "-C instrument-coverage" # Unstable feature: `--persist-doctests`: persist doctest executables after running # https://rustwiki.org/en/rustdoc/unstable-features.html#--persist-doctests-persist-doctest-executables-after-running # # Used to allow grcov to use these sources to generate coverage metrics. RUSTDOCFLAGS: "-C instrument-coverage -Z unstable-options --persist-doctests target/debug/doctests" run: cargo test - name: Generate HTML report run: grcov roe*.profraw --source-dir . --keep-only 'src/**/*.rs' --binary-path target/debug -t html --filter covered -o target/coverage - name: Generate detailed JSON report run: grcov roe*.profraw --source-dir . --keep-only 'src/**/*.rs' --binary-path target/debug -t covdir --filter covered -o target/coverage/coverage.json - name: Configure AWS Credentials uses: aws-actions/configure-aws-credentials@4fc4975 # v4.0.3 if: github.ref == 'refs/heads/trunk' with: aws-region: us-west-2 role-to-assume: arn:aws:iam::447522982029:role/gha-roe-s3-backup-20220820215201568000000007 role-session-name: GitHubActionsRustCodeCoverage@roe - name: Show AWS caller identity if: github.ref == 'refs/heads/trunk' run: aws sts get-caller-identity - name: Upload archives to S3 if: github.ref == 'refs/heads/trunk' run: | aws s3 sync target/coverage/ s3://artichoke-forge-code-coverage-us-west-2/roe/ --delete --sse AES256 --exclude '*' --include '*.svg' --content-type 'image/svg+xml' aws s3 sync target/coverage/ s3://artichoke-forge-code-coverage-us-west-2/roe/ --delete --sse AES256 --exclude '*' --include '*.html' --content-type 'text/html' aws s3 sync target/coverage/ s3://artichoke-forge-code-coverage-us-west-2/roe/ --delete --sse AES256 --exclude '*' --include '*.json' --content-type 'application/json' aws s3 sync target/coverage/ s3://artichoke-forge-code-coverage-us-west-2/roe/ --delete --sse AES256 --include '*' --exclude '*.svg' --exclude '*.html' --exclude '*.json' - name: Check missed lines shell: python env: GITHUB_REF_NAME: ${{ github.ref_name }} GITHUB_EVENT_NAME: ${{ github.event_name }} GITHUB_EVENT_NUMBER: ${{ github.event.number }} run: | import json import os from urllib.request import urlopen trunk_coverage_url = "https://codecov.artichokeruby.org/roe/coverage.json" def print_report(coverage, *, on=None): if on is None: raise ValueError("must provide `on` kwarg") print(f"On {on}:") print("coveragePercent =", coverage["coveragePercent"]) print("linesCovered =", coverage["linesCovered"]) print("linesMissed =", coverage["linesMissed"]) print("linesTotal =", coverage["linesTotal"]) print("") if os.environ.get("GITHUB_REF_NAME") == "trunk": # We don't need to compare trunk coverage to itself exit(0) with urlopen(trunk_coverage_url, data=None, timeout=3) as remote: trunk_coverage = json.load(remote) print_report(trunk_coverage, on="branch trunk") with open("target/coverage/coverage.json") as local: branch_coverage = json.load(local) on = None if os.environ.get("GITHUB_EVENT_NAME") == "pull_request": on = "PR artichoke/roe#" + os.environ.get("GITHUB_EVENT_NUMBER") print_report(branch_coverage, on=on) is_ok = branch_coverage["linesMissed"] <= trunk_coverage["linesMissed"] exit(0) if is_ok else exit(1) ```
lopopolo
added
A-security
Area: Security vulnerabilities and unsoundness issues.
A-build
Area: CI build infrastructure.
labels
Feb 2, 2025
lopopolo
deleted the
terraform/update-file-.github-workflows-code-coverage.yaml
branch
February 2, 2025 00:05
lopopolo
restored the
terraform/update-file-.github-workflows-code-coverage.yaml
branch
February 2, 2025 00:05
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Labels
A-build
Area: CI build infrastructure.
A-security
Area: Security vulnerabilities and unsoundness issues.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Managed by Terraform.
See zizmor's template-injection lint.
Contents