mirror of
https://github.com/u-boot/u-boot.git
synced 2025-04-18 02:44:37 +00:00
test/py: Add support to enable check for bad pattern
Executing a u-boot command may raise an error or extra bad pattern, beyond the default bad patterns. Providing a way to enable the console output error check in test. For example, description for OS boot test: import re check_type = 'kernel_boot_error' check_pattern = re.compile('ERROR -2: can't get kernel image!') with u_boot_console.enable_check(check_type, check_pattern): u_boot_console.run_command('<boot command>') Signed-off-by: Love Kumar <love.kumar@amd.com>
This commit is contained in:
parent
065ed551e3
commit
a57973ab47
1 changed files with 44 additions and 0 deletions
|
@ -55,6 +55,32 @@ class ConsoleDisableCheck(object):
|
|||
self.console.disable_check_count[self.check_type] -= 1
|
||||
self.console.eval_bad_patterns()
|
||||
|
||||
class ConsoleEnableCheck(object):
|
||||
"""Context manager (for Python's with statement) that temporarily enables
|
||||
the specified console output error check. This is useful when executing a
|
||||
command that might raise an extra bad pattern, beyond the default bad
|
||||
patterns, in order to validate that the extra bad pattern is actually
|
||||
detected. This class is used internally by ConsoleBase::enable_check(); it
|
||||
is not intended for direct usage."""
|
||||
|
||||
def __init__(self, console, check_type, check_pattern):
|
||||
self.console = console
|
||||
self.check_type = check_type
|
||||
self.check_pattern = check_pattern
|
||||
|
||||
def __enter__(self):
|
||||
global bad_pattern_defs
|
||||
self.default_bad_patterns = bad_pattern_defs
|
||||
bad_pattern_defs += ((self.check_type, self.check_pattern),)
|
||||
self.console.disable_check_count = {pat[PAT_ID]: 0 for pat in bad_pattern_defs}
|
||||
self.console.eval_bad_patterns()
|
||||
|
||||
def __exit__(self, extype, value, traceback):
|
||||
global bad_pattern_defs
|
||||
bad_pattern_defs = self.default_bad_patterns
|
||||
self.console.disable_check_count = {pat[PAT_ID]: 0 for pat in bad_pattern_defs}
|
||||
self.console.eval_bad_patterns()
|
||||
|
||||
class ConsoleSetupTimeout(object):
|
||||
"""Context manager (for Python's with statement) that temporarily sets up
|
||||
timeout for specific command. This is useful when execution time is greater
|
||||
|
@ -492,6 +518,24 @@ class ConsoleBase(object):
|
|||
|
||||
return ConsoleDisableCheck(self, check_type)
|
||||
|
||||
def enable_check(self, check_type, check_pattern):
|
||||
"""Temporarily enable an error check of U-Boot's output.
|
||||
|
||||
Create a new context manager (for use with the "with" statement) which
|
||||
temporarily enables a particular console output error check. The
|
||||
arguments form a new element of bad_pattern_defs defined above.
|
||||
|
||||
Args:
|
||||
check_type: The type of error-check or bad pattern to enable.
|
||||
check_pattern: The regexes for text error pattern or bad pattern
|
||||
to be checked.
|
||||
|
||||
Returns:
|
||||
A context manager object.
|
||||
"""
|
||||
|
||||
return ConsoleEnableCheck(self, check_type, check_pattern)
|
||||
|
||||
def temporary_timeout(self, timeout):
|
||||
"""Temporarily set up different timeout for commands.
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue