[Lldb-commits] [lldb] f5e0f8b - [lldb] Add test for importing ObjC modules in a non-ObjC target

Raphael Isemann via lldb-commits lldb-commits at lists.llvm.org
Tue Mar 17 04:50:05 PDT 2020


Author: Raphael Isemann
Date: 2020-03-17T12:49:48+01:00
New Revision: f5e0f8b10ab95e94b5ffb32e380f95d21415c3e8

URL: https://github.com/llvm/llvm-project/commit/f5e0f8b10ab95e94b5ffb32e380f95d21415c3e8
DIFF: https://github.com/llvm/llvm-project/commit/f5e0f8b10ab95e94b5ffb32e380f95d21415c3e8.diff

LOG: [lldb] Add test for importing ObjC modules in a non-ObjC target

This was previously crashing due to a missing nullptr check (see
e2d8aa6bf774ef29e134c40f886c55557bb5f970 ). This just adds a test that should
make sure this doesn't crash in case a user ends up in this strange setup.

Added: 
    lldb/test/API/lang/objc/modules-non-objc-target/Makefile
    lldb/test/API/lang/objc/modules-non-objc-target/TestObjCModulesNonObjCTarget.py
    lldb/test/API/lang/objc/modules-non-objc-target/main.c

Modified: 
    

Removed: 
    


################################################################################
diff  --git a/lldb/test/API/lang/objc/modules-non-objc-target/Makefile b/lldb/test/API/lang/objc/modules-non-objc-target/Makefile
new file mode 100644
index 000000000000..10495940055b
--- /dev/null
+++ b/lldb/test/API/lang/objc/modules-non-objc-target/Makefile
@@ -0,0 +1,3 @@
+C_SOURCES := main.c
+
+include Makefile.rules

diff  --git a/lldb/test/API/lang/objc/modules-non-objc-target/TestObjCModulesNonObjCTarget.py b/lldb/test/API/lang/objc/modules-non-objc-target/TestObjCModulesNonObjCTarget.py
new file mode 100644
index 000000000000..18283f6d2b33
--- /dev/null
+++ b/lldb/test/API/lang/objc/modules-non-objc-target/TestObjCModulesNonObjCTarget.py
@@ -0,0 +1,26 @@
+"""
+Tests that importing ObjC modules in a non-ObjC target doesn't crash LLDB.
+"""
+
+import lldb
+from lldbsuite.test.decorators import *
+from lldbsuite.test.lldbtest import *
+from lldbsuite.test import lldbutil
+
+class TestCase(TestBase):
+
+    mydir = TestBase.compute_mydir(__file__)
+
+    @skipUnlessDarwin
+    def test(self):
+        self.build()
+        lldbutil.run_to_source_breakpoint(self,"// break here", lldb.SBFileSpec("main.c"))
+
+        # Import foundation to get some ObjC types.
+        self.expect("expr --lang objc -- @import Foundation")
+        # Do something with NSString (which requires special handling when
+        # preparing to run in the target). The expression most likely can't
+        # be prepared to run in the target but it should at least not crash LLDB.
+        self.expect('expr --lang objc -- [NSString stringWithFormat:@"%d", 1];',
+                    error=True,
+                    substrs=["error: The expression could not be prepared to run in the target"])

diff  --git a/lldb/test/API/lang/objc/modules-non-objc-target/main.c b/lldb/test/API/lang/objc/modules-non-objc-target/main.c
new file mode 100644
index 000000000000..ba45ee316cd4
--- /dev/null
+++ b/lldb/test/API/lang/objc/modules-non-objc-target/main.c
@@ -0,0 +1,3 @@
+int main() {
+  return 0; // break here
+}


        


More information about the lldb-commits mailing list