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 def setUp(self): 18 TestBase.setUp(self) 19 self.source = 'main.c' 20 21 def tearDown(self): 22 # Destroy process before TestBase.tearDown() 23 self.dbg.GetSelectedTarget().GetProcess().Destroy() 24 25 # Call super's tearDown(). 26 TestBase.tearDown(self) 27 28 @skipIfRemote 29 @skipUnlessDarwin 30 # This test is explicitly a dSYM test, it doesn't need to run for any other config. 31 @skipIf(debug_info=no_match(["dsym"])) 32 def test_attach_and_check_dsyms(self): 33 """Test attach to binary, see if the framework dSYM is found""" 34 exe = self.getBuildArtifact(exe_name) 35 self.build() 36 37 # Use a file as a synchronization point between test and inferior. 38 pid_file_path = lldbutil.append_to_process_working_directory(self, 39 "token_pid_%d" % (int(os.getpid()))) 40 self.addTearDownHook( 41 lambda: self.run_platform_command( 42 "rm %s" % 43 (pid_file_path))) 44 45 popen = self.spawnSubprocess(exe, [self.getBuildDir(), pid_file_path]) 46 47 # Wait for the inferior to start up, dlopen a bundle, remove the bundle it linked in 48 pid = lldbutil.wait_for_file_on_target(self, pid_file_path) 49 50 # Since the library that was dlopen()'ed is now removed, lldb will need to find the 51 # binary & dSYM via target.exec-search-paths 52 settings_str = "settings set target.exec-search-paths " + self.get_process_working_directory() + "/hide.app" 53 self.runCmd(settings_str) 54 self.runCmd("process attach -p " + str(popen.pid)) 55 56 target = self.dbg.GetSelectedTarget() 57 self.assertTrue(target.IsValid(), 'Should have a valid Target after attaching to process') 58 59 setup_complete = target.FindFirstGlobalVariable("setup_is_complete") 60 self.assertEquals(setup_complete.GetValueAsUnsigned(), 1, 'Check that inferior process has completed setup') 61 62 # Find the bundle module, see if we found the dSYM too (they're both in "hide.app") 63 i = 0 64 found_module = False 65 while i < target.GetNumModules(): 66 mod = target.GetModuleAtIndex(i) 67 if mod.GetFileSpec().GetFilename() == 'MyFramework': 68 found_module = True 69 dsym_name = mod.GetSymbolFileSpec().GetFilename() 70 self.assertTrue (dsym_name == 'MyFramework', "Check that we found the dSYM for the bundle that was loaded") 71 i=i+1 72 73 self.assertTrue(found_module, "Check that we found the framework loaded in lldb's image list") 74