Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
K
kernel-hardening-checker
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
fact-depend
kernel-hardening-checker
Commits
a1888d29
Commit
a1888d29
authored
Apr 02, 2023
by
Alexander Popov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
test_engine: introduce get_engine_result()
It's refactoring, no functional changes
parent
ba85d0b9
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
29 additions
and
18 deletions
+29
-18
test_engine.py
kconfig_hardened_check/test_engine.py
+29
-18
No files found.
kconfig_hardened_check/test_engine.py
View file @
a1888d29
...
...
@@ -39,19 +39,16 @@ class TestEngine(unittest.TestCase):
kernel_version = (42, 43)
# 5. run the engine
result = []
self.run_engine(config_checklist,
parsed_kconfig_options, parsed_cmdline_options, kernel_version,
result)
self.run_engine(config_checklist, parsed_kconfig_options, parsed_cmdline_options, kernel_version)
# 6. check that the results are correct
# self.assertEqual(...
result = []
self.get_engine_result(config_checklist, result, 'json')
self.assertEqual(...
"""
@staticmethod
def
run_engine
(
checklist
,
parsed_kconfig_options
,
parsed_cmdline_options
,
kernel_version
,
result
):
def
run_engine
(
checklist
,
parsed_kconfig_options
,
parsed_cmdline_options
,
kernel_version
):
# populate the checklist with data
if
parsed_kconfig_options
:
populate_with_data
(
checklist
,
parsed_kconfig_options
,
'kconfig'
)
...
...
@@ -71,11 +68,20 @@ class TestEngine(unittest.TestCase):
# print the results in JSON
print
(
'JSON:'
)
result
=
[]
for
opt
in
checklist
:
result
.
append
(
opt
.
json_dump
(
True
))
# with_results
print
(
json
.
dumps
(
result
))
print
()
@staticmethod
def
get_engine_result
(
checklist
,
result
,
result_type
):
assert
(
result_type
in
(
'table'
,
'json'
)),
\
f
'invalid result type "{result_type}"'
if
result_type
==
'json'
:
for
opt
in
checklist
:
result
.
append
(
opt
.
json_dump
(
True
))
# with_results
def
test_single_kconfig
(
self
):
# 1. prepare the checklist
config_checklist
=
[]
...
...
@@ -100,10 +106,11 @@ class TestEngine(unittest.TestCase):
parsed_kconfig_options
[
'CONFIG_NAME_9'
]
=
'0'
# 3. run the engine
result
=
[]
self
.
run_engine
(
config_checklist
,
parsed_kconfig_options
,
None
,
None
,
result
)
self
.
run_engine
(
config_checklist
,
parsed_kconfig_options
,
None
,
None
)
# 4. check that the results are correct
result
=
[]
self
.
get_engine_result
(
config_checklist
,
result
,
'json'
)
self
.
assertEqual
(
result
,
[[
"CONFIG_NAME_1"
,
"kconfig"
,
"expected_1"
,
"decision_1"
,
"reason_1"
,
"OK"
],
...
...
@@ -142,10 +149,11 @@ class TestEngine(unittest.TestCase):
parsed_cmdline_options
[
'name_9'
]
=
'0'
# 3. run the engine
result
=
[]
self
.
run_engine
(
config_checklist
,
None
,
parsed_cmdline_options
,
None
,
result
)
self
.
run_engine
(
config_checklist
,
None
,
parsed_cmdline_options
,
None
)
# 4. check that the results are correct
result
=
[]
self
.
get_engine_result
(
config_checklist
,
result
,
'json'
)
self
.
assertEqual
(
result
,
[[
"name_1"
,
"cmdline"
,
"expected_1"
,
"decision_1"
,
"reason_1"
,
"OK"
],
...
...
@@ -188,10 +196,11 @@ class TestEngine(unittest.TestCase):
parsed_kconfig_options
[
'CONFIG_NAME_11'
]
=
'really_not_off'
# 3. run the engine
result
=
[]
self
.
run_engine
(
config_checklist
,
parsed_kconfig_options
,
None
,
None
,
result
)
self
.
run_engine
(
config_checklist
,
parsed_kconfig_options
,
None
,
None
)
# 4. check that the results are correct
result
=
[]
self
.
get_engine_result
(
config_checklist
,
result
,
'json'
)
self
.
assertEqual
(
result
,
[[
"CONFIG_NAME_1"
,
"kconfig"
,
"expected_1"
,
"decision_1"
,
"reason_1"
,
"OK"
],
...
...
@@ -232,10 +241,11 @@ class TestEngine(unittest.TestCase):
parsed_kconfig_options
[
'CONFIG_NAME_12'
]
=
'expected_12'
# 3. run the engine
result
=
[]
self
.
run_engine
(
config_checklist
,
parsed_kconfig_options
,
None
,
None
,
result
)
self
.
run_engine
(
config_checklist
,
parsed_kconfig_options
,
None
,
None
)
# 4. check that the results are correct
result
=
[]
self
.
get_engine_result
(
config_checklist
,
result
,
'json'
)
self
.
assertEqual
(
result
,
[[
"CONFIG_NAME_1"
,
"kconfig"
,
"expected_1"
,
"decision_1"
,
"reason_1"
,
"OK"
],
...
...
@@ -267,10 +277,11 @@ class TestEngine(unittest.TestCase):
kernel_version
=
(
42
,
43
)
# 4. run the engine
result
=
[]
self
.
run_engine
(
config_checklist
,
parsed_kconfig_options
,
None
,
kernel_version
,
result
)
self
.
run_engine
(
config_checklist
,
parsed_kconfig_options
,
None
,
kernel_version
)
# 5. check that the results are correct
result
=
[]
self
.
get_engine_result
(
config_checklist
,
result
,
'json'
)
self
.
assertEqual
(
result
,
[[
"CONFIG_NAME_1"
,
"kconfig"
,
"expected_1"
,
"decision_1"
,
"reason_1"
,
"OK: version >= 41.101"
],
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment