1"""Test that a dSYM can be found when a binary is in a deep bundle with multiple pathname components.""" 2 3 4#import unittest2 5from time import sleep 6 7import lldb 8from lldbsuite.test.decorators import * 9from lldbsuite.test.lldbtest import * 10from lldbsuite.test import lldbutil 11 12 13exe_name = 'deep-bundle' # must match Makefile 14 15class DeepBundleTestCase(TestBase): 16 17 mydir = TestBase.compute_mydir(__file__) 18 19 def setUp(self): 20 TestBase.setUp(self) 21 self.source = 'main.c' 22 23 def tearDown(self): 24 # Destroy process before TestBase.tearDown() 25 self.dbg.GetSelectedTarget().GetProcess().Destroy() 26 27 # Call super's tearDown(). 28 TestBase.tearDown(self) 29 30 @skipIfRemote 31 @skipUnlessDarwin 32 # This test is explicitly a dSYM test, it doesn't need to run for any other config. 33 @skipIf(debug_info=no_match(["dsym"])) 34 def test_attach_and_check_dsyms(self): 35 """Test attach to binary, see if the framework dSYM is found""" 36 exe = self.getBuildArtifact(exe_name) 37 self.build() 38 popen = self.spawnSubprocess(exe, [self.getBuildDir()]) 39 self.addTearDownHook(self.cleanupSubprocesses) 40 41 # Give the inferior time to start up, dlopen a bundle, remove the bundle it linked in 42 sleep(5) 43 44 # Since the library that was dlopen()'ed is now removed, lldb will need to find the 45 # binary & dSYM via target.exec-search-paths 46 settings_str = "settings set target.exec-search-paths " + self.get_process_working_directory() + "/hide.app" 47 self.runCmd(settings_str) 48 self.runCmd("process attach -p " + str(popen.pid)) 49 50 target = self.dbg.GetSelectedTarget() 51 self.assertTrue(target.IsValid(), 'Should have a valid Target after attaching to process') 52 53 setup_complete = target.FindFirstGlobalVariable("setup_is_complete") 54 self.assertEquals(setup_complete.GetValueAsUnsigned(), 1, 'Check that inferior process has completed setup') 55 56 # Find the bundle module, see if we found the dSYM too (they're both in "hide.app") 57 i = 0 58 found_module = False 59 while i < target.GetNumModules(): 60 mod = target.GetModuleAtIndex(i) 61 if mod.GetFileSpec().GetFilename() == 'MyFramework': 62 found_module = True 63 dsym_name = mod.GetSymbolFileSpec().GetFilename() 64 self.assertTrue (dsym_name == 'MyFramework', "Check that we found the dSYM for the bundle that was loaded") 65 i=i+1 66 67 self.assertTrue(found_module, "Check that we found the framework loaded in lldb's image list") 68