github actions: Collect coverage for cmdline checking
[kconfig-hardened-check.git] / .github / workflows / main.yml
index 4f36c8d5957d032f9976dd175330b1118a9e9ac9..70a0be583c1956bcf83335714b3ec842d9c9b754 100644 (file)
@@ -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,15 +47,19 @@ 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 -m verbose
         coverage run -a --branch bin/kconfig-hardened-check -p X86_64 -m json
@@ -71,16 +76,24 @@ jobs:
         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 -m verbose
-                coverage run -a --branch bin/kconfig-hardened-check -c $C -m json
-                coverage run -a --branch bin/kconfig-hardened-check -c $C -m show_ok
-                coverage run -a --branch bin/kconfig-hardened-check -c $C -m show_fail
+                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