With the recent patches to the ASTImporter that improve template type importing (D87444), most of the import-std-module tests can now finally import the type of the STL container they are testing. This patch removes most of the casts that were added to simplify types to something the ASTImporter can import (for example, std::vector<int>::size_type was casted to `size_t` until now). Also adds the missing tests that require referencing the container type (for example simply printing the whole container) as here we couldn't use a casting workaround. The only casts that remain are in the forward_list tests that reference the iterator and the stack test. Both tests are still failing to import the respective container type correctly (or crash while trying to import).
38 lines
1.3 KiB
Python
38 lines
1.3 KiB
Python
"""
|
|
Test that importing the std module on a compile unit
|
|
that doesn't use the std module will not break LLDB.
|
|
|
|
It's not really specified at the moment what kind of
|
|
error we should report back to the user in this
|
|
situation. Currently Clang will just complain that
|
|
the std module doesn't exist or can't be loaded.
|
|
"""
|
|
|
|
from lldbsuite.test.decorators import *
|
|
from lldbsuite.test.lldbtest import *
|
|
from lldbsuite.test import lldbutil
|
|
|
|
|
|
class STLTestCase(TestBase):
|
|
|
|
mydir = TestBase.compute_mydir(__file__)
|
|
|
|
@add_test_categories(["libc++"])
|
|
@skipIf(compiler=no_match("clang"))
|
|
def test(self):
|
|
self.build()
|
|
|
|
lldbutil.run_to_source_breakpoint(self,
|
|
"// Set break point at this line.",
|
|
lldb.SBFileSpec("main.cpp"))
|
|
|
|
# Activate importing of std module.
|
|
self.runCmd("settings set target.import-std-module true")
|
|
|
|
# Run some commands that should all fail without our std module.
|
|
self.expect("expr std::abs(-42)", error=True)
|
|
self.expect("expr std::div(2, 1).quot", error=True)
|
|
self.expect("expr (std::size_t)33U", error=True)
|
|
self.expect("expr char a = 'b'; char b = 'a'; std::swap(a, b); a",
|
|
error=True)
|