# pylint: disable=missing-class-docstring,missing-function-docstring
# pylint: disable=line-too-long,invalid-name,too-many-branches
-from typing import Dict, Tuple
import sys
+from typing import Optional, OrderedDict, Dict, List, Tuple
+StrOrNone = Optional[str]
+TupleOrNone = Optional[Tuple]
+
GREEN_COLOR = '\x1b[32m'
RED_COLOR = '\x1b[31m'
COLOR_END = '\x1b[0m'
"reason": self.reason,
}
if with_results:
+ assert self.result, f'unexpected empty result in {self.name}'
dump["check_result"] = self.result
dump["check_result_bool"] = self.result.startswith('OK')
return dump
dump = self.opts[0].json_dump(False)
if with_results:
# Add the 'check_result' and 'check_result_bool' keys to the dictionary
+ assert self.result, f'unexpected empty result in {self.name}'
dump["check_result"] = self.result
dump["check_result_bool"] = self.result.startswith('OK')
return dump
def perform_checks(checklist):
for opt in checklist:
opt.check()
+
+
+def print_unknown_options(checklist: List, parsed_options: OrderedDict[str, str], opt_type: str) -> None:
+ known_options = []
+
+ for o1 in checklist:
+ if o1.opt_type != 'complex':
+ known_options.append(o1.name)
+ continue
+ for o2 in o1.opts:
+ if o2.opt_type != 'complex':
+ if hasattr(o2, 'name'):
+ known_options.append(o2.name)
+ continue
+ for o3 in o2.opts:
+ assert(o3.opt_type != 'complex'), \
+ f'unexpected ComplexOptCheck inside {o2.name}'
+ if hasattr(o3, 'name'):
+ known_options.append(o3.name)
+
+ for option, value in parsed_options.items():
+ if option not in known_options:
+ print(f'[?] No check for {opt_type} option {option} ({value})')