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 39 # Use a file as a synchronization point between test and inferior. 40 pid_file_path = lldbutil.append_to_process_working_directory(self, 41 "token_pid_%d" % (int(os.getpid()))) 42 self.addTearDownHook( 43 lambda: self.run_platform_command( 44 "rm %s" % 45 (pid_file_path))) 46 47 popen = self.spawnSubprocess(exe, [self.getBuildDir(), pid_file_path]) 48 49 # Wait for the inferior to start up, dlopen a bundle, remove the bundle it linked in 50 pid = lldbutil.wait_for_file_on_target(self, pid_file_path) 51 52 # Since the library that was dlopen()'ed is now removed, lldb will need to find the 53 # binary & dSYM via target.exec-search-paths 54 settings_str = "settings set target.exec-search-paths " + self.get_process_working_directory() + "/hide.app" 55 self.runCmd(settings_str) 56 self.runCmd("process attach -p " + str(popen.pid)) 57 58 target = self.dbg.GetSelectedTarget() 59 self.assertTrue(target.IsValid(), 'Should have a valid Target after attaching to process') 60 61 setup_complete = target.FindFirstGlobalVariable("setup_is_complete") 62 self.assertEquals(setup_complete.GetValueAsUnsigned(), 1, 'Check that inferior process has completed setup') 63 64 # Find the bundle module, see if we found the dSYM too (they're both in "hide.app") 65 i = 0 66 found_module = False 67 while i < target.GetNumModules(): 68 mod = target.GetModuleAtIndex(i) 69 if mod.GetFileSpec().GetFilename() == 'MyFramework': 70 found_module = True 71 dsym_name = mod.GetSymbolFileSpec().GetFilename() 72 self.assertTrue (dsym_name == 'MyFramework', "Check that we found the dSYM for the bundle that was loaded") 73 i=i+1 74 75 self.assertTrue(found_module, "Check that we found the framework loaded in lldb's image list") 76