Skip to content

Commit bd30602

Browse files
committed
CI: refresh CodeQL action
1 parent 53c7bb2 commit bd30602

File tree

1 file changed

+61
-37
lines changed

1 file changed

+61
-37
lines changed

.github/workflows/codeql-analysis.yml

Lines changed: 61 additions & 37 deletions
Original file line numberDiff line numberDiff line change
@@ -9,51 +9,60 @@
99
# the `language` matrix defined below to confirm you have the correct set of
1010
# supported CodeQL languages.
1111
#
12-
name: "CodeQL"
12+
name: "CodeQL Advanced"
1313

1414
on:
1515
push:
16-
branches: [ main ]
16+
branches: [ "main" ]
1717
paths-ignore:
1818
- 'doc/**'
1919
pull_request:
2020
# The branches below must be a subset of the branches above
21-
branches: [ main ]
21+
branches: [ "main" ]
2222
paths-ignore:
2323
- 'doc/**'
2424
schedule:
25-
- cron: '17 21 * * 2'
25+
- cron: '23 23 * * 1'
2626

2727
jobs:
2828
analyze:
29-
name: Analyze
30-
runs-on: ubuntu-24.04
29+
name: Analyze (${{ matrix.language }})
30+
# Runner size impacts CodeQL analysis time. To learn more, please see:
31+
# - https://gh.io/recommended-hardware-resources-for-running-codeql
32+
# - https://gh.io/supported-runners-and-hardware-resources
33+
# - https://gh.io/using-larger-runners (GitHub.com only)
34+
# Consider using larger runners or machines with greater resources for possible analysis time improvements.
35+
runs-on: ${{ (matrix.language == 'swift' && 'macos-latest') || 'ubuntu-24.04' }}
3136
permissions:
37+
# required for all workflows
38+
security-events: write
39+
40+
# required to fetch internal or private CodeQL packs
41+
packages: read
42+
43+
# only required for workflows in private repositories
3244
actions: read
3345
contents: read
34-
security-events: write
3546

3647
strategy:
3748
fail-fast: false
3849
matrix:
39-
language: [ 'cpp', 'python' ]
40-
# CodeQL supports [ 'cpp', 'csharp', 'go', 'java', 'javascript', 'python' ]
41-
# Learn more:
42-
# https://docs.github.com/en/free-pro-team@latest/github/finding-security-vulnerabilities-and-errors-in-your-code/configuring-code-scanning#changing-the-languages-that-are-analyzed
43-
50+
include:
51+
- language: c-cpp
52+
build-mode: autobuild
53+
- language: python
54+
build-mode: none
55+
# CodeQL supports the following values keywords for 'language': 'c-cpp', 'csharp', 'go', 'java-kotlin', 'javascript-typescript', 'python', 'ruby', 'swift'
56+
# Use `c-cpp` to analyze code written in C, C++ or both
57+
# Use 'java-kotlin' to analyze code written in Java, Kotlin or both
58+
# Use 'javascript-typescript' to analyze code written in JavaScript, TypeScript or both
59+
# To learn more about changing the languages that are analyzed or customizing the build mode for your analysis,
60+
# see https://docs.github.com/en/code-security/code-scanning/creating-an-advanced-setup-for-code-scanning/customizing-your-advanced-setup-for-code-scanning.
61+
# If you are analyzing a compiled language, you can modify the 'build-mode' for that language to customize how
62+
# your codebase is analyzed, see https://docs.github.com/en/code-security/code-scanning/creating-an-advanced-setup-for-code-scanning/codeql-code-scanning-for-compiled-languages
4463
steps:
4564
- name: Checkout repository
46-
uses: actions/checkout@v3
47-
48-
# Initializes the CodeQL tools for scanning.
49-
- name: Initialize CodeQL
50-
uses: github/codeql-action/init@v2
51-
with:
52-
languages: ${{ matrix.language }}
53-
# If you wish to specify custom queries, you can do so here or in a config file.
54-
# By default, queries listed here will override any specified in a config file.
55-
# Prefix the list here with "+" to use these queries and those in the config file.
56-
# queries: ./path/to/local/query, your-org/your-repo/queries@main
65+
uses: actions/checkout@v4
5766

5867
# Installs the build dependencies
5968
- name: Install build depends
@@ -63,21 +72,36 @@ jobs:
6372
sudo apt install meson python3-coverage python3-pytest python3-pytest-cov libcmocka-dev python3-cffi libpython3-dev
6473
sudo apt build-dep netplan.io
6574
66-
# Autobuild attempts to build any compiled languages (C/C++, C#, or Java).
67-
# If this step fails, then you should remove it and run the build manually (see below)
68-
- name: Autobuild
69-
uses: github/codeql-action/autobuild@v2
70-
71-
# ℹ️ Command-line programs to run using the OS shell.
72-
# 📚 https://git.io/JvXDl
75+
# Initializes the CodeQL tools for scanning.
76+
- name: Initialize CodeQL
77+
uses: github/codeql-action/init@v3
78+
with:
79+
languages: ${{ matrix.language }}
80+
build-mode: ${{ matrix.build-mode }}
81+
# If you wish to specify custom queries, you can do so here or in a config file.
82+
# By default, queries listed here will override any specified in a config file.
83+
# Prefix the list here with "+" to use these queries and those in the config file.
7384

74-
# ✏️ If the Autobuild fails above, remove it and uncomment the following three lines
75-
# and modify them (or add more) to build your code if your project
76-
# uses a compiled language
85+
# For more details on CodeQL's query packs, refer to: https://docs.github.com/en/code-security/code-scanning/automatically-scanning-your-code-for-vulnerabilities-and-errors/configuring-code-scanning#using-queries-in-ql-packs
86+
# queries: security-extended,security-and-quality
7787

78-
#- run: |
79-
# make bootstrap
80-
# make release
88+
# If the analyze step fails for one of the languages you are analyzing with
89+
# "We were unable to automatically build your code", modify the matrix above
90+
# to set the build mode to "manual" for that language. Then modify this step
91+
# to build your code.
92+
# ℹ️ Command-line programs to run using the OS shell.
93+
# 📚 See https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#jobsjob_idstepsrun
94+
- if: matrix.build-mode == 'manual'
95+
shell: bash
96+
run: |
97+
echo 'If you are using a "manual" build mode for one or more of the' \
98+
'languages you are analyzing, replace this with the commands to build' \
99+
'your code, for example:'
100+
echo ' make bootstrap'
101+
echo ' make release'
102+
exit 1
81103
82104
- name: Perform CodeQL Analysis
83-
uses: github/codeql-action/analyze@v2
105+
uses: github/codeql-action/analyze@v3
106+
with:
107+
category: "/language:${{matrix.language}}"

0 commit comments

Comments
 (0)