diff --git a/.github/workflows/rust-clippy.yml b/.github/workflows/rust-clippy.yml new file mode 100644 index 0000000..4332913 --- /dev/null +++ b/.github/workflows/rust-clippy.yml @@ -0,0 +1,62 @@ +--- + +# This workflow uses actions that are not certified by GitHub. +# They are provided by a third-party and are governed by +# separate terms of service, privacy policy, and support +# documentation. +# rust-clippy is a tool that runs a bunch of lints to catch common +# mistakes in your Rust code and help improve your Rust code. +# More details at https://github.com/rust-lang/rust-clippy +# and https://rust-lang.github.io/rust-clippy/ + +name: rust-clippy analyze + +on: # yamllint disable-line rule:truthy + push: + branches: ["main", "develop", "feature/*"] + pull_request: + # The branches below must be a subset of the branches above + branches: ["main"] + schedule: + - cron: '38 4 * * 0' + +jobs: + rust-clippy-analyze: + name: Run rust-clippy analyzing + runs-on: ubuntu-latest + permissions: + contents: read + security-events: write + # only required for a private repository + # by github/codeql-action/upload-sarif to get the Action run status + actions: read + steps: + - name: Checkout code + uses: actions/checkout@v4 + + - name: Install Rust toolchain + # @v1 + uses: actions-rs/toolchain@16499b5e05bf2e26879000db0c1d13f7e13fa3af + with: + profile: minimal + toolchain: stable + components: clippy + override: true + + - name: Install required cargo + run: cargo install clippy-sarif sarif-fmt + + # yamllint disable rule:line-length + - name: Run rust-clippy + run: > + cargo clippy + --all-features + --message-format=json | clippy-sarif | tee rust-clippy-results.sarif | sarif-fmt + continue-on-error: true + # yamllint enable rule:line-length + + - name: Upload analysis results to GitHub + uses: github/codeql-action/upload-sarif@v3 + with: + sarif_file: rust-clippy-results.sarif + wait-for-processing: true