Mercurial > thymian
view tests/test.cpp @ 0:a4671277546c tip
created the repository for the thymian project
| author | ferencd |
|---|---|
| date | Tue, 17 Aug 2021 11:19:54 +0200 |
| parents | |
| children |
line wrap: on
line source
#include "gtest/gtest.h" #include "templater.h" #include <url_breaker.h> #include <cppdb.h> #include <time.h> #include <common.h> #include <cppdb/cppdb.h> #include <tnt/httprequest.h> #include <tnt/httpreply.h> #include <tnt/tntnet.h> #include <string> TEST(StringTemplate,DISABLED_IncludeRootData) { STRING_TEMPLATE(RootRequiredIncluded, "Testing {#str}"); STRING_TEMPLATE(RootProviderIncTestStuff, "Testing <!--#include RootRequiredIncluded#-->"); std::string tf = templater<RootProviderIncTestStuff>().templatize("str" <is> 123 ).get(); ASSERT_STREQ(tf.c_str(), "Testing Testing 123"); } TEST(StringTemplate,DISABLED_IfEq) { STRING_TEMPLATE(IfElseStuff, "Testing<!--#eq {#str},blabla#-->blaa<!--#endeq#-->123"); template_par<std::string> a("str", "blabla"); std::string tf = templater<IfElseStuff>().templatize(a).get(); ASSERT_STREQ(tf.c_str(), "Testingblaa123"); } TEST(StringTemplate,DISABLED_ErrorSetter) { STRING_TEMPLATE(ErrorSetterTemplateTest, "Testing {#str}"); auto t = templater<ErrorSetterTemplateTest>(); t.set_error("Error", 123, "."); std::string err = t.get_error(); ASSERT_STREQ("Error 123 .\n", err.c_str()); } TEST(StringTemplate, DISABLED_TranslateIndependentString) { std::string s = "he<!--#translate language#-->oh"; std::map<std::string, std::map<std::string, std::string> > translations; std::string translated = translator<void>::translate(s, "hu", translations); ASSERT_STREQ("henyelvoh", translated.c_str()); } TEST(StringTemplate, DISABLED_Translate) { STRING_TEMPLATE(ToTranslateTest, "he<!--#translate language#-->oh"); std::string translated = translator<ToTranslateTest>().translate("hu"); ASSERT_STREQ("henyelvoh", translated.c_str()); } TEST(StringTemplate, DISABLED_TranslateVar) { STRING_TEMPLATE(ToTranslateVarTest, "he<!--#translate {#str}#-->oh"); std::string translated = translator<ToTranslateVarTest>().templatize("str" <is> "language").set().translate("hu"); ASSERT_STREQ("he<span id='span_language'></span>oh", translated.c_str()); } TEST(StringTemplate, DISABLED_TranslatePythonOutput) { STRING_TEMPLATE(ToTranslateVarTest, "he<!--#translate <!--#init-script python#-->print('language')<!--#endscript#-->#-->oh"); std::string translated = translator<ToTranslateVarTest>().templatize("str" <is> "language").set().translate("hu"); ASSERT_STREQ("he<span id='span_language'></span>oh", translated.c_str()); } #include <tntdb.h> TEST(StringTemplate, DISABLED_FoodFromDb) { std::vector<template_struct> structs; try { tntdb::Connection conn = tntdb::connect("sqlite:lang.db"); // TODO: prepared statement std::string v = std::string("select * from food where type='") + "0" + "'"; tntdb::Result result = conn.select(v); for (tntdb::Result::const_iterator it = result.begin(); it != result.end(); ++it) { std::string name_src = ""; std::string img = ""; std::string desc = ""; int food_idx = -1; std::string type; tntdb::Row row = *it; row[0].get(food_idx); row[1].get(name_src); row[2].get(type); row[3].get(img); row[4].get(desc); template_struct food("foods", "fooditem"); food["name"] = name_src; food["img"] = img; food["desc"] = desc; structs.push_back(food); } } catch (std::exception& ex) { std::cerr << ex.what(); } STRING_TEMPLATE(ItSimpleStructTemplate, "<!--#struct fooditem(name,desc,img)#-->" "<!--#parameters foods:fooditem[]#-->" "Testing" "<!--#loop foods#-->" "{#foods.name}/{#foods.desc}/{#foods.img}" "<!--#endloop foods#-->"); template_vector_par tvp("foods", structs); std::string s = templater<ItSimpleStructTemplate>().templatize( tvp ).get(); ASSERT_STREQ(s.c_str(), "Testing12"); } TEST(StringTemplate, DISABLED_InitScript) { STRING_TEMPLATE(ScriptStuff, "Testing<!--#init-script python#-->" "def fun(s, c):\n" "\treturn s * c\n\n" "print(fun(str, 3))\n" "<!--#endscript#-->"); template_par<std::string> a("str", "A"); std::string tf = templater<ScriptStuff>().templatize(a).get(); ASSERT_STREQ(tf.c_str(), "TestingAAA"); } TEST(StringTemplate, DISABLED_InitScriptAndStandardScript) { STRING_TEMPLATE(ScriptStuff2Scripts, "Testing<!--#init-script python#-->" "def fun(s, c):\n" "\treturn s * c\n\n" "print(fun(str, 3))\n" "<!--#endscript#-->" "<!--#script python#-->" "def fun(s, c):\n" "\treturn s * c\n\n" "print(fun(str2, 3))\n" "<!--#endscript#-->"); template_par<std::string> a("str", "C"); template_par<std::string> b("str2", "D"); std::string tf = templater<ScriptStuff2Scripts>().templatize(a,b).get(); ASSERT_STREQ(tf.c_str(), "TestingCCCDDD"); } TEST(StringTemplate, DISABLED_InitScriptSetsVariables) { STRING_TEMPLATE(ScriptStuffSetsVar, "Testing{#str}<!--#init-script python#-->" "str='B'\n" "<!--#endscript#-->"); template_par<std::string> a("str", "A"); std::string tf = templater<ScriptStuffSetsVar>().templatize(a).get(); ASSERT_STREQ(tf.c_str(), "TestingB"); } TEST(StringTemplate,DISABLED_IfElse) { STRING_TEMPLATE(IfElseStuff, "<!--#define blaa#-->Testing<!--#if blaa#-->blaa<!--#else#-->{#str}<!--#endif blaa#-->123"); template_par<std::string> a("str", "blabla"); std::string tf = templater<IfElseStuff>().templatize(a).get(); ASSERT_STREQ(tf.c_str(), "Testingblaa123"); } TEST(StringTemplate,DISABLED_Defines) { STRING_TEMPLATE(DefineStuff, "<!--#define blaa#--><!--#if blaa#-->Testing {#str}<!--#endif blaa#-->"); template_par<std::string> a("str", "blabla"); std::string tf = templater<DefineStuff>().templatize(a).get(); ASSERT_STREQ(tf.c_str(), "Testing blabla"); } TEST(StringTemplate,DISABLED_NotSoDefines) { STRING_TEMPLATE(NotSoDefines, "<!--#define not_blaa#--><!--#if blaa#-->Testing {#str}<!--#endif blaa#-->"); template_par<std::string> a("str", "blabla"); std::string tf = templater<NotSoDefines>().templatize(a).get(); ASSERT_STREQ(tf.c_str(), ""); } TEST(StringTemplate,DISABLED_ValueDefines) { STRING_TEMPLATE(ValueDefines, "<!--#define blaa=bluu#-->Testing {#blaa}{#str}"); template_par<std::string> a("str", "blabla"); std::string tf = templater<ValueDefines>().templatize(a).get(); ASSERT_STREQ(tf.c_str(), "Testing bluublabla"); } TEST(StringTemplate,DISABLED_IfTest) { STRING_TEMPLATE(IfTestStuff, "Testing<!--#if str#-->:This is {#str}<!--#endif str#-->"); template_par<std::string> a("str", "blabla"); std::string tf = templater<IfTestStuff>().templatize(a).get(); ASSERT_STREQ(tf.c_str(), "Testing:This is blabla"); template_par<std::string> b("str", ""); std::string no_par = templater<IfTestStuff>().templatize(b).get(); ASSERT_STREQ(no_par.c_str(), "Testing"); } TEST(StringTemplate,DISABLED_SimpleString) { STRING_TEMPLATE(TestStuff, "Testing {#str}"); template_par<std::string> a("str", "blabla"); std::string tf = templater<TestStuff>().templatize(a).get(); ASSERT_STREQ(tf.c_str(), "Testing blabla"); } TEST(StringTemplate,DISABLED_SimpleNumber) { STRING_TEMPLATE(NumberTestStuff, "Testing {#str}"); auto x = "str" <is> 42; std::string tf = templater<NumberTestStuff>().templatize(x).get(); ASSERT_STREQ(tf.c_str(), "Testing 42"); } TEST(StringTemplate,DISABLED_SimpleInclusion) { STRING_TEMPLATE(TestIncluded, "Testing {#str}"); STRING_TEMPLATE(IncTestStuff, "Testing <!--#include TestIncluded(str=\"blaa\")#-->"); std::string tf = templater<IncTestStuff>().templatize().get(); ASSERT_STREQ(tf.c_str(), "Testing Testing blaa"); } TEST(StringTemplate,DISABLED_SimpleVariables) { STRING_TEMPLATE(TestVariables, "Testing {#str}{#str2}"); auto vars = templater<TestVariables>().variables(false); ASSERT_STREQ(vars[0].c_str(), "str"); ASSERT_STREQ(vars[1].c_str(), "str2"); } TEST(StringTemplate,DISABLED_IncludedVariables) { STRING_TEMPLATE(TestIncludedVariables, "Testing {#str}"); STRING_TEMPLATE(TestVariableIncluder, "Testing <!--#include TestIncludedVariables#-->{#str2}"); auto vars = templater<TestVariableIncluder>().variables(true); ASSERT_STREQ(vars[0].c_str(), "str"); ASSERT_STREQ(vars[1].c_str(), "str2"); } TEST(StringTemplate,DISABLED_SimpleInclusionErroneous) { STRING_TEMPLATE(TestIncluded1, "Testing {#str}"); STRING_TEMPLATE(IncTestStuff1, "Testing <!--#include TestIncluded(str=\"blaa)#-->"); std::string tf = templater<IncTestStuff1>().templatize().get(); ASSERT_STREQ(tf.c_str(), "Testing Testing blaa)#-->"); } TEST(StringTemplate,DISABLED_SimpleInclusion2) { STRING_TEMPLATE(TestIncluded2, "Testing"); STRING_TEMPLATE(IncTestStuff2, "Testing <!--#include TestIncluded2#-->More"); std::string tf = templater<IncTestStuff2>().templatize().get(); ASSERT_STREQ(tf.c_str(), "Testing TestingMore"); } TEST(StringTemplate,DISABLED_DoubleInclusion) { STRING_TEMPLATE(DoubleTestIncluded, "Testing {#str}"); STRING_TEMPLATE(DoubleIncTestStuff, "Testing <!--#include TestIncluded(str=\"blaa\")#--><!--#include TestIncluded(str=\"blee\")#-->"); std::string tf = templater<DoubleIncTestStuff>().templatize().get(); ASSERT_STREQ(tf.c_str(), "Testing Testing blaaTesting blee"); } TEST(StringTemplate,DISABLED_SimpleInclusionWithVariable) { STRING_TEMPLATE(VarTestIncluded, "<!--#parameters st#-->Testing {#str}"); STRING_TEMPLATE(VarTestStuff, "Testing <!--#include TestIncluded(str:{#more_str})#-->"); template_par<std::string> a("more_str", "blabla"); std::string tf = templater<VarTestStuff>().templatize(a).get(); ASSERT_STREQ(tf.c_str(), "Testing Testing blabla"); } TEST(StringTemplate, DISABLED_SimpleStruct) { STRING_TEMPLATE(SimpleStructTemplate, "<!--#struct simple_pair(a,b)#-->" "<!--#parameters st:simple_pair#-->" "Testing {#st.a}{#st.b}"); template_struct st("st", "simple_pair"); st["a"] = "A"; st["b"] = "B"; std::string s = templater<SimpleStructTemplate>().templatize(st).get(); ASSERT_STREQ(s.c_str(), "Testing AB"); } TEST(StringTemplate,DISABLED_SimpleStructAndVar) { STRING_TEMPLATE(VarSimpleStructTemplate, "<!--#struct simple_pair(a,b)#-->" "<!--#parameters st:simple_pair#-->" "Testing {#st.a}{#st.b}{#x}"); template_struct st("st", "simple_pair"); st["a"] = "A"; st["b"] = "B"; std::string s = templater<VarSimpleStructTemplate>().templatize( st, "x" <is> 42 ).get(); ASSERT_STREQ(s.c_str(), "Testing AB42"); } TEST(StringTemplate,DISABLED_VarAndSimpleStruct) { STRING_TEMPLATE(VarAndSimpleStructTemplate, "<!--#struct simple_pair(a,b)#-->" "<!--#parameters st:simple_pair#-->" "Testing {#x}{#st.a}{#st.b}"); template_struct st("st", "simple_pair"); st["a"] = "A"; st["b"] = "B"; std::string s = templater<VarAndSimpleStructTemplate>().templatize( "x" <is> 42, st ).get(); ASSERT_STREQ(s.c_str(), "Testing 42AB"); } TEST(StringTemplate,DISABLED_SimpleStruct2) { STRING_TEMPLATE(SecondSimpleStructTemplate, "<!--#struct simple(c)#-->" "<!--#struct simple_pair(a,b)#-->" "<!--#parameters st:simple_pair, x:simple#-->" "Testing {#x.c}{#st.a}{#st.b}"); template_struct st("st", "simple_pair"); st["a"] = "A"; st["b"] = "B"; template_struct x("x", "simple"); x["c"] = "C"; std::string s = templater<SecondSimpleStructTemplate>().templatize( x, st ).get(); ASSERT_STREQ(s.c_str(), "Testing CAB"); } TEST(StringTemplate, Iterator) { STRING_TEMPLATE(ItSimpleStructTemplate, "<!--#struct simple(c)#-->" "<!--#parameters v:simple[]#-->" "Testing" "<!--#loop v#-->" "{#v.c}" "<!--#endloop v#-->"); std::vector<template_struct> structs; template_struct ts("unused", "simple"); ts["c"] = "1"; structs.push_back(ts); ts["c"] = "2"; structs.push_back(ts); template_vector_par tvp("v", structs); std::string s = templater<ItSimpleStructTemplate>().templatize( tvp ).get(); ASSERT_STREQ(s.c_str(), "Testing12"); } TEST(StringTemplate,DISABLED_IteratorTwoStructsIfEq) { STRING_TEMPLATE(IteratorTwoStructsIfEq,"<!--#struct simple(c)#-->" "<!--#struct complex(d)#-->" "<!--#parameters v:simple[],w:complex[]#-->" "Testing" "<!--#loop v#-->" "{#v.c}" "<!--#endloop v#-->" "<!--#loop w#-->" "<!--#eq {#stg},{#w.d}#-->" "{#w.d}" "<!--#endeq#-->" "<!--#endloop w#-->" ); std::vector<template_struct> structs; std::vector<template_struct> structs2; template_struct ts("simples", "simple"); template_struct tsw("doubles", "double"); ts["c"] = "1"; structs.push_back(ts); ts["c"] = "2"; structs.push_back(ts); tsw["d"] = "3"; structs2.push_back(tsw); tsw["d"] = "4"; structs2.push_back(tsw); template_vector_par tvp("v", structs); template_vector_par tvp2("w", structs2); std::string s = templater<IteratorTwoStructsIfEq>().templatize("stg" <is> "3"). templatize(tvp2). templatize(tvp). get(); ASSERT_STREQ(s.c_str(), "Testing123"); } TEST(StringTemplate,IteratorTwoStructs) { STRING_TEMPLATE(IteratorTwoStructs, "<!--#struct simple(c)#-->" "<!--#struct complex(d)#-->" "<!--#parameters v:simple[],w:complex[]#-->" "Testing" "<!--#loop v#-->" "{#v.c}" "<!--#endloop v#-->" "<!--#loop w#-->" "{#w.d}" "<!--#endloop w#-->" ); std::vector<template_struct> structs; std::vector<template_struct> structs2; template_struct ts("simples", "simple"); template_struct tsw("doubles", "double"); ts["c"] = "1"; structs.push_back(ts); ts["c"] = "2"; structs.push_back(ts); tsw["d"] = "3"; structs2.push_back(tsw); tsw["d"] = "4"; structs2.push_back(tsw); template_vector_par tvp("v", structs); template_vector_par tvp2("w", structs2); std::string s = templater<IteratorTwoStructs>().templatize(tvp2).templatize(tvp).get(); ASSERT_STREQ(s.c_str(), "Testing1234"); } TEST(StringTemplate,DISABLED_JsonSource) { STRING_TEMPLATE(RequiredJsonTest, "Testing {str}"); std::string s = templater<RequiredJsonTest>().templatize(nlohmann::json{ {"str", "BLaaaaa"} }).get(); std::cout << s << std::endl; } /********************************************************************************************************************/ TABLE(Address) COLUMN(Id, INTEGER); COLUMN(StreetName, VARCHAR(256)); COLUMN(Code, INTEGER); ENDTABLE(Address) TABLE(Person) COLUMN(Id, INTEGER, PRIMARY_KEY); COLUMN(AddressId, INTEGER, NOT_NULL, DEFAULT(1)); COLUMN(Name, VARCHAR(256)); COLUMN(Age, INTEGER); COLUMN(Birthday, TIMESTAMP, DEFAULT(CURRENT_TIMESTAMP)); FOREIGN_KEY(AddressId -> Address.Id); ENDTABLE(Person) TEST(CppDb, DISABLED_BasicOperations) { std::string combined_select = SELECT(Person.Id, Person.Name, Person.Age, Address.StreetName) + FROM ( Person, Address) + WHERE( Person.Id != 23 AND Person.AddressId == Address.Id ); std::string p_create = Person.create(); std::string insert = Person( Person.Age, Person.Name ).insert( 14, std::string("John Doe") ); std::string prep_insert = Person( Person.Age, Person.Name ).prepare_insert( ); ASSERT_STREQ("SELECT Person.Id, Person.Name, Person.Age, Address.StreetName FROM Person, Address WHERE ((Person.Id<>23) AND (Person.AddressId=Address.Id))", combined_select.c_str() ); ASSERT_STREQ("CREATE TABLE IF NOT EXISTS Person (Id INTEGER PRIMARY KEY, AddressId INTEGER NOT NULL DEFAULT 1, Name VARCHAR(256), Age INTEGER, Birthday TIMESTAMP DEFAULT CURRENT_TIMESTAMP, FOREIGN KEY (AddressId) REFERENCES Address(Id))", p_create.c_str()); ASSERT_STREQ("INSERT OR IGNORE INTO Person(Age, Name) VALUES (14, \"John Doe\")", insert.c_str() ); ASSERT_STREQ("INSERT OR IGNORE INTO Person(Age, Name) VALUES (:v1, :v2)", prep_insert.c_str() ); std::string ordered_select = SELECT(Person.Id, Person.Name, Person.Age, Address.StreetName) + FROM ( Person, Address) + WHERE( Person.Id != 23 AND Person.AddressId == Address.Id ) + ORDER_BY(Person.Name DESC, Person.Age ASC); std::cout << ordered_select << std::endl; std::string ordered_select2 = SELECT(Person.Id, Person.Name, Person.Age, Address.StreetName) + FROM ( Person, Address) + WHERE( Person.Id != 23 AND Person.AddressId == Address.Id ) + ORDER_BY(Person.Name DESC, Person.Age); std::cout << ordered_select2; } TEST(CppDb, DISABLED_Delete) { std::string s = DELETE + FROM (Person) + WHERE (Person.Id == 23); std::cout << s; } TEST(XSSSanitizer, DISABLED_RemoveIp) { std::string s = "THIS HAS AN IP192.168.1.1ABC"; std::string s2 = "THIS HAS AN IP 192.168.1.1.ABC"; std::string sanit = unafrog::utils::sanitize_user_input(s); std::string sanit2 = unafrog::utils::sanitize_user_input(s2); ASSERT_STREQ(sanit.c_str(), "THIS HAS AN IPABC"); ASSERT_STREQ(sanit2.c_str(), "THIS HAS AN IP 192.168.1.1.ABC"); } TEST(ComponentBreaker, DISABLED_cb1) { url_breaker a("/A/B/C", "/alpha/beta/gamma"); ASSERT_EQ( (a["A"] == "alpha"), true); ASSERT_EQ( (a["B"] == "beta"), true); ASSERT_EQ( (a["C"] == "gamma"), true); } TEST(B62, DISABLED_b62_enc) { std::string s = "5zn2cg3h"; uint64_t l = 19617184805931; std::string g = unafrog::utils::b62::base62_encode(l); ASSERT_EQ(s, g); } TEST(Convert, DISABLED_HexStringToNr) { ASSERT_EQ(9, unafrog::utils::hex_string_to_nr<int>("09")); ASSERT_EQ(0, unafrog::utils::hex_string_to_nr<int>("00")); ASSERT_EQ(10, unafrog::utils::hex_string_to_nr<int>("0A")); ASSERT_EQ(1987, unafrog::utils::hex_string_to_nr<int>("07c3")); } TEST(UrlMaker, DISABLED_args) { std::string s = unafrog::utils::make_url("a", "b", "c"); std::string s1 = unafrog::utils::make_url("a"); std::string s2 = unafrog::utils::make_url("a", "b"); ASSERT_EQ(s, "a/b/c"); ASSERT_EQ(s1, "a"); ASSERT_EQ(s2, "a/b"); } TEST(Conversion, DISABLED_IntToHex) { ASSERT_EQ("0f", unafrog::utils::int_to_hex<char>(15)); } TEST(Common, DISABLED_DuplicateRemover) { ASSERT_EQ("ABC/DEF", remove_duplicates("ABC//DEF", '/')); ASSERT_EQ("ABCC/DEF", remove_duplicates("ABCC/DEF", '/')); ASSERT_EQ("/", remove_duplicates("//", '/')); }
