summaryrefslogtreecommitdiffstats
path: root/lldb/packages/Python/lldbsuite/test/lang/objc/modules-update/TestClangModulesUpdate.py
diff options
context:
space:
mode:
authorAdrian Prantl <aprantl@apple.com>2019-11-15 16:25:46 -0800
committerAdrian Prantl <aprantl@apple.com>2019-11-15 16:27:14 -0800
commit0304360a40b45ffcbb040596d2a01733c0103455 (patch)
treeca756660dced21f62c168a3eeb74c2078fe6ec55 /lldb/packages/Python/lldbsuite/test/lang/objc/modules-update/TestClangModulesUpdate.py
parentd295087639a824d1c0a29868bab1860afe657eaf (diff)
downloadbcm5719-llvm-0304360a40b45ffcbb040596d2a01733c0103455.tar.gz
bcm5719-llvm-0304360a40b45ffcbb040596d2a01733c0103455.zip
Add a testcase for Clang modules being updated within one LLDB session.
This actually works as expected, but wasn't explicitly tested before.
Diffstat (limited to 'lldb/packages/Python/lldbsuite/test/lang/objc/modules-update/TestClangModulesUpdate.py')
-rw-r--r--lldb/packages/Python/lldbsuite/test/lang/objc/modules-update/TestClangModulesUpdate.py69
1 files changed, 69 insertions, 0 deletions
diff --git a/lldb/packages/Python/lldbsuite/test/lang/objc/modules-update/TestClangModulesUpdate.py b/lldb/packages/Python/lldbsuite/test/lang/objc/modules-update/TestClangModulesUpdate.py
new file mode 100644
index 00000000000..28e4fe46cb5
--- /dev/null
+++ b/lldb/packages/Python/lldbsuite/test/lang/objc/modules-update/TestClangModulesUpdate.py
@@ -0,0 +1,69 @@
+from __future__ import print_function
+
+import unittest2
+import os
+import shutil
+
+import lldb
+from lldbsuite.test.decorators import *
+from lldbsuite.test.lldbtest import *
+from lldbsuite.test import lldbutil
+
+
+class TestClangModuleUpdate(TestBase):
+ mydir = TestBase.compute_mydir(__file__)
+
+ def setUp(self):
+ TestBase.setUp(self)
+
+ @skipUnlessDarwin
+ @skipIf(debug_info=no_match(["gmodules"]))
+ def test_expr(self):
+ with open(self.getBuildArtifact("module.modulemap"), "w") as f:
+ f.write("""
+ module Foo { header "f.h" }
+ """)
+ with open(self.getBuildArtifact("f.h"), "w") as f:
+ f.write("""
+ struct Q { int i; };
+ void f() {}
+ """)
+
+ mod_cache = self.getBuildArtifact("private-module-cache")
+ if os.path.isdir(mod_cache):
+ shutil.rmtree(mod_cache)
+ d = {'OBJC_SOURCES': 'first.m'}
+ self.build(dictionary=d)
+ self.assertTrue(os.path.isdir(mod_cache), "module cache exists")
+
+ logfile = self.getBuildArtifact("modules.log")
+ self.runCmd("log enable -f %s lldb module" % logfile)
+ target, process, _, bkpt = lldbutil.run_to_name_breakpoint(self, "main")
+ self.assertIn("int i", str(target.FindTypes('Q').GetTypeAtIndex(0)))
+ self.expect("image list -g", patterns=[r'first\.o', r'Foo.*\.pcm'])
+
+ # Update the module.
+ with open(self.getBuildArtifact("f.h"), "w") as f:
+ f.write("""
+ struct S { int i; };
+ struct S getS() { struct S r = {1}; return r; }
+ void f() {}
+ """)
+
+ # Rebuild.
+ d = {'OBJC_SOURCES': 'second.m'}
+ self.build(dictionary=d)
+
+ # Reattach.
+ process.Kill()
+ target, process, _, _ = lldbutil.run_to_breakpoint_do_run(self, target, bkpt)
+ self.assertIn("int i", str(target.FindTypes('S').GetTypeAtIndex(0)))
+ self.expect("image list -g", patterns=[r'second\.o', r'Foo.*\.pcm'])
+
+ # Check log file.
+ found = False
+ with open(logfile, 'r') as f:
+ for line in f:
+ if "module changed" in line and "Foo" in line:
+ found = True
+ self.assertTrue(found)
OpenPOWER on IntegriCloud