diff mlir/unittests/TableGen/FormatTest.cpp @ 150:1d019706d866

LLVM10
author anatofuz
date Thu, 13 Feb 2020 15:10:13 +0900
parents
children 2e18cbf3894f
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/mlir/unittests/TableGen/FormatTest.cpp	Thu Feb 13 15:10:13 2020 +0900
@@ -0,0 +1,158 @@
+//===- FormatTest.cpp - TableGen Format Utility Tests ---------------------===//
+//
+// 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 "mlir/TableGen/Format.h"
+#include "gmock/gmock.h"
+
+using mlir::tblgen::FmtContext;
+using mlir::tblgen::tgfmt;
+using ::testing::StrEq;
+
+TEST(FormatTest, EmptyFmtStr) {
+  FmtContext ctx;
+  std::string result = std::string(tgfmt("", &ctx));
+  EXPECT_TRUE(result.empty());
+}
+
+// Allow extra unused positional parameters
+TEST(FormatTest, EmptyFmtStrExtraParams) {
+  FmtContext ctx;
+  std::string result = std::string(tgfmt("", &ctx, "a", "b", "c"));
+  EXPECT_TRUE(result.empty());
+}
+
+// Allow unused placeholder substitution in context
+TEST(FormatTest, EmptyFmtStrPopulatedCtx) {
+  FmtContext ctx;
+  ctx.withBuilder("builder");
+  std::string result = std::string(tgfmt("", &ctx));
+  EXPECT_TRUE(result.empty());
+}
+
+TEST(FormatTest, LiteralFmtStr) {
+  FmtContext ctx;
+  std::string result = std::string(tgfmt("void foo {}", &ctx));
+  EXPECT_THAT(result, StrEq("void foo {}"));
+}
+
+// Print single dollar literally
+TEST(FormatTest, AdjacentDollar) {
+  FmtContext ctx;
+  std::string result = std::string(tgfmt("$", &ctx));
+  EXPECT_THAT(result, StrEq("$"));
+}
+
+// Print dangling dollar literally
+TEST(FormatTest, DanglingDollar) {
+  FmtContext ctx;
+  std::string result = std::string(tgfmt("foo bar baz$", &ctx));
+  EXPECT_THAT(result, StrEq("foo bar baz$"));
+}
+
+// Allow escape dollars with '$$'
+TEST(FormatTest, EscapeDollars) {
+  FmtContext ctx;
+  std::string result =
+      std::string(tgfmt("$$ $$$$ $$$0 $$$_self", &ctx.withSelf("self"), "-0"));
+  EXPECT_THAT(result, StrEq("$ $$ $-0 $self"));
+}
+
+TEST(FormatTest, PositionalFmtStr) {
+  FmtContext ctx;
+  std::string b = "b";
+  int c = 42;
+  char d = 'd';
+  std::string result =
+      std::string(tgfmt("$0 $1 $2 $3", &ctx, "a", b, c + 1, d));
+  EXPECT_THAT(result, StrEq("a b 43 d"));
+}
+
+// Output the placeholder if missing substitution
+TEST(FormatTest, PositionalFmtStrMissingParams) {
+  FmtContext ctx;
+  std::string result = std::string(tgfmt("$0 %1 $2", &ctx));
+  EXPECT_THAT(result, StrEq("$0<no-subst-found> %1 $2<no-subst-found>"));
+}
+
+// Allow flexible reference of positional parameters
+TEST(FormatTest, PositionalFmtStrFlexibleRef) {
+  FmtContext ctx;
+  std::string result = std::string(tgfmt("$2 $0 $2", &ctx, "a", "b", "c"));
+  EXPECT_THAT(result, StrEq("c a c"));
+}
+
+TEST(FormatTest, PositionalFmtStrNoWhitespace) {
+  FmtContext ctx;
+  std::string result = std::string(tgfmt("foo$0bar", &ctx, "-"));
+  EXPECT_THAT(result, StrEq("foo-bar"));
+}
+
+TEST(FormatTest, PlaceHolderFmtStrWithSelf) {
+  FmtContext ctx;
+  std::string result = std::string(tgfmt("$_self", &ctx.withSelf("sss")));
+  EXPECT_THAT(result, StrEq("sss"));
+}
+
+TEST(FormatTest, PlaceHolderFmtStrWithBuilder) {
+  FmtContext ctx;
+
+  std::string result = std::string(tgfmt("$_builder", &ctx.withBuilder("bbb")));
+  EXPECT_THAT(result, StrEq("bbb"));
+}
+
+TEST(FormatTest, PlaceHolderFmtStrWithOp) {
+  FmtContext ctx;
+  std::string result = std::string(tgfmt("$_op", &ctx.withOp("ooo")));
+  EXPECT_THAT(result, StrEq("ooo"));
+}
+
+TEST(FormatTest, PlaceHolderMissingCtx) {
+  std::string result = std::string(tgfmt("$_op", nullptr));
+  EXPECT_THAT(result, StrEq("$_op<no-subst-found>"));
+}
+
+TEST(FormatTest, PlaceHolderMissingSubst) {
+  FmtContext ctx;
+  std::string result = std::string(tgfmt("$_op", &ctx.withBuilder("builder")));
+  EXPECT_THAT(result, StrEq("$_op<no-subst-found>"));
+}
+
+// Test commonly used delimiters in C++
+TEST(FormatTest, PlaceHolderFmtStrDelimiter) {
+  FmtContext ctx;
+  ctx.addSubst("m", "");
+  std::string result = std::string(tgfmt("$m{$m($m[$m]$m)$m}$m|", &ctx));
+  EXPECT_THAT(result, StrEq("{([])}|"));
+}
+
+// Test allowed characters in placeholder symbol
+TEST(FormatTest, CustomPlaceHolderFmtStrPlaceHolderChars) {
+  FmtContext ctx;
+  ctx.addSubst("m", "0 ");
+  ctx.addSubst("m1", "1 ");
+  ctx.addSubst("m2C", "2 ");
+  ctx.addSubst("M_3", "3 ");
+  std::string result = std::string(tgfmt("$m$m1$m2C$M_3", &ctx));
+  EXPECT_THAT(result, StrEq("0 1 2 3 "));
+}
+
+TEST(FormatTest, CustomPlaceHolderFmtStrUnregisteredPlaceHolders) {
+  FmtContext ctx;
+  std::string result = std::string(tgfmt("foo($awesome, $param)", &ctx));
+  EXPECT_THAT(result,
+              StrEq("foo($awesome<no-subst-found>, $param<no-subst-found>)"));
+}
+
+TEST(FormatTest, MixedFmtStr) {
+  FmtContext ctx;
+  ctx.withBuilder("bbb");
+
+  std::string result = std::string(tgfmt("$_builder.build($_self, {$0, $1})",
+                                         &ctx.withSelf("sss"), "a", "b"));
+  EXPECT_THAT(result, StrEq("bbb.build(sss, {a, b})"));
+}