forked from OSchip/llvm-project
[clangd] Add separate unit tests for CanonicalIncludes. NFC
llvm-svn: 359455
This commit is contained in:
parent
9d4ed24f25
commit
9cbe82d57f
|
@ -25,6 +25,7 @@ add_unittest(ClangdUnitTests ClangdTests
|
|||
Annotations.cpp
|
||||
BackgroundIndexTests.cpp
|
||||
CancellationTests.cpp
|
||||
CanonicalIncludesTests.cpp
|
||||
ClangdTests.cpp
|
||||
ClangdUnitTests.cpp
|
||||
CodeCompleteTests.cpp
|
||||
|
|
|
@ -0,0 +1,62 @@
|
|||
//===-- CanonicalIncludesTests.cpp - --------------------------------------===//
|
||||
//
|
||||
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
||||
// See https://llvm.org/LICENSE.txt for license information.
|
||||
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "index/CanonicalIncludes.h"
|
||||
#include "gtest/gtest.h"
|
||||
|
||||
namespace clang {
|
||||
namespace clangd {
|
||||
namespace {
|
||||
|
||||
TEST(CanonicalIncludesTest, CXXStandardLibrary) {
|
||||
CanonicalIncludes CI;
|
||||
addSystemHeadersMapping(&CI);
|
||||
|
||||
// Usual standard library symbols are mapped correctly.
|
||||
EXPECT_EQ("<vector>", CI.mapHeader("path/vector.h", "std::vector"));
|
||||
// std::move is ambiguous, currently mapped only based on path
|
||||
EXPECT_EQ("<utility>", CI.mapHeader("libstdc++/bits/move.h", "std::move"));
|
||||
EXPECT_EQ("path/utility.h", CI.mapHeader("path/utility.h", "std::move"));
|
||||
// Unknown std symbols aren't mapped.
|
||||
EXPECT_EQ("foo/bar.h", CI.mapHeader("foo/bar.h", "std::notathing"));
|
||||
// iosfwd declares some symbols it doesn't own.
|
||||
EXPECT_EQ("<ostream>", CI.mapHeader("iosfwd", "std::ostream"));
|
||||
// And (for now) we assume it owns the others.
|
||||
EXPECT_EQ("<iosfwd>", CI.mapHeader("iosfwd", "std::notwathing"));
|
||||
}
|
||||
|
||||
TEST(CanonicalIncludesTest, PathMapping) {
|
||||
// As used for IWYU pragmas.
|
||||
CanonicalIncludes CI;
|
||||
CI.addMapping("foo/bar", "<baz>");
|
||||
|
||||
EXPECT_EQ("<baz>", CI.mapHeader("foo/bar", "some::symbol"));
|
||||
EXPECT_EQ("bar/bar", CI.mapHeader("bar/bar", "some::symbol"));
|
||||
}
|
||||
|
||||
TEST(CanonicalIncludesTest, SymbolMapping) {
|
||||
// As used for standard library.
|
||||
CanonicalIncludes CI;
|
||||
CI.addSymbolMapping("some::symbol", "<baz>");
|
||||
|
||||
EXPECT_EQ("<baz>", CI.mapHeader("foo/bar", "some::symbol"));
|
||||
EXPECT_EQ("foo/bar", CI.mapHeader("foo/bar", "other::symbol"));
|
||||
}
|
||||
|
||||
TEST(CanonicalIncludesTest, Precedence) {
|
||||
CanonicalIncludes CI;
|
||||
CI.addMapping("some/path", "<path>");
|
||||
CI.addSymbolMapping("some::symbol", "<symbol>");
|
||||
|
||||
// Symbol mapping beats path mapping.
|
||||
EXPECT_EQ("<symbol>", CI.mapHeader("some/path", "some::symbol"));
|
||||
}
|
||||
|
||||
} // namespace
|
||||
} // namespace clangd
|
||||
} // namespace clang
|
|
@ -931,47 +931,15 @@ TEST_F(SymbolCollectorTest, IncludeHeaderSameAsFileURI) {
|
|||
UnorderedElementsAre(IncludeHeaderWithRef(TestHeaderURI, 1u)));
|
||||
}
|
||||
|
||||
#ifndef _WIN32
|
||||
TEST_F(SymbolCollectorTest, CanonicalSTLHeader) {
|
||||
CollectorOpts.CollectIncludePath = true;
|
||||
CanonicalIncludes Includes;
|
||||
addSystemHeadersMapping(&Includes);
|
||||
CollectorOpts.Includes = &Includes;
|
||||
// bits/basic_string.h$ should be mapped to <string>
|
||||
TestHeaderName = "/nasty/bits/basic_string.h";
|
||||
TestFileName = "/nasty/bits/basic_string.cpp";
|
||||
TestHeaderURI = URI::create(TestHeaderName).toString();
|
||||
runSymbolCollector("class string {};", /*Main=*/"");
|
||||
EXPECT_THAT(Symbols, UnorderedElementsAre(AllOf(QName("string"),
|
||||
DeclURI(TestHeaderURI),
|
||||
IncludeHeader("<string>"))));
|
||||
}
|
||||
#endif
|
||||
|
||||
TEST_F(SymbolCollectorTest, STLiosfwd) {
|
||||
CollectorOpts.CollectIncludePath = true;
|
||||
CanonicalIncludes Includes;
|
||||
addSystemHeadersMapping(&Includes);
|
||||
CollectorOpts.Includes = &Includes;
|
||||
// Symbols from <iosfwd> should be mapped individually.
|
||||
TestHeaderName = testPath("iosfwd");
|
||||
TestFileName = testPath("iosfwd.cpp");
|
||||
std::string Header = R"(
|
||||
namespace std {
|
||||
class no_map {};
|
||||
class ios {};
|
||||
class ostream {};
|
||||
class filebuf {};
|
||||
} // namespace std
|
||||
)";
|
||||
runSymbolCollector(Header, /*Main=*/"");
|
||||
runSymbolCollector("namespace std { class string {}; }", /*Main=*/"");
|
||||
EXPECT_THAT(Symbols,
|
||||
UnorderedElementsAre(
|
||||
QName("std"),
|
||||
AllOf(QName("std::no_map"), IncludeHeader("<iosfwd>")),
|
||||
AllOf(QName("std::ios"), IncludeHeader("<ios>")),
|
||||
AllOf(QName("std::ostream"), IncludeHeader("<ostream>")),
|
||||
AllOf(QName("std::filebuf"), IncludeHeader("<fstream>"))));
|
||||
Contains(AllOf(QName("std::string"), DeclURI(TestHeaderURI),
|
||||
IncludeHeader("<string>"))));
|
||||
}
|
||||
|
||||
TEST_F(SymbolCollectorTest, IWYUPragma) {
|
||||
|
|
Loading…
Reference in New Issue