================
@@ -0,0 +1,56 @@
+#include "support/Markdown.h"
+#include "llvm/Support/Casting.h"
+#include "gtest/gtest.h"
+
+using namespace clang::doc::markdown;
+using namespace llvm;
+
+namespace {
+
+TEST(MarkdownNodeTest, TextNode) {
+ TextNode N("hello");
+ EXPECT_EQ(N.Kind, NodeKind::NK_Text);
+ EXPECT_EQ(N.Text, "hello");
+}
+
+TEST(MarkdownNodeTest, FencedCodeNode) {
+ StringRef Lines[] = {"int x = 0;"};
+ FencedCodeNode N("cpp", ArrayRef(Lines));
+ EXPECT_EQ(N.Kind, NodeKind::NK_FencedCode);
+ EXPECT_EQ(N.Lang, "cpp");
+ EXPECT_EQ(N.Lines.size(), 1u);
+}
+
+TEST(MarkdownNodeTest, HeadingNode) {
+ HeadingNode N(2, {});
+ EXPECT_EQ(N.Kind, NodeKind::NK_Heading);
+ EXPECT_EQ(N.Level, 2u);
+}
+
+TEST(MarkdownNodeTest, ThematicBreakNode) {
+ ThematicBreakNode N;
+ EXPECT_EQ(N.Kind, NodeKind::NK_ThematicBreak);
+}
+
+TEST(MarkdownNodeTest, InlineCodeNode) {
+ InlineCodeNode N("foo()");
+ EXPECT_EQ(N.Kind, NodeKind::NK_InlineCode);
+ EXPECT_EQ(N.Code, "foo()");
+}
+
+TEST(MarkdownNodeTest, EmphasisNode) {
+ EmphasisNode N({});
+ EXPECT_EQ(N.Kind, NodeKind::NK_Emphasis);
+}
+
+TEST(MarkdownNodeTest, UnorderedListNode) {
+ UnorderedListNode N({});
----------------
ilovepi wrote:
This type of construction seems odd. If you're fine accepting an empty struct,
I think it makes sense to have a no args constructor.
https://github.com/llvm/llvm-project/pull/205609
_______________________________________________
cfe-commits mailing list
[email protected]
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits