Code quality nightly scan #170
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
name: Code quality nightly scan | |
on: | |
schedule: | |
- cron: '0 4 * * *' | |
workflow_dispatch: | |
env: | |
apt_dependencies: >- | |
ca-certificates curl dconf-cli gcc gettext git libnss-wrapper libsmbclient-dev | |
libkrb5-dev libwbclient-dev pkg-config python3-coverage samba sudo | |
libglib2.0-dev gvfs libpam0g-dev | |
jobs: | |
tics: | |
name: TIOBE TiCS Framework | |
runs-on: ${{ vars.RUNNER }} | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-go@v5 | |
with: | |
go-version-file: go.mod | |
- name: Install dependencies | |
run: | | |
sudo apt-get update | |
sudo DEBIAN_FRONTEND=noninteractive apt-get install -y ${{ env.apt_dependencies }} | |
go install honnef.co/go/tools/cmd/staticcheck@latest | |
dotnet tool install -g dotnet-reportgenerator-globaltool | |
- name: TiCS scan | |
env: | |
TICSAUTHTOKEN: ${{ secrets.TICSAUTHTOKEN }} | |
GH_TOKEN: ${{ github.token }} | |
run: | | |
set -e | |
# Download, combine and move coverage to the right place so TiCS can parse it | |
RUN_ID=$(gh run list --workflow 'QA & sanity checks' --limit 1 --status success --json databaseId -b main | jq '.[].databaseId') | |
gh run download $RUN_ID -n coverage.zip -D /tmp/coverage | |
E2E_RUN_ID=$(gh run list --workflow 'E2E - Run tests' --limit 1 --status success --json databaseId -b main | jq '.[].databaseId') | |
gh run download $E2E_RUN_ID -n pam-coverage.zip -D /tmp/coverage | |
reportgenerator "-reports:/tmp/coverage/*.xml" "-targetdir:.coverage" -reporttypes:Cobertura | |
mv .coverage/Cobertura.xml .coverage/coverage.xml | |
# Install TiCS | |
. <(curl --silent --show-error 'https://canonical.tiobe.com/tiobeweb/TICS/api/public/v1/fapi/installtics/Script?cfg=default&platform=linux&url=https://canonical.tiobe.com/tiobeweb/TICS/') | |
# TiCS requires all artifacts to be built | |
go build ./cmd/... | |
TICSQServer -project adsys -tmpdir /tmp/tics -branchdir . |