summaryrefslogtreecommitdiff
path: root/.github/workflows/codeql-analysis.yml
blob: 887ea45d57d05a4c42d9fff767d233677d31a339 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
---
# vi: ts=2 sw=2 et:
# SPDX-License-Identifier: LGPL-2.1-or-later
#
name: "CodeQL"

on:
  pull_request:
    branches: [main]
    paths:
      - .github/codeql-config.yml
      - .github/codeql-custom.qls
      - .github/workflows/codeql-analysis.yml
      - .github/workflows/requirements.txt
      - .github/workflows/unit_tests.sh
  # It takes the workflow approximately 30 minutes to analyze the code base
  # so it doesn't seem to make much sense to trigger it on every PR or commit.
  # It runs daily at 01:00 to avoid colliding with the Coverity workflow.
  schedule:
    - cron: '0 1 * * *'

permissions:
  contents: read

jobs:
  analyze:
    name: Analyze
    runs-on: ubuntu-latest
    concurrency:
      group: ${{ github.workflow }}-${{ matrix.language }}-${{ github.ref }}
      cancel-in-progress: true
    permissions:
      actions: read
      security-events: write

    strategy:
      fail-fast: false
      matrix:
        language: [ 'cpp', 'python' ]

    steps:
    - name: Checkout repository
      uses: actions/checkout@a12a3943b4bdde767164f792f33f40b04645d846

    - name: Initialize CodeQL
      uses: github/codeql-action/init@28eead240834b314f7def40f6fcba65d100d99b1
      with:
        languages: ${{ matrix.language }}
        config-file: ./.github/codeql-config.yml

    - run: sudo -E .github/workflows/unit_tests.sh SETUP

    - name: Autobuild
      uses: github/codeql-action/autobuild@28eead240834b314f7def40f6fcba65d100d99b1

    - name: Perform CodeQL Analysis
      uses: github/codeql-action/analyze@28eead240834b314f7def40f6fcba65d100d99b1