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