Added more verbose output when string match fails. Converted TestGlobalVariables.py.

llvm-svn: 111666
This commit is contained in:
Johnny Chen 2010-08-20 18:25:15 +00:00
parent 84c29a096b
commit b145bbaf4b
2 changed files with 22 additions and 31 deletions

View File

@ -11,47 +11,32 @@ class TestGlobalVariables(TestBase):
def test_global_variables(self):
"""Test 'variable list -s -a' which omits args and shows scopes."""
res = self.res
exe = os.path.join(os.getcwd(), "a.out")
self.ci.HandleCommand("file " + exe, res)
self.assertTrue(res.Succeeded(), CURRENT_EXECUTABLE_SET)
self.runCmd("file " + exe, CURRENT_EXECUTABLE_SET)
# Break inside the main.
self.ci.HandleCommand("breakpoint set -f main.c -l 20", res)
self.assertTrue(res.Succeeded(), CMD_MSG('breakpoint set'))
self.assertTrue(res.GetOutput().startswith(
"Breakpoint created: 1: file ='main.c', line = 20, locations = 1"),
BREAKPOINT_CREATED)
self.expect("breakpoint set -f main.c -l 20", BREAKPOINT_CREATED,
startstr = "Breakpoint created: 1: file ='main.c', line = 20, locations = 1")
self.ci.HandleCommand("run", res)
self.runStarted = True
self.assertTrue(res.Succeeded(), RUN_STOPPED)
self.runCmd("run", RUN_STOPPED)
# The stop reason of the thread should be breakpoint.
self.ci.HandleCommand("thread list", res)
#print "thread list ->", res.GetOutput()
self.assertTrue(res.Succeeded(), CMD_MSG('thread list'))
self.assertTrue(res.GetOutput().find('state is Stopped') > 0 and
res.GetOutput().find('stop reason = breakpoint') > 0,
STOPPED_DUE_TO_BREAKPOINT)
self.expect("thread list", STOPPED_DUE_TO_BREAKPOINT,
substrs = ['state is Stopped',
'stop reason = breakpoint'])
# The breakpoint should have a hit count of 1.
self.ci.HandleCommand("breakpoint list", res)
self.assertTrue(res.Succeeded(), CMD_MSG('breakpoint list'))
self.assertTrue(res.GetOutput().find(' resolved, hit count = 1') > 0,
BREAKPOINT_HIT_ONCE)
self.expect("breakpoint list", BREAKPOINT_HIT_ONCE,
substrs = [' resolved, hit count = 1'])
# Check that GLOBAL scopes are indicated for the variables.
self.ci.HandleCommand("variable list -s -a", res);
self.assertTrue(res.Succeeded(), CMD_MSG('variable list ...'))
output = res.GetOutput()
self.assertTrue(output.find('GLOBAL: g_file_static_cstr') > 0 and
output.find('g_file_static_cstr') > 0 and
output.find('GLOBAL: g_file_global_int') > 0 and
output.find('(int) 42') > 0 and
output.find('GLOBAL: g_file_global_cstr') > 0 and
output.find('g_file_global_cstr') > 0,
VARIABLES_DISPLAYED_CORRECTLY)
self.expect("variable list -s -a", VARIABLES_DISPLAYED_CORRECTLY,
substrs = ['GLOBAL: g_file_static_cstr',
'"g_file_static_cstr"',
'GLOBAL: g_file_global_int',
'(int) 42',
'GLOBAL: g_file_global_cstr',
'"g_file_global_cstr"'])
if __name__ == '__main__':

View File

@ -157,10 +157,16 @@ class TestBase(unittest2.TestCase):
output = self.res.GetOutput()
matched = output.startswith(startstr) if startstr else True
if not matched and startstr and verbose:
print "Startstr not matched:", startstr
if substrs:
for str in substrs:
matched = output.find(str) > 0
if not matched:
if verbose:
print "Substring not matched:", str
break
self.assertTrue(matched, msg)