1""" 2Test that LLDB doesn't crash if the std module we load is empty. 3""" 4 5from lldbsuite.test.decorators import * 6from lldbsuite.test.lldbtest import * 7from lldbsuite.test import lldbutil 8import os 9 10class ImportStdModule(TestBase): 11 12 mydir = TestBase.compute_mydir(__file__) 13 14 # We only emulate a fake libc++ in this test and don't use the real libc++, 15 # but we still add the libc++ category so that this test is only run in 16 # test configurations where libc++ is actually supposed to be tested. 17 @add_test_categories(["libc++"]) 18 @skipIfRemote 19 @skipIf(compiler=no_match("clang")) 20 def test(self): 21 self.build() 22 23 sysroot = os.path.join(os.getcwd(), "root") 24 25 # Set the sysroot. 26 self.runCmd("platform select --sysroot '" + sysroot + "' host", CURRENT_EXECUTABLE_SET) 27 28 lldbutil.run_to_source_breakpoint(self, 29 "// Set break point at this line.", lldb.SBFileSpec("main.cpp")) 30 31 self.runCmd("settings set target.import-std-module true") 32 33 # Use the typedef that is only defined in our 'empty' module. If this fails, then LLDB 34 # somehow figured out the correct define for the header and compiled the right 35 # standard module that actually contains the std::vector template. 36 self.expect("expr MissingContent var = 3; var", substrs=['$0 = 3']) 37 # Try to access our mock std::vector. This should fail but not crash LLDB as the 38 # std::vector template should be missing from the std module. 39 self.expect("expr (size_t)v.size()", substrs=["Couldn't lookup symbols"], error=True) 40