2018-10-17 07:07:26 +08:00
|
|
|
//===-- clang-doc/MDGeneratorTest.cpp -------------------------------------===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// 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
|
2018-10-17 07:07:26 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "ClangDocTest.h"
|
|
|
|
#include "Generators.h"
|
|
|
|
#include "Representation.h"
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
|
|
|
namespace clang {
|
|
|
|
namespace doc {
|
|
|
|
|
|
|
|
std::unique_ptr<Generator> getMDGenerator() {
|
|
|
|
auto G = doc::findGeneratorByName("md");
|
|
|
|
if (!G)
|
|
|
|
return nullptr;
|
|
|
|
return std::move(G.get());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(MDGeneratorTest, emitNamespaceMD) {
|
|
|
|
NamespaceInfo I;
|
|
|
|
I.Name = "Namespace";
|
|
|
|
I.Namespace.emplace_back(EmptySID, "A", InfoType::IT_namespace);
|
|
|
|
|
|
|
|
I.ChildNamespaces.emplace_back(EmptySID, "ChildNamespace",
|
|
|
|
InfoType::IT_namespace);
|
|
|
|
I.ChildRecords.emplace_back(EmptySID, "ChildStruct", InfoType::IT_record);
|
|
|
|
I.ChildFunctions.emplace_back();
|
|
|
|
I.ChildFunctions.back().Name = "OneFunction";
|
2019-08-16 07:04:27 +08:00
|
|
|
I.ChildFunctions.back().Access = AccessSpecifier::AS_none;
|
2018-10-17 07:07:26 +08:00
|
|
|
I.ChildEnums.emplace_back();
|
|
|
|
I.ChildEnums.back().Name = "OneEnum";
|
|
|
|
|
|
|
|
auto G = getMDGenerator();
|
|
|
|
assert(G);
|
|
|
|
std::string Buffer;
|
|
|
|
llvm::raw_string_ostream Actual(Buffer);
|
2019-07-26 06:46:40 +08:00
|
|
|
auto Err = G->generateDocForInfo(&I, Actual, ClangDocContext());
|
2018-10-17 07:07:26 +08:00
|
|
|
assert(!Err);
|
|
|
|
std::string Expected = R"raw(# namespace Namespace
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## Namespaces
|
|
|
|
|
2020-03-07 09:33:56 +08:00
|
|
|
* [ChildNamespace](../ChildNamespace/index.md)
|
2018-10-17 07:07:26 +08:00
|
|
|
|
|
|
|
|
|
|
|
## Records
|
|
|
|
|
2020-03-07 09:33:56 +08:00
|
|
|
* [ChildStruct](../ChildStruct.md)
|
2018-10-17 07:07:26 +08:00
|
|
|
|
|
|
|
|
|
|
|
## Functions
|
|
|
|
|
|
|
|
### OneFunction
|
|
|
|
|
|
|
|
* OneFunction()*
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## Enums
|
|
|
|
|
|
|
|
| enum OneEnum |
|
|
|
|
|
|
|
|
--
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
)raw";
|
|
|
|
EXPECT_EQ(Expected, Actual.str());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(MDGeneratorTest, emitRecordMD) {
|
|
|
|
RecordInfo I;
|
|
|
|
I.Name = "r";
|
|
|
|
I.Namespace.emplace_back(EmptySID, "A", InfoType::IT_namespace);
|
|
|
|
|
|
|
|
I.DefLoc = Location(10, llvm::SmallString<16>{"test.cpp"});
|
|
|
|
I.Loc.emplace_back(12, llvm::SmallString<16>{"test.cpp"});
|
|
|
|
|
|
|
|
I.Members.emplace_back("int", "X", AccessSpecifier::AS_private);
|
|
|
|
I.TagType = TagTypeKind::TTK_Class;
|
|
|
|
I.Parents.emplace_back(EmptySID, "F", InfoType::IT_record);
|
|
|
|
I.VirtualParents.emplace_back(EmptySID, "G", InfoType::IT_record);
|
|
|
|
|
|
|
|
I.ChildRecords.emplace_back(EmptySID, "ChildStruct", InfoType::IT_record);
|
|
|
|
I.ChildFunctions.emplace_back();
|
|
|
|
I.ChildFunctions.back().Name = "OneFunction";
|
|
|
|
I.ChildEnums.emplace_back();
|
|
|
|
I.ChildEnums.back().Name = "OneEnum";
|
|
|
|
|
|
|
|
auto G = getMDGenerator();
|
|
|
|
assert(G);
|
|
|
|
std::string Buffer;
|
|
|
|
llvm::raw_string_ostream Actual(Buffer);
|
2019-07-26 06:46:40 +08:00
|
|
|
auto Err = G->generateDocForInfo(&I, Actual, ClangDocContext());
|
2018-10-17 07:07:26 +08:00
|
|
|
assert(!Err);
|
|
|
|
std::string Expected = R"raw(# class r
|
|
|
|
|
2020-03-07 09:33:56 +08:00
|
|
|
*Defined at test.cpp#10*
|
2018-10-17 07:07:26 +08:00
|
|
|
|
|
|
|
Inherits from F, G
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## Members
|
|
|
|
|
|
|
|
private int X
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## Records
|
|
|
|
|
|
|
|
ChildStruct
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## Functions
|
|
|
|
|
|
|
|
### OneFunction
|
|
|
|
|
2019-08-16 07:04:27 +08:00
|
|
|
*public OneFunction()*
|
2018-10-17 07:07:26 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## Enums
|
|
|
|
|
|
|
|
| enum OneEnum |
|
|
|
|
|
|
|
|
--
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
)raw";
|
|
|
|
EXPECT_EQ(Expected, Actual.str());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(MDGeneratorTest, emitFunctionMD) {
|
|
|
|
FunctionInfo I;
|
|
|
|
I.Name = "f";
|
|
|
|
I.Namespace.emplace_back(EmptySID, "A", InfoType::IT_namespace);
|
|
|
|
|
|
|
|
I.DefLoc = Location(10, llvm::SmallString<16>{"test.cpp"});
|
|
|
|
I.Loc.emplace_back(12, llvm::SmallString<16>{"test.cpp"});
|
|
|
|
|
2019-08-16 07:04:27 +08:00
|
|
|
I.Access = AccessSpecifier::AS_none;
|
|
|
|
|
2018-10-17 07:07:26 +08:00
|
|
|
I.ReturnType = TypeInfo(EmptySID, "void", InfoType::IT_default);
|
|
|
|
I.Params.emplace_back("int", "P");
|
|
|
|
I.IsMethod = true;
|
|
|
|
I.Parent = Reference(EmptySID, "Parent", InfoType::IT_record);
|
|
|
|
|
|
|
|
auto G = getMDGenerator();
|
|
|
|
assert(G);
|
|
|
|
std::string Buffer;
|
|
|
|
llvm::raw_string_ostream Actual(Buffer);
|
2019-07-26 06:46:40 +08:00
|
|
|
auto Err = G->generateDocForInfo(&I, Actual, ClangDocContext());
|
2018-10-17 07:07:26 +08:00
|
|
|
assert(!Err);
|
|
|
|
std::string Expected = R"raw(### f
|
|
|
|
|
|
|
|
*void f(int P)*
|
|
|
|
|
2020-03-07 09:33:56 +08:00
|
|
|
*Defined at test.cpp#10*
|
2018-10-17 07:07:26 +08:00
|
|
|
|
|
|
|
)raw";
|
|
|
|
|
|
|
|
EXPECT_EQ(Expected, Actual.str());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(MDGeneratorTest, emitEnumMD) {
|
|
|
|
EnumInfo I;
|
|
|
|
I.Name = "e";
|
|
|
|
I.Namespace.emplace_back(EmptySID, "A", InfoType::IT_namespace);
|
|
|
|
|
|
|
|
I.DefLoc = Location(10, llvm::SmallString<16>{"test.cpp"});
|
|
|
|
I.Loc.emplace_back(12, llvm::SmallString<16>{"test.cpp"});
|
|
|
|
|
|
|
|
I.Members.emplace_back("X");
|
|
|
|
I.Scoped = true;
|
|
|
|
|
|
|
|
auto G = getMDGenerator();
|
|
|
|
assert(G);
|
|
|
|
std::string Buffer;
|
|
|
|
llvm::raw_string_ostream Actual(Buffer);
|
2019-07-26 06:46:40 +08:00
|
|
|
auto Err = G->generateDocForInfo(&I, Actual, ClangDocContext());
|
2018-10-17 07:07:26 +08:00
|
|
|
assert(!Err);
|
|
|
|
std::string Expected = R"raw(| enum class e |
|
|
|
|
|
|
|
|
--
|
|
|
|
|
|
|
|
| X |
|
|
|
|
|
|
|
|
|
2020-03-07 09:33:56 +08:00
|
|
|
*Defined at test.cpp#10*
|
2018-10-17 07:07:26 +08:00
|
|
|
|
|
|
|
)raw";
|
|
|
|
|
|
|
|
EXPECT_EQ(Expected, Actual.str());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(MDGeneratorTest, emitCommentMD) {
|
|
|
|
FunctionInfo I;
|
|
|
|
I.Name = "f";
|
|
|
|
I.DefLoc = Location(10, llvm::SmallString<16>{"test.cpp"});
|
|
|
|
I.ReturnType = TypeInfo(EmptySID, "void", InfoType::IT_default);
|
|
|
|
I.Params.emplace_back("int", "I");
|
|
|
|
I.Params.emplace_back("int", "J");
|
2019-08-16 07:04:27 +08:00
|
|
|
I.Access = AccessSpecifier::AS_none;
|
2018-10-17 07:07:26 +08:00
|
|
|
|
|
|
|
CommentInfo Top;
|
|
|
|
Top.Kind = "FullComment";
|
|
|
|
|
2019-08-15 07:52:23 +08:00
|
|
|
Top.Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
CommentInfo *BlankLine = Top.Children.back().get();
|
|
|
|
BlankLine->Kind = "ParagraphComment";
|
2019-08-15 07:52:23 +08:00
|
|
|
BlankLine->Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
BlankLine->Children.back()->Kind = "TextComment";
|
|
|
|
|
2019-08-15 07:52:23 +08:00
|
|
|
Top.Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
CommentInfo *Brief = Top.Children.back().get();
|
|
|
|
Brief->Kind = "ParagraphComment";
|
2019-08-15 07:52:23 +08:00
|
|
|
Brief->Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
Brief->Children.back()->Kind = "TextComment";
|
|
|
|
Brief->Children.back()->Name = "ParagraphComment";
|
|
|
|
Brief->Children.back()->Text = " Brief description.";
|
|
|
|
|
2019-08-15 07:52:23 +08:00
|
|
|
Top.Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
CommentInfo *Extended = Top.Children.back().get();
|
|
|
|
Extended->Kind = "ParagraphComment";
|
2019-08-15 07:52:23 +08:00
|
|
|
Extended->Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
Extended->Children.back()->Kind = "TextComment";
|
|
|
|
Extended->Children.back()->Text = " Extended description that";
|
2019-08-15 07:52:23 +08:00
|
|
|
Extended->Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
Extended->Children.back()->Kind = "TextComment";
|
|
|
|
Extended->Children.back()->Text = " continues onto the next line.";
|
|
|
|
|
2019-08-15 07:52:23 +08:00
|
|
|
Top.Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
CommentInfo *HTML = Top.Children.back().get();
|
|
|
|
HTML->Kind = "ParagraphComment";
|
2019-08-15 07:52:23 +08:00
|
|
|
HTML->Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
HTML->Children.back()->Kind = "TextComment";
|
2019-08-15 07:52:23 +08:00
|
|
|
HTML->Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
HTML->Children.back()->Kind = "HTMLStartTagComment";
|
|
|
|
HTML->Children.back()->Name = "ul";
|
|
|
|
HTML->Children.back()->AttrKeys.emplace_back("class");
|
|
|
|
HTML->Children.back()->AttrValues.emplace_back("test");
|
2019-08-15 07:52:23 +08:00
|
|
|
HTML->Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
HTML->Children.back()->Kind = "HTMLStartTagComment";
|
|
|
|
HTML->Children.back()->Name = "li";
|
2019-08-15 07:52:23 +08:00
|
|
|
HTML->Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
HTML->Children.back()->Kind = "TextComment";
|
|
|
|
HTML->Children.back()->Text = " Testing.";
|
2019-08-15 07:52:23 +08:00
|
|
|
HTML->Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
HTML->Children.back()->Kind = "HTMLEndTagComment";
|
|
|
|
HTML->Children.back()->Name = "ul";
|
|
|
|
HTML->Children.back()->SelfClosing = true;
|
|
|
|
|
2019-08-15 07:52:23 +08:00
|
|
|
Top.Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
CommentInfo *Verbatim = Top.Children.back().get();
|
|
|
|
Verbatim->Kind = "VerbatimBlockComment";
|
|
|
|
Verbatim->Name = "verbatim";
|
|
|
|
Verbatim->CloseName = "endverbatim";
|
2019-08-15 07:52:23 +08:00
|
|
|
Verbatim->Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
Verbatim->Children.back()->Kind = "VerbatimBlockLineComment";
|
|
|
|
Verbatim->Children.back()->Text = " The description continues.";
|
|
|
|
|
2019-08-15 07:52:23 +08:00
|
|
|
Top.Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
CommentInfo *ParamOut = Top.Children.back().get();
|
|
|
|
ParamOut->Kind = "ParamCommandComment";
|
|
|
|
ParamOut->Direction = "[out]";
|
|
|
|
ParamOut->ParamName = "I";
|
|
|
|
ParamOut->Explicit = true;
|
2019-08-15 07:52:23 +08:00
|
|
|
ParamOut->Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
ParamOut->Children.back()->Kind = "ParagraphComment";
|
|
|
|
ParamOut->Children.back()->Children.emplace_back(
|
2019-08-15 07:52:23 +08:00
|
|
|
std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
ParamOut->Children.back()->Children.back()->Kind = "TextComment";
|
|
|
|
ParamOut->Children.back()->Children.emplace_back(
|
2019-08-15 07:52:23 +08:00
|
|
|
std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
ParamOut->Children.back()->Children.back()->Kind = "TextComment";
|
|
|
|
ParamOut->Children.back()->Children.back()->Text = " is a parameter.";
|
|
|
|
|
2019-08-15 07:52:23 +08:00
|
|
|
Top.Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
CommentInfo *ParamIn = Top.Children.back().get();
|
|
|
|
ParamIn->Kind = "ParamCommandComment";
|
|
|
|
ParamIn->Direction = "[in]";
|
|
|
|
ParamIn->ParamName = "J";
|
2019-08-15 07:52:23 +08:00
|
|
|
ParamIn->Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
ParamIn->Children.back()->Kind = "ParagraphComment";
|
|
|
|
ParamIn->Children.back()->Children.emplace_back(
|
2019-08-15 07:52:23 +08:00
|
|
|
std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
ParamIn->Children.back()->Children.back()->Kind = "TextComment";
|
|
|
|
ParamIn->Children.back()->Children.back()->Text = " is a parameter.";
|
|
|
|
ParamIn->Children.back()->Children.emplace_back(
|
2019-08-15 07:52:23 +08:00
|
|
|
std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
ParamIn->Children.back()->Children.back()->Kind = "TextComment";
|
|
|
|
|
2019-08-15 07:52:23 +08:00
|
|
|
Top.Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
CommentInfo *Return = Top.Children.back().get();
|
|
|
|
Return->Kind = "BlockCommandComment";
|
|
|
|
Return->Name = "return";
|
|
|
|
Return->Explicit = true;
|
2019-08-15 07:52:23 +08:00
|
|
|
Return->Children.emplace_back(std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
Return->Children.back()->Kind = "ParagraphComment";
|
|
|
|
Return->Children.back()->Children.emplace_back(
|
2019-08-15 07:52:23 +08:00
|
|
|
std::make_unique<CommentInfo>());
|
2018-10-17 07:07:26 +08:00
|
|
|
Return->Children.back()->Children.back()->Kind = "TextComment";
|
|
|
|
Return->Children.back()->Children.back()->Text = "void";
|
|
|
|
|
|
|
|
I.Description.emplace_back(std::move(Top));
|
|
|
|
|
|
|
|
auto G = getMDGenerator();
|
|
|
|
assert(G);
|
|
|
|
std::string Buffer;
|
|
|
|
llvm::raw_string_ostream Actual(Buffer);
|
2019-07-26 06:46:40 +08:00
|
|
|
auto Err = G->generateDocForInfo(&I, Actual, ClangDocContext());
|
2018-10-17 07:07:26 +08:00
|
|
|
assert(!Err);
|
|
|
|
std::string Expected =
|
|
|
|
R"raw(### f
|
|
|
|
|
|
|
|
*void f(int I, int J)*
|
|
|
|
|
2020-03-07 09:33:56 +08:00
|
|
|
*Defined at test.cpp#10*
|
2018-10-17 07:07:26 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Brief description.
|
|
|
|
|
|
|
|
Extended description that continues onto the next line.
|
|
|
|
|
|
|
|
<ul "class=test">
|
|
|
|
|
|
|
|
<li>
|
|
|
|
|
|
|
|
Testing.</ul>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
The description continues.
|
|
|
|
|
|
|
|
**I** [out]
|
|
|
|
|
|
|
|
**J**
|
|
|
|
|
|
|
|
**return**void
|
|
|
|
|
|
|
|
)raw";
|
|
|
|
|
|
|
|
EXPECT_EQ(Expected, Actual.str());
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace doc
|
|
|
|
} // namespace clang
|