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).
41 lines
1.5 KiB
Python
41 lines
1.5 KiB
Python
"""
|
|
Test that we respect the sysroot when building the std module.
|
|
"""
|
|
|
|
from lldbsuite.test.decorators import *
|
|
from lldbsuite.test.lldbtest import *
|
|
from lldbsuite.test import lldbutil
|
|
import os
|
|
|
|
|
|
class ImportStdModule(TestBase):
|
|
|
|
mydir = TestBase.compute_mydir(__file__)
|
|
|
|
# We only emulate a fake libc++ in this test and don't use the real libc++,
|
|
# but we still add the libc++ category so that this test is only run in
|
|
# test configurations where libc++ is actually supposed to be tested.
|
|
@add_test_categories(["libc++"])
|
|
@skipIf(compiler=no_match("clang"))
|
|
@skipIfRemote # This test messes with the platform, can't be run remotely.
|
|
def test(self):
|
|
self.build()
|
|
|
|
sysroot = os.path.join(os.getcwd(), "root")
|
|
|
|
# Set the sysroot.
|
|
self.runCmd("platform select --sysroot '" + sysroot + "' host",
|
|
CURRENT_EXECUTABLE_SET)
|
|
|
|
lldbutil.run_to_source_breakpoint(self,
|
|
"// Set break point at this line.",
|
|
lldb.SBFileSpec("main.cpp"))
|
|
|
|
self.runCmd("settings set target.import-std-module true")
|
|
|
|
# Call our custom function in our sysroot std module.
|
|
# If this gives us the correct result, then we used the sysroot.
|
|
# We rely on the default argument of -123 to make sure we actually have the C++ module.
|
|
# (We don't have default arguments in the debug information).
|
|
self.expect("expr std::myabs()", substrs=['(int) $0 = 123'])
|