Squashed 'third_party/ctemplate/' content from commit 6742f62
Change-Id: I828e4e4c906f13ba19944d78a8a78652b62949af
git-subtree-dir: third_party/ctemplate
git-subtree-split: 6742f6233db12f545e90baa8f34f5c29c4eb396a
diff --git a/src/tests/template_test_util_test.cc b/src/tests/template_test_util_test.cc
new file mode 100644
index 0000000..190ac95
--- /dev/null
+++ b/src/tests/template_test_util_test.cc
@@ -0,0 +1,262 @@
+// Copyright (c) 2008, Google Inc.
+// All rights reserved.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are
+// met:
+//
+// * Redistributions of source code must retain the above copyright
+// notice, this list of conditions and the following disclaimer.
+// * Redistributions in binary form must reproduce the above
+// copyright notice, this list of conditions and the following disclaimer
+// in the documentation and/or other materials provided with the
+// distribution.
+// * Neither the name of Google Inc. nor the names of its
+// contributors may be used to endorse or promote products derived from
+// this software without specific prior written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+#include "config_for_unittests.h"
+#include "tests/template_test_util.h"
+
+#include <stdio.h>
+#include <string>
+#include <vector>
+
+#include "base/arena.h"
+#include <ctemplate/template_dictionary.h>
+#include <ctemplate/template_string.h>
+#include "base/util.h"
+TEST_INIT // defines RUN_ALL_TESTS()
+
+#define ASSERT_EQ(a, b) EXPECT_EQ(a, b)
+
+using std::vector;
+using std::string;
+using GOOGLE_NAMESPACE::UnsafeArena;
+
+using GOOGLE_NAMESPACE::TemplateDictionary;
+using GOOGLE_NAMESPACE::TemplateDictionaryPeer;
+using GOOGLE_NAMESPACE::TemplateString;
+using GOOGLE_NAMESPACE::StaticTemplateString;
+
+namespace {
+
+TEST(TemplateTestUtilTest, GetSectionValue) {
+ TemplateDictionary dict("test_GetSectionValue");
+ dict.SetValue("VALUE", "value");
+
+ TemplateDictionaryPeer peer(&dict);
+ EXPECT_STREQ("value", peer.GetSectionValue("VALUE"));
+}
+
+TEST(TemplateTestUtilTest, IsHiddenSection) {
+ TemplateDictionary dict("test_IsHiddenSection");
+
+ {
+ TemplateDictionaryPeer peer(&dict);
+ EXPECT_TRUE(peer.IsHiddenSection("SECTION"));
+ }
+
+ dict.AddSectionDictionary("SECTION");
+
+ {
+ TemplateDictionaryPeer peer(&dict);
+ EXPECT_FALSE(peer.IsHiddenSection("SECTION"));
+ }
+}
+
+TEST(TemplateTestUtilTest, GetSectionDictionaries) {
+ TemplateDictionary dict("test_GetSectionDictionaries");
+
+ {
+ TemplateDictionaryPeer peer(&dict);
+ vector<const TemplateDictionary*> dicts;
+ // Add some dummy value into the vector to confirm that the call to
+ // GetSectionDictionaries will correctly clear the vector.
+ dicts.push_back(NULL);
+ EXPECT_EQ(0, peer.GetSectionDictionaries("SECTION", &dicts));
+ EXPECT_TRUE(dicts.empty());
+ }
+
+ dict.AddSectionDictionary("SECTION")->SetValue("SECTION_VALUE", "0");
+
+ {
+ TemplateDictionaryPeer peer(&dict);
+ vector<const TemplateDictionary*> dicts;
+ ASSERT_EQ(1, peer.GetSectionDictionaries("SECTION", &dicts));
+
+ TemplateDictionaryPeer peer_section(dicts[0]);
+ EXPECT_STREQ("0", peer_section.GetSectionValue("SECTION_VALUE"));
+ }
+
+ dict.AddSectionDictionary("SECTION")->SetValue("SECTION_VALUE", "1");
+ dict.AddSectionDictionary("ANOTHER_SECTION")->SetValue("ANOTHER_VALUE", "2");
+
+ {
+ TemplateDictionaryPeer peer(&dict);
+ vector<const TemplateDictionary*> dicts;
+ ASSERT_EQ(2, peer.GetSectionDictionaries("SECTION", &dicts));
+
+ TemplateDictionaryPeer peer_section0(dicts[0]);
+ EXPECT_STREQ("0", peer_section0.GetSectionValue("SECTION_VALUE"));
+
+ TemplateDictionaryPeer peer_section1(dicts[1]);
+ EXPECT_STREQ("1", peer_section1.GetSectionValue("SECTION_VALUE"));
+ }
+}
+
+TEST(TemplateTestUtilTest, GetIncludeDictionaries) {
+ TemplateDictionary dict("test_GetIncludeDictionaries");
+
+ {
+ TemplateDictionaryPeer peer(&dict);
+ vector<const TemplateDictionary*> dicts;
+ // Add some dummy value into the vector to confirm that the call to
+ // GetSectionDictionaries will correctly clear the vector.
+ dicts.push_back(NULL);
+ EXPECT_EQ(0, peer.GetIncludeDictionaries("SECTION", &dicts));
+ EXPECT_TRUE(dicts.empty());
+ }
+
+ dict.AddIncludeDictionary("SECTION")->SetValue("SECTION_VALUE", "0");
+
+ {
+ TemplateDictionaryPeer peer(&dict);
+ vector<const TemplateDictionary*> dicts;
+ ASSERT_EQ(1, peer.GetIncludeDictionaries("SECTION", &dicts));
+
+ TemplateDictionaryPeer peer_section(dicts[0]);
+ EXPECT_STREQ("0", peer_section.GetSectionValue("SECTION_VALUE"));
+ }
+
+ dict.AddIncludeDictionary("SECTION")->SetValue("SECTION_VALUE", "1");
+ dict.AddIncludeDictionary("ANOTHER_SECTION")->SetValue("ANOTHER_VALUE", "2");
+
+ {
+ TemplateDictionaryPeer peer(&dict);
+ vector<const TemplateDictionary*> dicts;
+ ASSERT_EQ(2, peer.GetIncludeDictionaries("SECTION", &dicts));
+
+ TemplateDictionaryPeer peer_section0(dicts[0]);
+ EXPECT_STREQ("0", peer_section0.GetSectionValue("SECTION_VALUE"));
+
+ TemplateDictionaryPeer peer_section1(dicts[1]);
+ EXPECT_STREQ("1", peer_section1.GetSectionValue("SECTION_VALUE"));
+ }
+}
+
+TEST(TemplateTestUtilTest, GetIncludeAndSectionDictionaries) {
+ TemplateDictionary dict("test_GetIncludeAndSectionDictionaries");
+
+ {
+ TemplateDictionaryPeer peer(&dict);
+ vector<const TemplateDictionary*> dicts;
+ EXPECT_EQ(0, peer.GetIncludeDictionaries("SECTION", &dicts));
+ EXPECT_EQ(0, peer.GetSectionDictionaries("SECTION", &dicts));
+ }
+
+ dict.AddIncludeDictionary("SECTION")->SetValue("SECTION_VALUE", "0");
+ dict.AddSectionDictionary("SECTION")->SetValue("SECTION_VALUE", "1");
+
+ {
+ TemplateDictionaryPeer peer(&dict);
+ vector<const TemplateDictionary*> include_dicts;
+ ASSERT_EQ(1, peer.GetIncludeDictionaries("SECTION", &include_dicts));
+
+ TemplateDictionaryPeer include_peer(include_dicts[0]);
+ EXPECT_STREQ("0", include_peer.GetSectionValue("SECTION_VALUE"));
+
+ vector<const TemplateDictionary*> section_dicts;
+ ASSERT_EQ(1, peer.GetSectionDictionaries("SECTION", §ion_dicts));
+
+ TemplateDictionaryPeer section_peer(section_dicts[0]);
+ EXPECT_STREQ("1", section_peer.GetSectionValue("SECTION_VALUE"));
+ }
+
+ dict.AddIncludeDictionary("SECTION")->SetValue("SECTION_VALUE", "2");
+ dict.AddIncludeDictionary("ANOTHER_SECTION")->SetValue("ANOTHER_VALUE", "3");
+
+ dict.AddSectionDictionary("SECTION")->SetValue("SECTION_VALUE", "4");
+ dict.AddSectionDictionary("ONE_MORE_SECTION")->SetValue("ANOTHER_VALUE", "5");
+
+ {
+ TemplateDictionaryPeer peer(&dict);
+ vector<const TemplateDictionary*> dicts;
+ ASSERT_EQ(2, peer.GetIncludeDictionaries("SECTION", &dicts));
+
+ TemplateDictionaryPeer include_peer0(dicts[0]);
+ EXPECT_STREQ("0", include_peer0.GetSectionValue("SECTION_VALUE"));
+
+ TemplateDictionaryPeer include_peer1(dicts[1]);
+ EXPECT_STREQ("2", include_peer1.GetSectionValue("SECTION_VALUE"));
+
+ EXPECT_EQ(1, peer.GetIncludeDictionaries("ANOTHER_SECTION", &dicts));
+ EXPECT_EQ(0, peer.GetIncludeDictionaries("ONE_MORE_SECTION", &dicts));
+
+ vector<const TemplateDictionary*> section_dicts;
+ ASSERT_EQ(2, peer.GetSectionDictionaries("SECTION", §ion_dicts));
+
+ TemplateDictionaryPeer section_peer0(section_dicts[0]);
+ EXPECT_STREQ("1", section_peer0.GetSectionValue("SECTION_VALUE"));
+
+ TemplateDictionaryPeer section_peer1(section_dicts[1]);
+ EXPECT_STREQ("4", section_peer1.GetSectionValue("SECTION_VALUE"));
+
+ EXPECT_EQ(0, peer.GetSectionDictionaries("ANOTHER_SECTION", &dicts));
+ EXPECT_EQ(1, peer.GetSectionDictionaries("ONE_MORE_SECTION", &dicts));
+ }
+}
+
+TEST(TemplateTestUtilTest, GetFilename) {
+ TemplateDictionary parent("test_GetFilename");
+ TemplateDictionary* child = parent.AddIncludeDictionary("INCLUDE_marker");
+ child->SetFilename("included_filename");
+
+ TemplateDictionaryPeer parent_peer(&parent);
+ EXPECT_EQ(NULL, parent_peer.GetFilename());
+
+ TemplateDictionaryPeer child_peer(child);
+ EXPECT_STREQ("included_filename", child_peer.GetFilename());
+}
+
+StaticTemplateString GetTestTemplateString(UnsafeArena* arena) {
+ string will_go_out_of_scope("VALUE");
+ // We want to ensure that the STS_INIT_FOR_TEST macro:
+ // - Can produce a StaticTemplateString (guard again its format changing).
+ // - Produces a StaticTemplateString that is still valid after the string
+ // used to initialize it goes out-of-scope.
+ StaticTemplateString sts = STS_INIT_FOR_TEST(will_go_out_of_scope.c_str(),
+ will_go_out_of_scope.length(),
+ arena);
+ return sts;
+}
+
+TEST(TemplateUtilTest, InitStaticTemplateStringForTest) {
+ UnsafeArena arena(1024);
+ StaticTemplateString kValue = GetTestTemplateString(&arena);
+
+ TemplateDictionary dict("test_GetSectionValue");
+ dict.SetValue(kValue, "value");
+
+ TemplateDictionaryPeer peer(&dict);
+ EXPECT_STREQ("value", peer.GetSectionValue(kValue));
+}
+
+} // namespace anonymous
+
+int main(int argc, char **argv) {
+
+ return RUN_ALL_TESTS();
+}