12 runs-on: ubuntu-latest
18 python-version: [3.6, 3.7, 3.8, 3.9]
19 # github runner with python 3.5 currently fails to install this package
23 - name: Set up Python ${{ matrix.python-version }}
24 uses: actions/setup-python@v1
26 python-version: ${{ matrix.python-version }}
28 - name: Install package
30 python -m pip install --upgrade pip
32 pip --verbose install git+https://github.com/a13xp0p0v/kconfig-hardened-check
33 echo ">>>>> first start <<<<<"
34 kconfig-hardened-check
36 - name: Check all configs with the installed tool
38 echo ">>>>> check all configs <<<<<"
39 CONFIG_DIR=`find /opt/hostedtoolcache/Python/ -name config_files`
40 CONFIGS=`find $CONFIG_DIR -type f | grep "\.config"`
44 COUNT=$(expr $COUNT + 1)
45 echo -e "\n>>>>> checking config number $COUNT <<<<<"
46 kconfig-hardened-check -c $C
48 echo -e "\n>>>>> checking $COUNT configs is done <<<<<"
50 - name: Get source code for collecting coverage
51 uses: actions/checkout@v2
53 - name: Collect coverage for the basic functionality
55 echo ">>>>> get help <<<<<"
56 coverage run -a --branch bin/kconfig-hardened-check
57 coverage run -a --branch bin/kconfig-hardened-check -h
59 echo ">>>>> get version <<<<<"
60 coverage run -a --branch bin/kconfig-hardened-check --version
62 echo ">>>>> print the security hardening preferences <<<<<"
63 coverage run -a --branch bin/kconfig-hardened-check -p X86_64
64 coverage run -a --branch bin/kconfig-hardened-check -p X86_64 -m verbose
65 coverage run -a --branch bin/kconfig-hardened-check -p X86_64 -m json
67 coverage run -a --branch bin/kconfig-hardened-check -p X86_32
68 coverage run -a --branch bin/kconfig-hardened-check -p X86_32 -m verbose
69 coverage run -a --branch bin/kconfig-hardened-check -p X86_32 -m json
71 coverage run -a --branch bin/kconfig-hardened-check -p ARM64
72 coverage run -a --branch bin/kconfig-hardened-check -p ARM64 -m verbose
73 coverage run -a --branch bin/kconfig-hardened-check -p ARM64 -m json
75 coverage run -a --branch bin/kconfig-hardened-check -p ARM
76 coverage run -a --branch bin/kconfig-hardened-check -p ARM -m verbose
77 coverage run -a --branch bin/kconfig-hardened-check -p ARM -m json
79 echo ">>>>> use local cmdline as an example <<<<<"
82 echo ">>>>> check the example kconfig files and cmdline <<<<<"
83 CONFIG_DIR=`find . -name config_files`
84 CONFIGS=`find $CONFIG_DIR -type f | grep "\.config"`
88 COUNT=$(expr $COUNT + 1)
89 echo -e "\n>>>>> checking config number $COUNT <<<<<"
90 coverage run -a --branch bin/kconfig-hardened-check -c $C -l /proc/cmdline
91 coverage run -a --branch bin/kconfig-hardened-check -c $C -l /proc/cmdline -m verbose > /dev/null
92 coverage run -a --branch bin/kconfig-hardened-check -c $C -l /proc/cmdline -m json
93 coverage run -a --branch bin/kconfig-hardened-check -c $C -l /proc/cmdline -m show_ok
94 coverage run -a --branch bin/kconfig-hardened-check -c $C -l /proc/cmdline -m show_fail
96 echo -e "\n>>>>> checking $COUNT configs is done <<<<<"
97 coverage xml -i -o coverage.xml
99 - name: Handle coverage
100 uses: codecov/codecov-action@v1
103 flags: functional_test
104 name: codecov-umbrella
105 fail_ci_if_error: true