Merge branch 'config-collection-2' #308
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: functional test | |
on: | |
push: | |
branches: [ master ] | |
jobs: | |
functional_test: | |
if: github.repository == 'a13xp0p0v/kernel-hardening-checker' | |
runs-on: ubuntu-latest | |
strategy: | |
max-parallel: 1 | |
fail-fast: false | |
matrix: | |
python-version: ['3.9', '3.10', '3.11', '3.12', '3.13'] | |
steps: | |
- name: Set up Python ${{ matrix.python-version }} | |
uses: actions/setup-python@v5 | |
with: | |
python-version: ${{ matrix.python-version }} | |
- name: Install package | |
run: | | |
python -m pip install --upgrade pip | |
echo "Install the package via pip..." | |
pip --verbose install git+https://github.com/a13xp0p0v/kernel-hardening-checker | |
echo "Run the installed tool..." | |
kernel-hardening-checker | |
- name: Check all configs with the installed tool | |
run: | | |
echo "Check all configs with the installed tool..." | |
sysctl -a > /tmp/sysctls | |
CONFIG_DIR=`find /opt/hostedtoolcache/Python/ -name config_files` | |
KCONFIGS=`find $CONFIG_DIR -type f | grep -e "\.config" -e "\.gz"` | |
COUNT=0 | |
for C in $KCONFIGS | |
do | |
COUNT=$(expr $COUNT + 1) | |
echo -e "\n>>>>> checking kconfig number $COUNT <<<<<" | |
kernel-hardening-checker -c $C -l /proc/cmdline -s /tmp/sysctls | |
done | |
echo -e "\nHave checked $COUNT kconfigs" | |
- name: Get source code for collecting coverage | |
uses: actions/checkout@v4 | |
- name: Run the functional tests and collect the coverage | |
run: | | |
pip install coverage | |
sh .github/workflows/functional_test.sh | |
- name: Prepare final coverage report | |
run: | | |
coverage xml -i -o coverage.xml | |
- name: Handle coverage | |
uses: codecov/codecov-action@v4 | |
env: | |
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }} | |
with: | |
files: ./coverage.xml | |
flags: functional_test | |
name: functional_test_upload | |
fail_ci_if_error: true | |
verbose: true |