diff options
| author | Johnny Chen <johnny.chen@apple.com> | 2011-04-01 00:35:55 +0000 |
|---|---|---|
| committer | Johnny Chen <johnny.chen@apple.com> | 2011-04-01 00:35:55 +0000 |
| commit | df2963ed46ee860c28b3c3b20cb3d2f1ad2637e7 (patch) | |
| tree | 018bd852712bcbfea39dfc0b32acbd52855bf36a | |
| parent | 95bf0fd3abcefce429f40f875f0f9ae3b0deed9e (diff) | |
| download | bcm5719-llvm-df2963ed46ee860c28b3c3b20cb3d2f1ad2637e7.tar.gz bcm5719-llvm-df2963ed46ee860c28b3c3b20cb3d2f1ad2637e7.zip | |
Add TestSymbolAPI.py to test the newly added SBSymbol and SBAddress APIs:
lldb::SymbolType SBSymbol::GetType();
lldb::SectionType SBAddress::GetSectionType ();
lldb::SBModule SBAddress::GetModule ();
Also add an lldb::SBModule::GetUUIDString() API which is easier for Python
to work with in the test script.
llvm-svn: 128695
| -rw-r--r-- | lldb/include/lldb/API/SBModule.h | 3 | ||||
| -rw-r--r-- | lldb/source/API/SBModule.cpp | 25 | ||||
| -rw-r--r-- | lldb/test/python_api/function_symbol/TestSymbolAPI.py | 96 |
3 files changed, 124 insertions, 0 deletions
diff --git a/lldb/include/lldb/API/SBModule.h b/lldb/include/lldb/API/SBModule.h index 712ea1b689b..280dd31693d 100644 --- a/lldb/include/lldb/API/SBModule.h +++ b/lldb/include/lldb/API/SBModule.h @@ -39,6 +39,9 @@ public: const uint8_t * GetUUIDBytes () const; + const char * + GetUUIDString () const; + #ifndef SWIG bool operator == (const lldb::SBModule &rhs) const; diff --git a/lldb/source/API/SBModule.cpp b/lldb/source/API/SBModule.cpp index 0a5c8aaacc3..e7e95be1e8b 100644 --- a/lldb/source/API/SBModule.cpp +++ b/lldb/source/API/SBModule.cpp @@ -95,6 +95,31 @@ SBModule::GetUUIDBytes () const } +const char * +SBModule::GetUUIDString () const +{ + LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); + + static char uuid_string[80]; + const char * uuid_c_string = NULL; + if (m_opaque_sp) + uuid_c_string = (const char *)m_opaque_sp->GetUUID().GetAsCString(uuid_string, sizeof(uuid_string)); + + if (log) + { + if (uuid_c_string) + { + StreamString s; + m_opaque_sp->GetUUID().Dump (&s); + log->Printf ("SBModule(%p)::GetUUIDString () => %s", m_opaque_sp.get(), s.GetData()); + } + else + log->Printf ("SBModule(%p)::GetUUIDString () => NULL", m_opaque_sp.get()); + } + return uuid_c_string; +} + + bool SBModule::operator == (const SBModule &rhs) const { diff --git a/lldb/test/python_api/function_symbol/TestSymbolAPI.py b/lldb/test/python_api/function_symbol/TestSymbolAPI.py new file mode 100644 index 00000000000..353bd31b3be --- /dev/null +++ b/lldb/test/python_api/function_symbol/TestSymbolAPI.py @@ -0,0 +1,96 @@ +""" +Test newly added SBSymbol and SBAddress APIs. +""" + +import os, time +import re +import unittest2 +import lldb, lldbutil +from lldbtest import * + +class SymbolAPITestCase(TestBase): + + mydir = os.path.join("python_api", "function_symbol") + + @unittest2.skipUnless(sys.platform.startswith("darwin"), "requires Darwin") + @python_api_test + def test_with_dsym(self): + """Exercise some SBSymbol and SBAddress APIs.""" + self.buildDsym() + self.symbol_and_address_api() + + @python_api_test + def test_with_dwarf(self): + """Exercise some SBSymbol and SBAddress APIs.""" + self.buildDwarf() + self.symbol_and_address_api() + + def setUp(self): + # Call super's setUp(). + TestBase.setUp(self) + # Find the line number to of function 'c'. + self.line1 = line_number('main.c', '// Find the line number for breakpoint 1 here.') + self.line2 = line_number('main.c', '// Find the line number for breakpoint 2 here.') + + def symbol_and_address_api(self): + """Exercise some SBSymbol and SBAddress APIs.""" + exe = os.path.join(os.getcwd(), "a.out") + + # Create a target by the debugger. + target = self.dbg.CreateTarget(exe) + self.assertTrue(target.IsValid(), VALID_TARGET) + + # Now create the two breakpoints inside function 'a'. + breakpoint1 = target.BreakpointCreateByLocation('main.c', self.line1) + breakpoint2 = target.BreakpointCreateByLocation('main.c', self.line2) + #print "breakpoint1:", breakpoint1 + #print "breakpoint2:", breakpoint2 + self.assertTrue(breakpoint1.IsValid() and + breakpoint1.GetNumLocations() == 1, + VALID_BREAKPOINT) + self.assertTrue(breakpoint2.IsValid() and + breakpoint2.GetNumLocations() == 1, + VALID_BREAKPOINT) + + # Now launch the process, and do not stop at entry point. + error = lldb.SBError() + self.process = target.LaunchSimple (None, None, os.getcwd()) + + self.process = target.GetProcess() + self.assertTrue(self.process.IsValid(), PROCESS_IS_VALID) + + # Frame #0 should be on self.line1. + self.assertTrue(self.process.GetState() == lldb.eStateStopped) + thread = lldbutil.get_stopped_thread(self.process, lldb.eStopReasonBreakpoint) + self.assertTrue(thread != None, "There should be a thread stopped due to breakpoint condition") + frame0 = thread.GetFrameAtIndex(0) + symbol_line1 = frame0.GetSymbol() + # We should have a symbol type of code. + self.assertTrue(symbol_line1.GetType() == lldb.eSymbolTypeCode) + addr_line1 = symbol_line1.GetStartAddress() + # And a section type of code, too. + self.assertTrue(addr_line1.GetSectionType() == lldb.eSectionTypeCode) + + # Continue the inferior, the breakpoint 2 should be hit. + self.process.Continue() + self.assertTrue(self.process.GetState() == lldb.eStateStopped) + thread = lldbutil.get_stopped_thread(self.process, lldb.eStopReasonBreakpoint) + self.assertTrue(thread != None, "There should be a thread stopped due to breakpoint condition") + frame0 = thread.GetFrameAtIndex(0) + symbol_line2 = frame0.GetSymbol() + # We should have a symbol type of code. + self.assertTrue(symbol_line2.GetType() == lldb.eSymbolTypeCode) + addr_line2 = symbol_line2.GetStartAddress() + # And a section type of code, too. + self.assertTrue(addr_line2.GetSectionType() == lldb.eSectionTypeCode) + + # Now verify that both addresses point to the same module. + print "UUID:", addr_line1.GetModule().GetUUIDString() + self.assertTrue(addr_line1.GetModule().GetUUIDString() == addr_line2.GetModule().GetUUIDString()) + + +if __name__ == '__main__': + import atexit + lldb.SBDebugger.Initialize() + atexit.register(lambda: lldb.SBDebugger.Terminate()) + unittest2.main() |

