mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-20 20:15:49 -04:00

Summary: A lot of tests do this trick but the vast majority of them don't even call `print()`. Most of this patch was generated by a script that just looks at all the files and deletes the line if there is no `print (` or `print(` anywhere else in the file. I checked the remaining tests manually and deleted the import if we never call print (but instead do stuff like `expr print(...)` and similar false-positives). I also corrected the additional empty lines after the import in the files that I manually edited. Reviewers: JDevlieghere, labath, jfb Reviewed By: labath Subscribers: dexonsmith, wuzish, nemanjai, kbarton, christof, arphaman, abidh, lldb-commits Tags: #lldb Differential Revision: https://reviews.llvm.org/D71452
73 lines
2.6 KiB
Python
73 lines
2.6 KiB
Python
"""Test that a dSYM can be found when a binary is in a bundle hnd has dots in the filename."""
|
|
|
|
|
|
#import unittest2
|
|
import os.path
|
|
from time import sleep
|
|
|
|
import lldb
|
|
from lldbsuite.test.decorators import *
|
|
from lldbsuite.test.lldbtest import *
|
|
from lldbsuite.test import lldbutil
|
|
|
|
|
|
exe_name = 'find-bundle-with-dots-in-fn' # must match Makefile
|
|
|
|
class BundleWithDotInFilenameTestCase(TestBase):
|
|
|
|
mydir = TestBase.compute_mydir(__file__)
|
|
|
|
@skipIfRemote
|
|
@skipUnlessDarwin
|
|
# This test is explicitly a dSYM test, it doesn't need to run for any other config, but
|
|
# the following doesn't work, fixme.
|
|
# @skipIf(debug_info=no_match(["dsym"]), bugnumber="This test is looking explicitly for a dSYM")
|
|
|
|
def setUp(self):
|
|
TestBase.setUp(self)
|
|
self.source = 'main.c'
|
|
|
|
def tearDown(self):
|
|
# Destroy process before TestBase.tearDown()
|
|
self.dbg.GetSelectedTarget().GetProcess().Destroy()
|
|
|
|
# Call super's tearDown().
|
|
TestBase.tearDown(self)
|
|
|
|
def test_attach_and_check_dsyms(self):
|
|
"""Test attach to binary, see if the bundle dSYM is found"""
|
|
exe = self.getBuildArtifact(exe_name)
|
|
self.build()
|
|
os.chdir(self.getBuildDir());
|
|
popen = self.spawnSubprocess(exe)
|
|
self.addTearDownHook(self.cleanupSubprocesses)
|
|
|
|
# Give the inferior time to start up, dlopen a bundle, remove the bundle it linked in
|
|
sleep(5)
|
|
|
|
# Since the library that was dlopen()'ed is now removed, lldb will need to find the
|
|
# binary & dSYM via target.exec-search-paths
|
|
settings_str = "settings set target.exec-search-paths " + self.get_process_working_directory() + "/hide.app"
|
|
self.runCmd(settings_str)
|
|
|
|
self.runCmd("process attach -p " + str(popen.pid))
|
|
|
|
target = self.dbg.GetSelectedTarget()
|
|
self.assertTrue(target.IsValid(), 'Should have a valid Target after attaching to process')
|
|
|
|
setup_complete = target.FindFirstGlobalVariable("setup_is_complete")
|
|
self.assertTrue(setup_complete.GetValueAsUnsigned() == 1, 'Check that inferior process has completed setup')
|
|
|
|
# Find the bundle module, see if we found the dSYM too (they're both in "hide.app")
|
|
i = 0
|
|
while i < target.GetNumModules():
|
|
mod = target.GetModuleAtIndex(i)
|
|
if mod.GetFileSpec().GetFilename() == 'com.apple.sbd':
|
|
dsym_name = mod.GetSymbolFileSpec().GetFilename()
|
|
self.assertTrue (dsym_name == 'com.apple.sbd', "Check that we found the dSYM for the bundle that was loaded")
|
|
i=i+1
|
|
os.chdir(self.getSourceDir());
|
|
|
|
if __name__ == '__main__':
|
|
unittest.main()
|