diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2016-01-13 20:06:56 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2016-01-13 20:06:56 +0000 | 
| commit | 7fed546d1996271dabc7cf71d4d033125c4da4ee (patch) | |
| tree | 2b6dc7dcb4a6380cb331aded15f5a81c0038e194 /packages/Python/lldbsuite/test/lang | |
| parent | 9e6d35490a6542f9c97607f93c2ef8ca8e03cbcc (diff) | |
Notes
Diffstat (limited to 'packages/Python/lldbsuite/test/lang')
3 files changed, 70 insertions, 0 deletions
| diff --git a/packages/Python/lldbsuite/test/lang/objc/global_ptrs/Makefile b/packages/Python/lldbsuite/test/lang/objc/global_ptrs/Makefile new file mode 100644 index 000000000000..a1608fe5a664 --- /dev/null +++ b/packages/Python/lldbsuite/test/lang/objc/global_ptrs/Makefile @@ -0,0 +1,6 @@ +LEVEL = ../../../make + +OBJC_SOURCES := main.m +LDFLAGS = $(CFLAGS) -lobjc -framework Foundation + +include $(LEVEL)/Makefile.rules diff --git a/packages/Python/lldbsuite/test/lang/objc/global_ptrs/TestGlobalObjects.py b/packages/Python/lldbsuite/test/lang/objc/global_ptrs/TestGlobalObjects.py new file mode 100644 index 000000000000..c4c581b9240f --- /dev/null +++ b/packages/Python/lldbsuite/test/lang/objc/global_ptrs/TestGlobalObjects.py @@ -0,0 +1,53 @@ +"""Test that a global ObjC object found before the process is started updates correctly.""" + +from __future__ import print_function + + + +import os, time +import lldb +import lldbsuite.test.lldbutil as lldbutil +from lldbsuite.test.lldbtest import * + +class TestObjCGlobalVar(TestBase): + +    mydir = TestBase.compute_mydir(__file__) + +    def setUp(self): +        # Call super's setUp(). +        TestBase.setUp(self) +        self.main_source = lldb.SBFileSpec("main.m") + +    @skipUnlessDarwin +    @add_test_categories(['pyapi']) +    def test_with_python_api(self): +        """Test that a global ObjC object found before the process is started updates correctly.""" +        self.build() +        exe = os.path.join(os.getcwd(), "a.out") + +        target = self.dbg.CreateTarget(exe) +        self.assertTrue(target, VALID_TARGET) + +        bkpt = target.BreakpointCreateBySourceRegex ('NSLog', self.main_source) +        self.assertTrue(bkpt, VALID_BREAKPOINT) + +        # Before we launch, make an SBValue for our global object pointer: +        g_obj_ptr = target.FindFirstGlobalVariable("g_obj_ptr") +        self.assertTrue(g_obj_ptr.GetError().Success(), "Made the g_obj_ptr") +        self.assertTrue(g_obj_ptr.GetValueAsUnsigned(10) == 0, "g_obj_ptr is initially null") + +        # Now launch the process, and do not stop at entry point. +        process = target.LaunchSimple (None, None, self.get_process_working_directory()) + +        self.assertTrue(process, PROCESS_IS_VALID) + +        # The stop reason of the thread should be breakpoint. +        threads = lldbutil.get_threads_stopped_at_breakpoint (process, bkpt) +        if len(threads) != 1: +            self.fail ("Failed to stop at breakpoint 1.") + +        thread = threads[0] + +        dyn_value = g_obj_ptr.GetDynamicValue(lldb.eDynamicCanRunTarget) +        self.assertTrue(dyn_value.GetError().Success(), "Dynamic value is valid") +        self.assertTrue(dyn_value.GetObjectDescription() == "Some NSString") diff --git a/packages/Python/lldbsuite/test/lang/objc/global_ptrs/main.m b/packages/Python/lldbsuite/test/lang/objc/global_ptrs/main.m new file mode 100644 index 000000000000..977a984e06e0 --- /dev/null +++ b/packages/Python/lldbsuite/test/lang/objc/global_ptrs/main.m @@ -0,0 +1,11 @@ +#import <Foundation/Foundation.h> + +id g_obj_ptr = nil; + +int +main() +{ +  g_obj_ptr = @"Some NSString"; +  NSLog(@"My string was %@.", g_obj_ptr); +  return 0; +} | 
