[clangd] Add separate unit tests for CanonicalIncludes. NFC

llvm-svn: 359455
This commit is contained in:
Sam McCall 2019-04-29 14:36:26 +00:00
parent 9d4ed24f25
commit 9cbe82d57f
3 changed files with 66 additions and 35 deletions

View File

@ -25,6 +25,7 @@ add_unittest(ClangdUnitTests ClangdTests
Annotations.cpp
BackgroundIndexTests.cpp
CancellationTests.cpp
CanonicalIncludesTests.cpp
ClangdTests.cpp
ClangdUnitTests.cpp
CodeCompleteTests.cpp

View File

@ -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

View File

@ -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) {