X-Git-Url: https://jxself.org/git/?a=blobdiff_plain;f=.github%2Fworkflows%2Fmain.yml;h=70a0be583c1956bcf83335714b3ec842d9c9b754;hb=e3503e95d12774be3d7ac2d555d65e8499a79881;hp=86cac64198fd056213ae3fb1577729d94ad0a847;hpb=52caf95cdfdd25f1e49554068b26a2c0c0332026;p=kconfig-hardened-check.git diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 86cac64..70a0be5 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -15,7 +15,7 @@ jobs: max-parallel: 4 fail-fast: false matrix: - python-version: [3.6, 3.7, 3.8] + python-version: [3.6, 3.7, 3.8, 3.9] # github runner with python 3.5 currently fails to install this package steps: @@ -30,13 +30,14 @@ jobs: python -m pip install --upgrade pip pip install coverage pip --verbose install git+https://github.com/a13xp0p0v/kconfig-hardened-check + echo ">>>>> first start <<<<<" kconfig-hardened-check - - name: Check all configs + - name: Check all configs with the installed tool run: | echo ">>>>> check all configs <<<<<" CONFIG_DIR=`find /opt/hostedtoolcache/Python/ -name config_files` - CONFIGS=`find $CONFIG_DIR -type f|grep "\.config"` + CONFIGS=`find $CONFIG_DIR -type f | grep "\.config"` COUNT=0 for C in $CONFIGS do @@ -46,37 +47,53 @@ jobs: done echo -e "\n>>>>> checking $COUNT configs is done <<<<<" - - name: Get source code + - name: Get source code for collecting coverage uses: actions/checkout@v2 - - name: Collect coverage + - name: Collect coverage for the basic functionality run: | + echo ">>>>> get help <<<<<" coverage run -a --branch bin/kconfig-hardened-check + coverage run -a --branch bin/kconfig-hardened-check -h + echo ">>>>> get version <<<<<" + coverage run -a --branch bin/kconfig-hardened-check --version + + echo ">>>>> print the security hardening preferences <<<<<" coverage run -a --branch bin/kconfig-hardened-check -p X86_64 - coverage run -a --branch bin/kconfig-hardened-check -p X86_64 --debug - coverage run -a --branch bin/kconfig-hardened-check -p X86_64 --json + coverage run -a --branch bin/kconfig-hardened-check -p X86_64 -m verbose + coverage run -a --branch bin/kconfig-hardened-check -p X86_64 -m json coverage run -a --branch bin/kconfig-hardened-check -p X86_32 - coverage run -a --branch bin/kconfig-hardened-check -p X86_32 --debug - coverage run -a --branch bin/kconfig-hardened-check -p X86_32 --json + coverage run -a --branch bin/kconfig-hardened-check -p X86_32 -m verbose + coverage run -a --branch bin/kconfig-hardened-check -p X86_32 -m json coverage run -a --branch bin/kconfig-hardened-check -p ARM64 - coverage run -a --branch bin/kconfig-hardened-check -p ARM64 --debug - coverage run -a --branch bin/kconfig-hardened-check -p ARM64 --json + coverage run -a --branch bin/kconfig-hardened-check -p ARM64 -m verbose + coverage run -a --branch bin/kconfig-hardened-check -p ARM64 -m json coverage run -a --branch bin/kconfig-hardened-check -p ARM - coverage run -a --branch bin/kconfig-hardened-check -p ARM --debug - coverage run -a --branch bin/kconfig-hardened-check -p ARM --json + coverage run -a --branch bin/kconfig-hardened-check -p ARM -m verbose + coverage run -a --branch bin/kconfig-hardened-check -p ARM -m json - CONFIG_DIR=`find /opt/hostedtoolcache/Python/ -name config_files` - CONFIGS=`find $CONFIG_DIR -type f|grep "\.config"` + echo ">>>>> use local cmdline as an example <<<<<" + cat /proc/cmdline + + echo ">>>>> check the example kconfig files and cmdline <<<<<" + CONFIG_DIR=`find . -name config_files` + CONFIGS=`find $CONFIG_DIR -type f | grep "\.config"` + COUNT=0 for C in $CONFIGS do - coverage run -a --branch bin/kconfig-hardened-check -c $C - coverage run -a --branch bin/kconfig-hardened-check -c $C --debug - coverage run -a --branch bin/kconfig-hardened-check -c $C --json + COUNT=$(expr $COUNT + 1) + echo -e "\n>>>>> checking config number $COUNT <<<<<" + coverage run -a --branch bin/kconfig-hardened-check -c $C -l /proc/cmdline + coverage run -a --branch bin/kconfig-hardened-check -c $C -l /proc/cmdline -m verbose > /dev/null + coverage run -a --branch bin/kconfig-hardened-check -c $C -l /proc/cmdline -m json + coverage run -a --branch bin/kconfig-hardened-check -c $C -l /proc/cmdline -m show_ok + coverage run -a --branch bin/kconfig-hardened-check -c $C -l /proc/cmdline -m show_fail done + echo -e "\n>>>>> checking $COUNT configs is done <<<<<" coverage xml -i -o coverage.xml - name: Handle coverage