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