[Lldb-commits] [lldb] r121168 - /lldb/trunk/test/foundation/TestSymbolTable.py
Johnny Chen
johnny.chen at apple.com
Tue Dec 7 11:37:52 PST 2010
Author: johnny
Date: Tue Dec 7 13:37:52 2010
New Revision: 121168
URL: http://llvm.org/viewvc/llvm-project?rev=121168&view=rev
Log:
Add test/foundation/TestSymbolTable.py to exercise accessing the symbol table
entries (including synthesized properties) through the lldb Python APIs.
Added:
lldb/trunk/test/foundation/TestSymbolTable.py
Added: lldb/trunk/test/foundation/TestSymbolTable.py
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/foundation/TestSymbolTable.py?rev=121168&view=auto
==============================================================================
--- lldb/trunk/test/foundation/TestSymbolTable.py (added)
+++ lldb/trunk/test/foundation/TestSymbolTable.py Tue Dec 7 13:37:52 2010
@@ -0,0 +1,81 @@
+"""
+Test symbol table access for main.m.
+"""
+
+import os, time
+import unittest2
+import lldb
+from lldbtest import *
+
+ at unittest2.skipUnless(sys.platform.startswith("darwin"), "requires Darwin")
+class FoundationSymtabTestCase(TestBase):
+
+ mydir = "foundation"
+
+ symbols_list = ['-[MyString initWithNSString:]',
+ '-[MyString dealloc]',
+ '-[MyString description]',
+ '-[MyString descriptionPauses]', # synthesized property
+ '-[MyString setDescriptionPauses:]', # synthesized property
+ 'Test_Selector',
+ 'Test_NSString',
+ 'Test_MyString',
+ 'Test_NSArray',
+ 'main'
+ ]
+
+ def test_with_dsym_and_python_api(self):
+ """Test symbol table access with Python APIs."""
+ self.buildDsym()
+ self.symtab_access_python()
+
+ def test_with_dwarf_and_python_api(self):
+ """Test symbol table access with Python APIs."""
+ self.buildDwarf()
+ self.symtab_access_python()
+
+ def symtab_access_python(self):
+ """Test symbol table access with Python APIs."""
+ exe = os.path.join(os.getcwd(), "a.out")
+ self.runCmd("file " + exe, CURRENT_EXECUTABLE_SET)
+
+ target = self.dbg.CreateTarget(exe)
+ self.assertTrue(target.IsValid(), VALID_TARGET)
+
+ # Launch the process, and do not stop at the entry point.
+ process = target.LaunchProcess([''], [''], os.ctermid(), 0, False)
+
+ #
+ # Exercise Python APIs to access the symbol table entries.
+ #
+
+ # Create the filespec by which to locate our a.out module.
+ filespec = lldb.SBFileSpec(exe, False)
+
+ module = target.FindModule(filespec)
+ self.assertTrue(module.IsValid(), VALID_MODULE)
+
+ # Create the set of known symbols. As we iterate through the symbol
+ # table, remove the symbol from the set if it is a known symbol.
+ expected_symbols = set(self.symbols_list)
+ from lldbutil import lldb_iter
+ for symbol in lldb_iter(module, 'GetNumSymbols', 'GetSymbolAtIndex'):
+ self.assertTrue(symbol.IsValid(), VALID_SYMBOL)
+ #print "symbol:", symbol
+ name = symbol.GetName()
+ if name in expected_symbols:
+ #print "Removing %s from known_symbols %s" % (name, expected_symbols)
+ expected_symbols.remove(name)
+
+ # At this point, the known_symbols set should have become an empty set.
+ # If not, raise an error.
+ #print "symbols unaccounted for:", expected_symbols
+ self.assertTrue(len(expected_symbols) == 0,
+ "All the known symbols are accounted for")
+
+
+if __name__ == '__main__':
+ import atexit
+ lldb.SBDebugger.Initialize()
+ atexit.register(lambda: lldb.SBDebugger.Terminate())
+ unittest2.main()
More information about the lldb-commits
mailing list