forked from OSchip/llvm-project
Add a test script for verifying that the convenience variables:
o lldb.debugger o lldb.target o lldb.process o lldb.thread o lldb.frame "just works" when we stop at a breakpoint. llvm-svn: 130904
This commit is contained in:
parent
baa878ce4a
commit
0bade020a0
|
@ -0,0 +1,5 @@
|
||||||
|
LEVEL = ../make
|
||||||
|
|
||||||
|
C_SOURCES := main.c
|
||||||
|
|
||||||
|
include $(LEVEL)/Makefile.rules
|
|
@ -0,0 +1,88 @@
|
||||||
|
"""Test convenience variables when you drop in from lldb prompt into an embedded interpreter."""
|
||||||
|
|
||||||
|
import os
|
||||||
|
import unittest2
|
||||||
|
import lldb
|
||||||
|
import pexpect
|
||||||
|
from lldbtest import *
|
||||||
|
|
||||||
|
class ConvenienceVariablesCase(TestBase):
|
||||||
|
|
||||||
|
mydir = "embedded_interpreter"
|
||||||
|
|
||||||
|
@unittest2.skipUnless(sys.platform.startswith("darwin"), "requires Darwin")
|
||||||
|
def test_with_dsym_and_run_command(self):
|
||||||
|
"""Test convenience variables lldb.debugger, lldb.target, lldb.process, lldb.thread, and lldb.frame."""
|
||||||
|
self.buildDsym()
|
||||||
|
self.convenience_variables()
|
||||||
|
|
||||||
|
@python_api_test
|
||||||
|
def test_with_dwarf_and_process_launch_api(self):
|
||||||
|
"""Test convenience variables lldb.debugger, lldb.target, lldb.process, lldb.thread, and lldb.frame."""
|
||||||
|
self.buildDwarf()
|
||||||
|
self.convenience_variables()
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
# Call super's setUp().
|
||||||
|
TestBase.setUp(self)
|
||||||
|
# Find the line number to break on inside main.cpp.
|
||||||
|
self.line = line_number('main.c', 'Hello world.')
|
||||||
|
|
||||||
|
def convenience_variables(self):
|
||||||
|
"""Test convenience variables lldb.debugger, lldb.target, lldb.process, lldb.thread, and lldb.frame."""
|
||||||
|
exe = os.path.join(os.getcwd(), "a.out")
|
||||||
|
prompt = "(lldb) "
|
||||||
|
python_prompt = ">>> "
|
||||||
|
|
||||||
|
# So that the child gets torn down after the test.
|
||||||
|
self.child = pexpect.spawn('%s %s' % (self.lldbExec, exe))
|
||||||
|
child = self.child
|
||||||
|
# Turn on logging for what the child sends back.
|
||||||
|
if self.TraceOn():
|
||||||
|
child.logfile_read = sys.stdout
|
||||||
|
|
||||||
|
# Set the breakpoint, run the inferior, when it breaks, issue print on
|
||||||
|
# the various convenience variables.
|
||||||
|
child.expect_exact(prompt)
|
||||||
|
child.sendline('breakpoint set -f main.c -l %d' % self.line)
|
||||||
|
child.expect_exact(prompt)
|
||||||
|
child.sendline('run')
|
||||||
|
child.expect_exact(prompt)
|
||||||
|
child.sendline('script')
|
||||||
|
child.expect_exact(python_prompt)
|
||||||
|
|
||||||
|
# Set a flag so that we know during teardown time, we need to exit the
|
||||||
|
# Python interpreter, then the lldb interpreter.
|
||||||
|
self.child_in_script_interpreter = True
|
||||||
|
|
||||||
|
child.sendline('print lldb.debugger')
|
||||||
|
child.expect_exact(python_prompt)
|
||||||
|
self.expect(child.before, exe=False,
|
||||||
|
patterns = ['Debugger \(instance: .*, id: \d\)'])
|
||||||
|
|
||||||
|
child.sendline('print lldb.target')
|
||||||
|
child.expect_exact(python_prompt)
|
||||||
|
self.expect(child.before, exe=False,
|
||||||
|
substrs = ['a.out'])
|
||||||
|
|
||||||
|
child.sendline('print lldb.process')
|
||||||
|
child.expect_exact(python_prompt)
|
||||||
|
self.expect(child.before, exe=False,
|
||||||
|
patterns = ['SBProcess: pid = \d+, state = stopped, threads = \d, executable = a.out'])
|
||||||
|
|
||||||
|
child.sendline('print lldb.thread')
|
||||||
|
child.expect_exact(python_prompt)
|
||||||
|
self.expect(child.before, exe=False,
|
||||||
|
patterns = ['SBThread: tid = 0x[0-9a-f]+'])
|
||||||
|
|
||||||
|
child.sendline('print lldb.frame')
|
||||||
|
child.expect_exact(python_prompt)
|
||||||
|
self.expect(child.before, exe=False,
|
||||||
|
substrs = ['frame #0', 'main.c:%d' % self.line])
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
import atexit
|
||||||
|
lldb.SBDebugger.Initialize()
|
||||||
|
atexit.register(lambda: lldb.SBDebugger.Terminate())
|
||||||
|
unittest2.main()
|
|
@ -0,0 +1,6 @@
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
int main(int argc, char const *argv[]) {
|
||||||
|
printf("Hello world.\n");
|
||||||
|
return 0;
|
||||||
|
}
|
|
@ -529,6 +529,7 @@ class TestBase(unittest2.TestCase):
|
||||||
# This is for the case of directly spawning 'lldb' and interacting with it
|
# This is for the case of directly spawning 'lldb' and interacting with it
|
||||||
# using pexpect.
|
# using pexpect.
|
||||||
self.child = None
|
self.child = None
|
||||||
|
self.child_in_script_interpreter = False
|
||||||
|
|
||||||
# There is no process associated with the debugger as yet.
|
# There is no process associated with the debugger as yet.
|
||||||
# See also self.tearDown() where it checks whether self.process has a
|
# See also self.tearDown() where it checks whether self.process has a
|
||||||
|
@ -682,6 +683,9 @@ class TestBase(unittest2.TestCase):
|
||||||
if self.child and self.child.isalive():
|
if self.child and self.child.isalive():
|
||||||
with recording(self, traceAlways) as sbuf:
|
with recording(self, traceAlways) as sbuf:
|
||||||
print >> sbuf, "tearing down the child process...."
|
print >> sbuf, "tearing down the child process...."
|
||||||
|
if self.child_in_script_interpreter:
|
||||||
|
self.child.sendline('quit()')
|
||||||
|
self.child.expect_exact('(lldb) ')
|
||||||
self.child.sendline('quit')
|
self.child.sendline('quit')
|
||||||
try:
|
try:
|
||||||
self.child.expect(pexpect.EOF)
|
self.child.expect(pexpect.EOF)
|
||||||
|
|
Loading…
Reference in New Issue