Skip to content

Create codeql.yml

Create codeql.yml #160

Workflow file for this run

# ------------------------------------------------------------------------------
# <auto-generated>
#
# This code was generated.
#
# - To turn off auto-generation set:
#
# [SonarCloudGitHubActions (AutoGenerate = false)]
#
# - To trigger manual generation invoke:
#
# nuke --generate-configuration GitHubActions_pr --host GitHubActions
#
# </auto-generated>
# ------------------------------------------------------------------------------
name: pr
on:
pull_request:
branches:
- main
jobs:
ubuntu-latest:
name: ubuntu-latest
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
with:
fetch-depth: 0
- name: Setup .Net 6.0.*
uses: actions/setup-dotnet@v3
with:
dotnet-version: 6.0.*
- name: Setup .Net 7.0.*
uses: actions/setup-dotnet@v3
with:
dotnet-version: 7.0.*
- name: Setup JDK (for SonarCloud)
uses: actions/setup-java@v3
with:
distribution: zulu
java-version: 17
- name: Install/Update SonarCloud scanner
run:
dotnet tool update dotnet-sonarscanner --global
- name: Install/Update Coverlet Report Generator (for SonarCloud)
run:
dotnet tool update dotnet-reportgenerator-globaltool --global
- name: Begin SonarCloud scan
run:
dotnet-sonarscanner begin /k:"ebjornset_DryGen" /o:"ebjornset" /d:sonar.login="${{ secrets.SONAR_TOKEN }}" /d:sonar.host.url="https://sonarcloud.io" /d:sonar.coverageReportPaths="./.sonarqubecoverage/SonarQube.xml"
- name: 'Cache: .nuke/temp, ~/.nuget/packages'
uses: actions/cache@v3
with:
path: |
.nuke/temp
~/.nuget/packages
key: ${{ runner.os }}-${{ hashFiles('global.json', 'src/**/*.csproj') }}
- name: 'Run: '
run: ./build.cmd
- name: Check if there are any git changes
id: get_changes
run: echo "::set-output name=changed::$(git status --porcelain | wc -l)"
- name: List any git changes
if: steps.get_changes.outputs.changed != 0
run: git status --porcelain
- name: Display any git diffs
if: steps.get_changes.outputs.changed != 0
run: git diff HEAD
- name: Fail if there are any git changes
if: steps.get_changes.outputs.changed != 0
uses: actions/github-script@v3
with:
script: |
core.setFailed('Git modifications found after <nuke>. Maybe <nuke [docs]> was omitted before commit? Check the output from the step "Display any git diffs" and/or "List any git changes" for details about the detected git changes.')
- name: Run Coverlet Report Generator (for SonarCloud)
run:
reportgenerator "-reports:**/TestResults/**/coverage.cobertura.xml" "-targetdir:.sonarqubecoverage" "-reporttypes:SonarQube"
- name: End SonarCloud scan
run:
dotnet-sonarscanner end /d:sonar.login="${{ secrets.SONAR_TOKEN }}"
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Upload test results artifacts
uses: actions/upload-artifact@v3
if: always()
with:
name: TestResults
retention-days: 30
path: '**/TestResults/**/*'