Use escape to correctly escape unicode characters

This commit is contained in:
fbraem
2015-12-07 17:33:10 +01:00
parent 7086d93324
commit 18b92b5b36
7 changed files with 163 additions and 162 deletions

View File

@@ -26,16 +26,11 @@
namespace Poco { namespace Poco {
std::string Foundation_API toJSON(char c);
/// Utility function for escaping JSON characters.
void Foundation_API toJSON(const std::string& value, std::ostream& out, bool wrap = true); void Foundation_API toJSON(const std::string& value, std::ostream& out, bool wrap = true);
/// Formats string value into the supplied output stream by /// Formats string value into the supplied output stream by
/// escaping control characters. /// escaping control characters.
/// If wrap is true, the resulting string is enclosed in double quotes /// If wrap is true, the resulting string is enclosed in double quotes
std::string Foundation_API toJSON(const std::string& value, bool wrap = true); std::string Foundation_API toJSON(const std::string& value, bool wrap = true);
/// Formats string value by escaping control characters. /// Formats string value by escaping control characters.
/// If wrap is true, the resulting string is enclosed in double quotes /// If wrap is true, the resulting string is enclosed in double quotes

View File

@@ -13,39 +13,16 @@
// SPDX-License-Identifier: BSL-1.0 // SPDX-License-Identifier: BSL-1.0
// //
#include "Poco/JSONString.h" #include "Poco/JSONString.h"
#include "Poco/UTF8String.h"
#include <ostream> #include <ostream>
namespace Poco { namespace Poco {
std::string toJSON(char c)
{
switch (c)
{
case '\\': return "\\\\";
case '"': return "\\\"";
case '/': return "\\/";
case '\b': return "\\b";
case '\f': return "\\f";
case '\n': return "\\n";
case '\r': return "\\r";
case '\t': return "\\t";
default: return std::string(1, c);
}
}
void toJSON(const std::string& value, std::ostream& out, bool wrap) void toJSON(const std::string& value, std::ostream& out, bool wrap)
{ {
if (wrap) out << '"'; if (wrap) out << '"';
for (std::string::const_iterator it = value.begin(), out << UTF8::escape(value.begin(), value.end());
end = value.end(); it != end; ++it)
{
out << toJSON(*it);
}
if (wrap) out << '"'; if (wrap) out << '"';
} }
@@ -54,11 +31,7 @@ std::string toJSON(const std::string& value, bool wrap)
{ {
std::string ret; std::string ret;
if (wrap) ret.append(1, '"'); if (wrap) ret.append(1, '"');
for (std::string::const_iterator it = value.begin(), ret.append(UTF8::escape(value.begin(), value.end()));
end = value.end(); it != end; ++it)
{
ret.append(toJSON(*it));
}
if (wrap) ret.append(1, '"'); if (wrap) ret.append(1, '"');
return ret; return ret;
} }

View File

@@ -16,7 +16,7 @@
#include "Poco/Dynamic/VarHolder.h" #include "Poco/Dynamic/VarHolder.h"
#include "Poco/Dynamic/Var.h" #include "Poco/Dynamic/Var.h"
#include "Poco/JSONString.h" #include "Poco/UTF8String.h"
namespace Poco { namespace Poco {
@@ -38,31 +38,28 @@ namespace Impl {
void escape(std::string& target, const std::string& source) void escape(std::string& target, const std::string& source)
{ {
std::string::const_iterator it(source.begin()); target = UTF8::escape(source.begin(), source.end());
std::string::const_iterator end(source.end());
for (; it != end; ++it)
{
target.append(Poco::toJSON(*it));
}
} }
bool isJSONString(const Var& any) bool isJSONString(const Var& any)
{ {
return any.type() == typeid(std::string) || return any.type() == typeid(std::string) ||
any.type() == typeid(char) || any.type() == typeid(char) ||
any.type() == typeid(char*) || any.type() == typeid(char*) ||
any.type() == typeid(Poco::DateTime) || any.type() == typeid(Poco::DateTime) ||
any.type() == typeid(Poco::LocalDateTime) || any.type() == typeid(Poco::LocalDateTime) ||
any.type() == typeid(Poco::Timestamp); any.type() == typeid(Poco::Timestamp);
} }
void appendJSONString(std::string& val, const Var& any) void appendJSONString(std::string& val, const Var& any)
{ {
val += '"'; std::string json(val);
escape(val, any.convert<std::string>()); val.append(1, '"');
val += '"'; escape(json, any.convert<std::string>());
val.append(json);
val.append(1, '"');
} }
@@ -74,14 +71,14 @@ void appendJSONKey(std::string& val, const Var& any)
void appendJSONValue(std::string& val, const Var& any) void appendJSONValue(std::string& val, const Var& any)
{ {
if (any.isEmpty()) if (any.isEmpty())
{ {
val.append("null"); val.append("null");
} }
else else
{ {
bool isStr = isJSONString(any); bool isStr = isJSONString(any);
if (isStr) if (isStr)
{ {
appendJSONString(val, any.convert<std::string>()); appendJSONString(val, any.convert<std::string>());
} }

View File

@@ -272,7 +272,7 @@ void StringTest::testIcompare()
assert (icompare(ss1, 2, 2, ss2, 1, 3) < 0); assert (icompare(ss1, 2, 2, ss2, 1, 3) < 0);
assert (icompare(ss1, 2, 2, ss2, 1, 2) == 0); assert (icompare(ss1, 2, 2, ss2, 1, 2) == 0);
assert (icompare(ss3, 1, 3, ss1, 2, 3) > 0); assert (icompare(ss3, 1, 3, ss1, 2, 3) > 0);
assert (icompare(s1, s2.c_str()) == 0); assert (icompare(s1, s2.c_str()) == 0);
assert (icompare(s1, s3.c_str()) < 0); assert (icompare(s1, s3.c_str()) < 0);
assert (icompare(s1, s4.c_str()) < 0); assert (icompare(s1, s4.c_str()) < 0);
@@ -281,12 +281,12 @@ void StringTest::testIcompare()
assert (icompare(s2, s4.c_str()) < 0); assert (icompare(s2, s4.c_str()) < 0);
assert (icompare(s1, s5.c_str()) > 0); assert (icompare(s1, s5.c_str()) > 0);
assert (icompare(s5, s4.c_str()) < 0); assert (icompare(s5, s4.c_str()) < 0);
assert (icompare(ss1, 2, 3, "aaa") == 0); assert (icompare(ss1, 2, 3, "aaa") == 0);
assert (icompare(ss1, 2, 2, "aaa") < 0); assert (icompare(ss1, 2, 2, "aaa") < 0);
assert (icompare(ss1, 2, 3, "AAA") == 0); assert (icompare(ss1, 2, 3, "AAA") == 0);
assert (icompare(ss1, 2, 2, "bb") < 0); assert (icompare(ss1, 2, 2, "bb") < 0);
assert (icompare(ss1, 2, "aaa") > 0); assert (icompare(ss1, 2, "aaa") > 0);
} }
@@ -295,7 +295,7 @@ void StringTest::testCILessThan()
{ {
typedef std::map<std::string, int, CILess> CIMapType; typedef std::map<std::string, int, CILess> CIMapType;
CIMapType ciMap; CIMapType ciMap;
ciMap["z"] = 1; ciMap["z"] = 1;
ciMap["b"] = 2; ciMap["b"] = 2;
ciMap["A"] = 3; ciMap["A"] = 3;
@@ -309,7 +309,7 @@ void StringTest::testCILessThan()
assert (it->second == 4); assert (it->second == 4);
typedef std::set<std::string, CILess> CISetType; typedef std::set<std::string, CILess> CISetType;
CISetType ciSet; CISetType ciSet;
ciSet.insert("z"); ciSet.insert("z");
ciSet.insert("b"); ciSet.insert("b");
@@ -346,7 +346,7 @@ void StringTest::testTranslateInPlace()
void StringTest::testReplace() void StringTest::testReplace()
{ {
std::string s("aabbccdd"); std::string s("aabbccdd");
assert (replace(s, std::string("aa"), std::string("xx")) == "xxbbccdd"); assert (replace(s, std::string("aa"), std::string("xx")) == "xxbbccdd");
assert (replace(s, std::string("bb"), std::string("xx")) == "aaxxccdd"); assert (replace(s, std::string("bb"), std::string("xx")) == "aaxxccdd");
assert (replace(s, std::string("dd"), std::string("xx")) == "aabbccxx"); assert (replace(s, std::string("dd"), std::string("xx")) == "aabbccxx");
@@ -365,7 +365,7 @@ void StringTest::testReplace()
assert (replace(s, "b", "") == "aaccdd"); assert (replace(s, "b", "") == "aaccdd");
assert (replace(s, "ee", "xx") == "aabbccdd"); assert (replace(s, "ee", "xx") == "aabbccdd");
assert (replace(s, "dd", "") == "aabbcc"); assert (replace(s, "dd", "") == "aabbcc");
s = "aabbaabb"; s = "aabbaabb";
assert (replace(s, std::string("aa"), std::string("")) == "bbbb"); assert (replace(s, std::string("aa"), std::string("")) == "bbbb");
assert (replace(s, std::string("a"), std::string("")) == "bbbb"); assert (replace(s, std::string("a"), std::string("")) == "bbbb");
@@ -380,7 +380,7 @@ void StringTest::testReplace()
assert (replace(s, "a", "x") == "xxbbxxbb"); assert (replace(s, "a", "x") == "xxbbxxbb");
assert (replace(s, "a", "xx") == "xxxxbbxxxxbb"); assert (replace(s, "a", "xx") == "xxxxbbxxxxbb");
assert (replace(s, "aa", "xxx") == "xxxbbxxxbb"); assert (replace(s, "aa", "xxx") == "xxxbbxxxbb");
assert (replace(s, "aa", "xx", 2) == "aabbxxbb"); assert (replace(s, "aa", "xx", 2) == "aabbxxbb");
assert (replace(s, 'a', 'x', 2) == "aabbxxbb"); assert (replace(s, 'a', 'x', 2) == "aabbxxbb");
assert (remove(s, 'a', 2) == "aabbbb"); assert (remove(s, 'a', 2) == "aabbbb");
@@ -422,7 +422,7 @@ void StringTest::testCat()
assert (cat(s1, s2, s3, s4) == "onetwothreefour"); assert (cat(s1, s2, s3, s4) == "onetwothreefour");
assert (cat(s1, s2, s3, s4, s5) == "onetwothreefourfive"); assert (cat(s1, s2, s3, s4, s5) == "onetwothreefourfive");
assert (cat(s1, s2, s3, s4, s5, s6) == "onetwothreefourfivesix"); assert (cat(s1, s2, s3, s4, s5, s6) == "onetwothreefourfivesix");
std::vector<std::string> vec; std::vector<std::string> vec;
assert (cat(std::string(), vec.begin(), vec.end()) == ""); assert (cat(std::string(), vec.begin(), vec.end()) == "");
assert (cat(std::string(","), vec.begin(), vec.end()) == ""); assert (cat(std::string(","), vec.begin(), vec.end()) == "");
@@ -520,7 +520,7 @@ void StringTest::testStringToFloat()
float d = 12e34f; float d = 12e34f;
assert(strToFloat(format("12e34", ds), result, ds, ts)); assert(strToFloat(format("12e34", ds), result, ds, ts));
assertEqualDelta(d, result, 0.01e34); assertEqualDelta(d, result, 0.01e34);
d = 1.234e30f; d = 1.234e30f;
assert(strToFloat(format("1%c234e30", ds), result, ds, ts)); assert(strToFloat(format("1%c234e30", ds), result, ds, ts));
assertEqualDelta(d, result, 0.01); assertEqualDelta(d, result, 0.01);
@@ -533,7 +533,7 @@ void StringTest::testStringToFloat()
assertEqualDelta(d, result, 0.01); assertEqualDelta(d, result, 0.01);
assert(strToFloat(format("-12%c34", ds), result, ds, ts)); assert(strToFloat(format("-12%c34", ds), result, ds, ts));
assertEqualDelta(-12.34, result, 0.01); assertEqualDelta(-12.34, result, 0.01);
assert(strToFloat(format(" 12%c34", ds), result, ds, ts)); assert(strToFloat(format(" 12%c34", ds), result, ds, ts));
assertEqualDelta(12.34, result, 0.01); assertEqualDelta(12.34, result, 0.01);
assert(strToFloat(format("12%c34 ", ds), result, ds, ts)); assert(strToFloat(format("12%c34 ", ds), result, ds, ts));
@@ -621,23 +621,23 @@ void StringTest::testStringToDouble()
double d = 12e34; double d = 12e34;
assert(strToDouble(format("12e34", ds), result, ds, ts)); assert(strToDouble(format("12e34", ds), result, ds, ts));
assertEqualDelta(d, result, 0.01e34); assertEqualDelta(d, result, 0.01e34);
d = 1.234e100; d = 1.234e100;
assert(strToDouble(format("1%c234e100", ds), result, ds, ts)); assert(strToDouble(format("1%c234e100", ds), result, ds, ts));
assertEqualDelta(d, result, 0.01); assertEqualDelta(d, result, 0.01);
assert(strToDouble(format("1%c234E+100", ds), result, ds, ts)); assert(strToDouble(format("1%c234E+100", ds), result, ds, ts));
assertEqualDelta(d, result, 0.01); assertEqualDelta(d, result, 0.01);
d = 1.234e-100; d = 1.234e-100;
assert(strToDouble(format("1%c234E-100", ds), result, ds, ts)); assert(strToDouble(format("1%c234E-100", ds), result, ds, ts));
assertEqualDelta(d, result, 0.01); assertEqualDelta(d, result, 0.01);
d = -1.234e100; d = -1.234e100;
assert(strToDouble(format("-1%c234e+100", ds), result, ds, ts)); assert(strToDouble(format("-1%c234e+100", ds), result, ds, ts));
assertEqualDelta(d, result, 0.01); assertEqualDelta(d, result, 0.01);
assert(strToDouble(format("-1%c234E100", ds), result, ds, ts)); assert(strToDouble(format("-1%c234E100", ds), result, ds, ts));
assertEqualDelta(d, result, 0.01); assertEqualDelta(d, result, 0.01);
d = 1.234e-100; d = 1.234e-100;
assert(strToDouble(format(" 1%c234e-100 ", ds), result, ds, ts)); assert(strToDouble(format(" 1%c234e-100 ", ds), result, ds, ts));
assertEqualDelta(d, result, 0.01); assertEqualDelta(d, result, 0.01);
@@ -674,7 +674,7 @@ void StringTest::testStringToDouble()
assertEqualDelta(d, result, 0.01); assertEqualDelta(d, result, 0.01);
assert(strToDouble(format("-12%c34", ds), result, ds, ts)); assert(strToDouble(format("-12%c34", ds), result, ds, ts));
assertEqualDelta(-12.34, result, 0.01); assertEqualDelta(-12.34, result, 0.01);
assert(strToDouble(format(" 12%c34", ds), result, ds, ts)); assert(strToDouble(format(" 12%c34", ds), result, ds, ts));
assertEqualDelta(12.34, result, 0.01); assertEqualDelta(12.34, result, 0.01);
assert(strToDouble(format("12%c34 ", ds), result, ds, ts)); assert(strToDouble(format("12%c34 ", ds), result, ds, ts));
@@ -784,13 +784,13 @@ void StringTest::benchmarkStrToInt()
sw.stop(); sw.stop();
std::cout << "std::strtol Number: " << res << std::endl; std::cout << "std::strtol Number: " << res << std::endl;
double timeStrtol = sw.elapsed() / 1000.0; double timeStrtol = sw.elapsed() / 1000.0;
sw.restart(); sw.restart();
for (int i = 0; i < 1000000; ++i) strToInt(num.c_str(), res, 10); for (int i = 0; i < 1000000; ++i) strToInt(num.c_str(), res, 10);
sw.stop(); sw.stop();
std::cout << "strToInt Number: " << res << std::endl; std::cout << "strToInt Number: " << res << std::endl;
double timeStrToInt = sw.elapsed() / 1000.0; double timeStrToInt = sw.elapsed() / 1000.0;
sw.restart(); sw.restart();
for (int i = 0; i < 1000000; ++i) std::sscanf(num.c_str(), "%d", &res); for (int i = 0; i < 1000000; ++i) std::sscanf(num.c_str(), "%d", &res);
sw.stop(); sw.stop();
@@ -801,11 +801,11 @@ void StringTest::benchmarkStrToInt()
std::cout << std::endl << "Timing and speedup relative to I/O stream:" << std::endl << std::endl; std::cout << std::endl << "Timing and speedup relative to I/O stream:" << std::endl << std::endl;
std::cout << std::setw(14) << "Stream:\t" << std::setw(10) << std::setfill(' ') << timeStream << "[ms]" << std::endl; std::cout << std::setw(14) << "Stream:\t" << std::setw(10) << std::setfill(' ') << timeStream << "[ms]" << std::endl;
std::cout << std::setw(14) << "std::strtol:\t" << std::setw(10) << std::setfill(' ') << timeStrtol << "[ms]" << std::cout << std::setw(14) << "std::strtol:\t" << std::setw(10) << std::setfill(' ') << timeStrtol << "[ms]" <<
std::setw(10) << std::setfill(' ') << "Speedup: " << (timeStream / timeStrtol) << '\t' ; std::setw(10) << std::setfill(' ') << "Speedup: " << (timeStream / timeStrtol) << '\t' ;
graph = (int) (timeStream / timeStrtol); for (int i = 0; i < graph; ++i) std::cout << '|'; graph = (int) (timeStream / timeStrtol); for (int i = 0; i < graph; ++i) std::cout << '|';
std::cout << std::endl << std::setw(14) << "strToInt:\t" << std::setw(10) << std::setfill(' ') << timeStrToInt << "[ms]" << std::cout << std::endl << std::setw(14) << "strToInt:\t" << std::setw(10) << std::setfill(' ') << timeStrToInt << "[ms]" <<
std::setw(10) << std::setfill(' ') << "Speedup: " << (timeStream / timeStrToInt) << '\t' ; std::setw(10) << std::setfill(' ') << "Speedup: " << (timeStream / timeStrToInt) << '\t' ;
graph = (int) (timeStream / timeStrToInt); for (int i = 0; i < graph; ++i) std::cout << '|'; graph = (int) (timeStream / timeStrToInt); for (int i = 0; i < graph; ++i) std::cout << '|';
@@ -843,7 +843,7 @@ void StringTest::benchmarkStrToFloat()
sw.stop(); sw.stop();
std::cout << "strToDouble Number: " << res << std::endl; std::cout << "strToDouble Number: " << res << std::endl;
double timeStrToDouble = sw.elapsed() / 1000.0; double timeStrToDouble = sw.elapsed() / 1000.0;
// standard sscanf // standard sscanf
sw.restart(); sw.restart();
for (int i = 0; i < 1000000; ++i) std::sscanf(num.c_str(), "%lf", &res); for (int i = 0; i < 1000000; ++i) std::sscanf(num.c_str(), "%lf", &res);
@@ -862,11 +862,11 @@ void StringTest::benchmarkStrToFloat()
std::cout << std::endl << "Timing and speedup relative to I/O stream:" << std::endl << std::endl; std::cout << std::endl << "Timing and speedup relative to I/O stream:" << std::endl << std::endl;
std::cout << std::setw(14) << "Stream:\t" << std::setw(10) << std::setfill(' ') << std::setprecision(4) << timeStream << "[ms]" << std::endl; std::cout << std::setw(14) << "Stream:\t" << std::setw(10) << std::setfill(' ') << std::setprecision(4) << timeStream << "[ms]" << std::endl;
std::cout << std::setw(14) << "std::strtod:\t" << std::setw(10) << std::setfill(' ') << timeStdStrtod << "[ms]" << std::cout << std::setw(14) << "std::strtod:\t" << std::setw(10) << std::setfill(' ') << timeStdStrtod << "[ms]" <<
std::setw(10) << std::setfill(' ') << "Speedup: " << (timeStream / timeStdStrtod) << '\t' ; std::setw(10) << std::setfill(' ') << "Speedup: " << (timeStream / timeStdStrtod) << '\t' ;
graph = (int) (timeStream / timeStdStrtod); for (int i = 0; i < graph; ++i) std::cout << '#'; graph = (int) (timeStream / timeStdStrtod); for (int i = 0; i < graph; ++i) std::cout << '#';
std::cout << std::endl << std::setw(14) << "strToDouble:\t" << std::setw(10) << std::setfill(' ') << timeStrToDouble << "[ms]" << std::cout << std::endl << std::setw(14) << "strToDouble:\t" << std::setw(10) << std::setfill(' ') << timeStrToDouble << "[ms]" <<
std::setw(10) << std::setfill(' ') << "Speedup: " << (timeStream / timeStrToDouble) << '\t' ; std::setw(10) << std::setfill(' ') << "Speedup: " << (timeStream / timeStrToDouble) << '\t' ;
graph = (int) (timeStream / timeStrToDouble); for (int i = 0; i < graph; ++i) std::cout << '#'; graph = (int) (timeStream / timeStrToDouble); for (int i = 0; i < graph; ++i) std::cout << '#';
@@ -986,13 +986,13 @@ void StringTest::testFloatToString()
{ {
double val = 1.03721575516329e-112; double val = 1.03721575516329e-112;
std::string str; std::string str;
assert (doubleToStr(str, val, 14, 21) == "1.03721575516329e-112"); assert (doubleToStr(str, val, 14, 21) == "1.03721575516329e-112");
assert (doubleToStr(str, val, 14, 22) == " 1.03721575516329e-112"); assert (doubleToStr(str, val, 14, 22) == " 1.03721575516329e-112");
val = -val; val = -val;
assert (doubleToStr(str, val, 14, 22) == "-1.03721575516329e-112"); assert (doubleToStr(str, val, 14, 22) == "-1.03721575516329e-112");
assert (doubleToStr(str, val, 14, 23) == " -1.03721575516329e-112"); assert (doubleToStr(str, val, 14, 23) == " -1.03721575516329e-112");
val = -10372157551632.9; val = -10372157551632.9;
assert (doubleToStr(str, val, 1, 21, ',') == "-10,372,157,551,632.9"); assert (doubleToStr(str, val, 1, 21, ',') == "-10,372,157,551,632.9");
assert (doubleToStr(str, val, 1, 22, ',') == " -10,372,157,551,632.9"); assert (doubleToStr(str, val, 1, 22, ',') == " -10,372,157,551,632.9");
@@ -1046,7 +1046,7 @@ void StringTest::benchmarkFloatToStr()
sw.stop(); sw.stop();
std::cout << "std::sprintf Number: " << str << std::endl; std::cout << "std::sprintf Number: " << str << std::endl;
double timeSprintf = sw.elapsed() / 1000.0; double timeSprintf = sw.elapsed() / 1000.0;
// POCO Way (via double-conversion) // POCO Way (via double-conversion)
// no padding // no padding
sw.restart(); sw.restart();
@@ -1056,7 +1056,7 @@ void StringTest::benchmarkFloatToStr()
std::cout << "doubleToStr(char) Number: " << buffer << std::endl; std::cout << "doubleToStr(char) Number: " << buffer << std::endl;
double timeDoubleToStrChar = sw.elapsed() / 1000.0; double timeDoubleToStrChar = sw.elapsed() / 1000.0;
// with padding // with padding
str = ""; str = "";
sw.restart(); sw.restart();
for (int i = 0; i < 1000000; ++i) doubleToStr(str, val); for (int i = 0; i < 1000000; ++i) doubleToStr(str, val);
@@ -1067,16 +1067,16 @@ void StringTest::benchmarkFloatToStr()
int graph; int graph;
std::cout << std::endl << "Timing and speedup relative to I/O stream:" << std::endl << std::endl; std::cout << std::endl << "Timing and speedup relative to I/O stream:" << std::endl << std::endl;
std::cout << std::setw(14) << "Stream:\t" << std::setw(10) << std::setfill(' ') << std::setprecision(4) << timeStream << "[ms]" << std::endl; std::cout << std::setw(14) << "Stream:\t" << std::setw(10) << std::setfill(' ') << std::setprecision(4) << timeStream << "[ms]" << std::endl;
std::cout << std::setw(14) << "sprintf:\t" << std::setw(10) << std::setfill(' ') << timeSprintf << "[ms]" << std::cout << std::setw(14) << "sprintf:\t" << std::setw(10) << std::setfill(' ') << timeSprintf << "[ms]" <<
std::setw(10) << std::setfill(' ') << "Speedup: " << (timeStream / timeSprintf) << '\t' ; std::setw(10) << std::setfill(' ') << "Speedup: " << (timeStream / timeSprintf) << '\t' ;
graph = (int) (timeStream / timeSprintf); for (int i = 0; i < graph; ++i) std::cout << '#'; graph = (int) (timeStream / timeSprintf); for (int i = 0; i < graph; ++i) std::cout << '#';
std::cout << std::endl << std::setw(14) << "doubleToChar:\t" << std::setw(10) << std::setfill(' ') << timeDoubleToStrChar << "[ms]" << std::cout << std::endl << std::setw(14) << "doubleToChar:\t" << std::setw(10) << std::setfill(' ') << timeDoubleToStrChar << "[ms]" <<
std::setw(10) << std::setfill(' ') << "Speedup: " << (timeStream / timeDoubleToStrChar) << '\t' ; std::setw(10) << std::setfill(' ') << "Speedup: " << (timeStream / timeDoubleToStrChar) << '\t' ;
graph = (int) (timeStream / timeDoubleToStrChar); for (int i = 0; i < graph; ++i) std::cout << '#'; graph = (int) (timeStream / timeDoubleToStrChar); for (int i = 0; i < graph; ++i) std::cout << '#';
std::cout << std::endl << std::setw(14) << "doubleToString:\t" << std::setw(10) << std::setfill(' ') << timeDoubleToStrString << "[ms]" << std::cout << std::endl << std::setw(14) << "doubleToString:\t" << std::setw(10) << std::setfill(' ') << timeDoubleToStrString << "[ms]" <<
std::setw(10) << std::setfill(' ') << "Speedup: " << (timeStream / timeDoubleToStrString) << '\t' ; std::setw(10) << std::setfill(' ') << "Speedup: " << (timeStream / timeDoubleToStrString) << '\t' ;
graph = (int) (timeStream / timeDoubleToStrString); for (int i = 0; i < graph; ++i) std::cout << '#'; graph = (int) (timeStream / timeDoubleToStrString); for (int i = 0; i < graph; ++i) std::cout << '#';
@@ -1086,17 +1086,17 @@ void StringTest::benchmarkFloatToStr()
void StringTest::testJSONString() void StringTest::testJSONString()
{ {
assert (toJSON('\\') == "\\\\"); assert (toJSON("\\", false) == "\\\\");
assert (toJSON('"') == "\\\""); assert (toJSON("\"", false) == "\\\"");
assert (toJSON('/') == "\\/"); assert (toJSON("/", false) == "\\/");
assert (toJSON('\b') == "\\b"); assert (toJSON("\b", false) == "\\b");
assert (toJSON('\f') == "\\f"); assert (toJSON("\f", false) == "\\f");
assert (toJSON('\n') == "\\n"); assert (toJSON("\n", false) == "\\n");
assert (toJSON('\r') == "\\r"); assert (toJSON("\r", false) == "\\r");
assert (toJSON('\t') == "\\t"); assert (toJSON("\t", false) == "\\t");
assert (toJSON('a') == "a"); assert (toJSON("a", false) == "a");
// ??? on MSVC, the assert macro expansion // ??? on MSVC, the assert macro expansion
// fails to compile when this string is inline ??? // fails to compile when this string is inline ???
std::string str = "\"foo\\\\\""; std::string str = "\"foo\\\\\"";
assert (toJSON("foo\\") == str); assert (toJSON("foo\\") == str);

View File

@@ -72,7 +72,7 @@ void VarTest::testInt8()
{ {
Poco::Int8 src = 32; Poco::Int8 src = 32;
Var a1 = src; Var a1 = src;
assert (a1.type() == typeid(Poco::Int8)); assert (a1.type() == typeid(Poco::Int8));
std::string s1; std::string s1;
@@ -124,10 +124,10 @@ void VarTest::testInt8()
std::string t2; std::string t2;
a2.convert(t2); a2.convert(t2);
assert (s1 == t2); assert (s1 == t2);
Int8 value = a1.extract<Int8>(); Int8 value = a1.extract<Int8>();
assert (value == 32); assert (value == 32);
try try
{ {
Int16 value2; value2 = a1.extract<Int16>(); Int16 value2; value2 = a1.extract<Int16>();
@@ -215,7 +215,7 @@ void VarTest::testInt16()
Int16 value = a1.extract<Int16>(); Int16 value = a1.extract<Int16>();
assert (value == 32); assert (value == 32);
try try
{ {
Int32 value2; value2 = a1.extract<Int32>(); Int32 value2; value2 = a1.extract<Int32>();
@@ -248,7 +248,7 @@ void VarTest::testInt32()
{ {
Poco::Int32 src = 32; Poco::Int32 src = 32;
Var a1 = src; Var a1 = src;
assert (a1.type() == typeid(Poco::Int32)); assert (a1.type() == typeid(Poco::Int32));
std::string s1; std::string s1;
@@ -300,10 +300,10 @@ void VarTest::testInt32()
std::string t2; std::string t2;
a2.convert(t2); a2.convert(t2);
assert (s1 == t2); assert (s1 == t2);
Int32 value = a1.extract<Int32>(); Int32 value = a1.extract<Int32>();
assert (value == 32); assert (value == 32);
try try
{ {
Int16 value2; value2 = a1.extract<Int16>(); Int16 value2; value2 = a1.extract<Int16>();
@@ -336,7 +336,7 @@ void VarTest::testInt64()
{ {
Poco::Int64 src = 32; Poco::Int64 src = 32;
Var a1 = src; Var a1 = src;
assert (a1.type() == typeid(Poco::Int64)); assert (a1.type() == typeid(Poco::Int64));
std::string s1; std::string s1;
@@ -391,7 +391,7 @@ void VarTest::testInt64()
Int64 value = a1.extract<Int64>(); Int64 value = a1.extract<Int64>();
assert (value == 32); assert (value == 32);
try try
{ {
Int16 value2; value2 = a1.extract<Int16>(); Int16 value2; value2 = a1.extract<Int16>();
@@ -479,7 +479,7 @@ void VarTest::testUInt8()
UInt8 value = a1.extract<UInt8>(); UInt8 value = a1.extract<UInt8>();
assert (value == 32); assert (value == 32);
try try
{ {
Int16 value2; value2 = a1.extract<Int16>(); Int16 value2; value2 = a1.extract<Int16>();
@@ -567,7 +567,7 @@ void VarTest::testUInt16()
UInt16 value = a1.extract<UInt16>(); UInt16 value = a1.extract<UInt16>();
assert (value == 32); assert (value == 32);
try try
{ {
Int16 value2; value2 = a1.extract<Int16>(); Int16 value2; value2 = a1.extract<Int16>();
@@ -655,7 +655,7 @@ void VarTest::testUInt32()
UInt32 value = a1.extract<UInt32>(); UInt32 value = a1.extract<UInt32>();
assert (value == 32); assert (value == 32);
try try
{ {
Int16 value2; value2 = a1.extract<Int16>(); Int16 value2; value2 = a1.extract<Int16>();
@@ -743,7 +743,7 @@ void VarTest::testUInt64()
UInt64 value = a1.extract<UInt64>(); UInt64 value = a1.extract<UInt64>();
assert (value == 32); assert (value == 32);
try try
{ {
Int16 value2; value2 = a1.extract<Int16>(); Int16 value2; value2 = a1.extract<Int16>();
@@ -776,7 +776,7 @@ void VarTest::testBool()
{ {
bool src = true; bool src = true;
Var a1 = src; Var a1 = src;
assert (a1.type() == typeid(bool)); assert (a1.type() == typeid(bool));
std::string s1; std::string s1;
@@ -831,7 +831,7 @@ void VarTest::testBool()
bool value = a1.extract<bool>(); bool value = a1.extract<bool>();
assert (value); assert (value);
try try
{ {
Int16 value2; value2 = a1.extract<Int16>(); Int16 value2; value2 = a1.extract<Int16>();
@@ -847,7 +847,7 @@ void VarTest::testChar()
{ {
char src = ' '; char src = ' ';
Var a1 = src; Var a1 = src;
assert (a1.type() == typeid(char)); assert (a1.type() == typeid(char));
std::string s1; std::string s1;
@@ -902,7 +902,7 @@ void VarTest::testChar()
char value = a1.extract<char>(); char value = a1.extract<char>();
assert (value == ' '); assert (value == ' ');
try try
{ {
Int16 value2; value2 = a1.extract<Int16>(); Int16 value2; value2 = a1.extract<Int16>();
@@ -921,7 +921,7 @@ void VarTest::testFloat()
float src = 32.0f; float src = 32.0f;
Var a1 = src; Var a1 = src;
assert (a1.type() == typeid(float)); assert (a1.type() == typeid(float));
std::string s1; std::string s1;
@@ -976,7 +976,7 @@ void VarTest::testFloat()
float value = a1.extract<float>(); float value = a1.extract<float>();
assert (value == 32.0f); assert (value == 32.0f);
try try
{ {
Int16 value2; value2 = a1.extract<Int16>(); Int16 value2; value2 = a1.extract<Int16>();
@@ -1013,7 +1013,7 @@ void VarTest::testDouble()
double src = 32.0; double src = 32.0;
Var a1 = src; Var a1 = src;
assert (a1.type() == typeid(double)); assert (a1.type() == typeid(double));
std::string s1; std::string s1;
@@ -1068,7 +1068,7 @@ void VarTest::testDouble()
double value = a1.extract<double>(); double value = a1.extract<double>();
assert (value == 32.0); assert (value == 32.0);
try try
{ {
Int16 value2; value2 = a1.extract<Int16>(); Int16 value2; value2 = a1.extract<Int16>();
@@ -1078,7 +1078,7 @@ void VarTest::testDouble()
{ {
} }
Var a3 = a1 + 1.0; Var a3 = a1 + 1.0;
assert (a3 == 33.0); assert (a3 == 33.0);
a3 = a1 - 1.0; a3 = a1 - 1.0;
@@ -1101,7 +1101,7 @@ void VarTest::testDouble()
void VarTest::testString() void VarTest::testString()
{ {
Var a1("32"); Var a1("32");
assert (a1.type() == typeid(std::string)); assert (a1.type() == typeid(std::string));
std::string s1; std::string s1;
@@ -1152,7 +1152,7 @@ void VarTest::testString()
const std::string& value = a1.extract<std::string>(); const std::string& value = a1.extract<std::string>();
assert (value == "32"); assert (value == "32");
try try
{ {
Int16 value2; value2 = a1.extract<Int16>(); Int16 value2; value2 = a1.extract<Int16>();
@@ -1186,7 +1186,7 @@ void VarTest::testLong()
{ {
long src = 32; long src = 32;
Var a1 = src; Var a1 = src;
assert (a1.type() == typeid(long)); assert (a1.type() == typeid(long));
std::string s1; std::string s1;
@@ -1238,10 +1238,10 @@ void VarTest::testLong()
std::string t2; std::string t2;
a2.convert(t2); a2.convert(t2);
assert (s1 == t2); assert (s1 == t2);
long value = a1.extract<long>(); long value = a1.extract<long>();
assert (value == 32); assert (value == 32);
try try
{ {
Int16 value2; value2 = a1.extract<Int16>(); Int16 value2; value2 = a1.extract<Int16>();
@@ -1274,7 +1274,7 @@ void VarTest::testULong()
{ {
unsigned long src = 32; unsigned long src = 32;
Var a1 = src; Var a1 = src;
assert (a1.type() == typeid(unsigned long)); assert (a1.type() == typeid(unsigned long));
std::string s1; std::string s1;
@@ -1329,7 +1329,7 @@ void VarTest::testULong()
unsigned long value = a1.extract<unsigned long>(); unsigned long value = a1.extract<unsigned long>();
assert (value == 32); assert (value == 32);
try try
{ {
Int16 value2; value2 = a1.extract<Int16>(); Int16 value2; value2 = a1.extract<Int16>();
@@ -1607,26 +1607,26 @@ void VarTest::testArithmeticOperators()
assert (any3 == "123456789"); assert (any3 == "123456789");
assert (("xyz" + any3) == "xyz123456789"); assert (("xyz" + any3) == "xyz123456789");
try { any3 = any1 - any2; fail ("must fail"); } try { any3 = any1 - any2; fail ("must fail"); }
catch (InvalidArgumentException&){} catch (InvalidArgumentException&){}
try { any3 -= any2; fail ("must fail"); } try { any3 -= any2; fail ("must fail"); }
catch (InvalidArgumentException&){} catch (InvalidArgumentException&){}
try { any3 = any1 * any2; fail ("must fail"); } try { any3 = any1 * any2; fail ("must fail"); }
catch (InvalidArgumentException&){} catch (InvalidArgumentException&){}
try { any3 *= any2; fail ("must fail"); } try { any3 *= any2; fail ("must fail"); }
catch (InvalidArgumentException&){} catch (InvalidArgumentException&){}
try { any3 = any1 / any2; fail ("must fail"); } try { any3 = any1 / any2; fail ("must fail"); }
catch (InvalidArgumentException&){} catch (InvalidArgumentException&){}
try { any3 /= any2; fail ("must fail"); } try { any3 /= any2; fail ("must fail"); }
catch (InvalidArgumentException&){} catch (InvalidArgumentException&){}
any1 = 10; any1 = 10;
assert (any1++ == 10); assert (any1++ == 10);
assert (any1 == 11); assert (any1 == 11);
assert (++any1 == 12); assert (++any1 == 12);
@@ -1637,16 +1637,16 @@ void VarTest::testArithmeticOperators()
any1 = 1.23; any1 = 1.23;
try { ++any1; fail ("must fail"); } try { ++any1; fail ("must fail"); }
catch (InvalidArgumentException&){}
try { any1++; fail ("must fail"); }
catch (InvalidArgumentException&){} catch (InvalidArgumentException&){}
try { --any1; fail ("must fail"); } try { any1++; fail ("must fail"); }
catch (InvalidArgumentException&){} catch (InvalidArgumentException&){}
try { any1--; fail ("must fail"); } try { --any1; fail ("must fail"); }
catch (InvalidArgumentException&){}
try { any1--; fail ("must fail"); }
catch (InvalidArgumentException&){} catch (InvalidArgumentException&){}
} }
@@ -1733,9 +1733,9 @@ void VarTest::testCtor()
Var a1(42); Var a1(42);
Var a2(a1); Var a2(a1);
Var a3; Var a3;
a3 = a1; a3 = a1;
assert (a2 == 42); assert (a2 == 42);
assert (a3 == 42); assert (a3 == 42);
} }
@@ -2157,7 +2157,7 @@ void VarTest::testArrayOfStructsToString()
"{ \"Age\" : 1, \"First Name\" : \"Junior\", \"Last Name\" : \"POCO\" }, " "{ \"Age\" : 1, \"First Name\" : \"Junior\", \"Last Name\" : \"POCO\" }, "
"{ \"Age\" : 100, \"First Name\" : \"Senior\", \"Last Name\" : \"POCO\" } " "{ \"Age\" : 100, \"First Name\" : \"Senior\", \"Last Name\" : \"POCO\" } "
"] ] ]"; "] ] ]";
assert (res == expected); assert (res == expected);
assert (a1.toString() == res); assert (a1.toString() == res);
} }
@@ -2388,7 +2388,7 @@ void VarTest::testJSONDeserializeStruct()
void VarTest::testDate() void VarTest::testDate()
{ {
Poco::DateTime dtNow(2007, 3, 13, 8, 12, 15); Poco::DateTime dtNow(2007, 3, 13, 8, 12, 15);
Poco::Timestamp tsNow = dtNow.timestamp(); Poco::Timestamp tsNow = dtNow.timestamp();
Poco::LocalDateTime ldtNow(dtNow.timestamp()); Poco::LocalDateTime ldtNow(dtNow.timestamp());
Var dt(dtNow); Var dt(dtNow);
@@ -2425,7 +2425,7 @@ void VarTest::testGetIdxMustThrow(Var& a1, std::vector<Var>::size_type n)
{ {
try try
{ {
Var val1 = a1[n]; Var val1 = a1[n];
fail("bad cast - must throw"); fail("bad cast - must throw");
val1 = 0; // silence the compiler val1 = 0; // silence the compiler
} }
@@ -2439,7 +2439,7 @@ void VarTest::testGetIdxMustThrow(Var& a1, std::vector<Var>::size_type n)
try try
{ {
const Var& c1 = a1; const Var& c1 = a1;
const Var& cval1 = c1[n]; const Var& cval1 = c1[n];
fail("bad const cast - must throw"); fail("bad const cast - must throw");
assert (cval1 == c1); // silence the compiler assert (cval1 == c1); // silence the compiler
} }

View File

@@ -376,7 +376,7 @@ void JSONTest::testEmptyObject()
void JSONTest::testComplexObject() void JSONTest::testComplexObject()
{ {
std::string json = std::string json =
"{" "{"
"\"id\": 1," "\"id\": 1,"
"\"jsonrpc\": \"2.0\"," "\"jsonrpc\": \"2.0\","
@@ -430,7 +430,7 @@ void JSONTest::testComplexObject()
"}" "}"
"]" "]"
"}"; "}";
Parser parser; Parser parser;
Var result; Var result;
@@ -599,7 +599,7 @@ void JSONTest::testObjectProperty()
} }
assert(result.type() == typeid(Object::Ptr)); assert(result.type() == typeid(Object::Ptr));
Object::Ptr object = result.extract<Object::Ptr>(); Object::Ptr object = result.extract<Object::Ptr>();
assert (object->isObject("test")); assert (object->isObject("test"));
assert (!object->isArray("test")); assert (!object->isArray("test"));
@@ -1104,7 +1104,7 @@ void JSONTest::testComment()
catch(Poco::SyntaxException&) catch(Poco::SyntaxException&)
{ {
} }
parser.reset(); parser.reset();
parser.setAllowComments(true); parser.setAllowComments(true);
try try
@@ -1187,7 +1187,7 @@ void JSONTest::testPrintHandler()
"}" "}"
); );
json = json =
"{" "{"
"\"array\":" "\"array\":"
"[" "["
@@ -1453,7 +1453,7 @@ void JSONTest::testStringifyPreserveOrder()
assert (ostr.str() == "{\"Simpsons\":{\"husband\":{\"name\":\"Homer\",\"age\":38},\"wife\":{\"name\":\"Marge\",\"age\":36}," assert (ostr.str() == "{\"Simpsons\":{\"husband\":{\"name\":\"Homer\",\"age\":38},\"wife\":{\"name\":\"Marge\",\"age\":36},"
"\"children\":[\"Bart\",\"Lisa\",\"Maggie\"]," "\"children\":[\"Bart\",\"Lisa\",\"Maggie\"],"
"\"address\":{\"number\":742,\"street\":\"Evergreen Terrace\",\"town\":\"Springfield\"}}}"); "\"address\":{\"number\":742,\"street\":\"Evergreen Terrace\",\"town\":\"Springfield\"}}}");
ostr.str(""); ostr.str("");
Stringifier::stringify(result, ostr, 1); Stringifier::stringify(result, ostr, 1);
assert (ostr.str() == "{\n" assert (ostr.str() == "{\n"
@@ -1473,7 +1473,7 @@ void JSONTest::testStringifyPreserveOrder()
" ],\n" " ],\n"
" \"address\" : {\n" " \"address\" : {\n"
" \"number\" : 742,\n" " \"number\" : 742,\n"
" \"street\" : \"Evergreen Terrace\",\n" " \"street\" : \"Evergreen Terrace\",\n"
" \"town\" : \"Springfield\"\n" " \"town\" : \"Springfield\"\n"
" }\n" " }\n"
" }\n" " }\n"
@@ -1498,7 +1498,7 @@ void JSONTest::testStringifyPreserveOrder()
" ],\n" " ],\n"
" \"address\" : {\n" " \"address\" : {\n"
" \"number\" : 742,\n" " \"number\" : 742,\n"
" \"street\" : \"Evergreen Terrace\",\n" " \"street\" : \"Evergreen Terrace\",\n"
" \"town\" : \"Springfield\"\n" " \"town\" : \"Springfield\"\n"
" }\n" " }\n"
" }\n" " }\n"
@@ -1523,7 +1523,7 @@ void JSONTest::testStringifyPreserveOrder()
" ],\n" " ],\n"
" \"address\" : {\n" " \"address\" : {\n"
" \"number\" : 742,\n" " \"number\" : 742,\n"
" \"street\" : \"Evergreen Terrace\",\n" " \"street\" : \"Evergreen Terrace\",\n"
" \"town\" : \"Springfield\"\n" " \"town\" : \"Springfield\"\n"
" }\n" " }\n"
" }\n" " }\n"
@@ -1534,16 +1534,16 @@ void JSONTest::testStringifyPreserveOrder()
assert (ds["Simpsons"]["husband"].isStruct()); assert (ds["Simpsons"]["husband"].isStruct());
assert (ds["Simpsons"]["husband"]["name"] == "Homer"); assert (ds["Simpsons"]["husband"]["name"] == "Homer");
assert (ds["Simpsons"]["husband"]["age"] == 38); assert (ds["Simpsons"]["husband"]["age"] == 38);
assert (ds["Simpsons"]["wife"].isStruct()); assert (ds["Simpsons"]["wife"].isStruct());
assert (ds["Simpsons"]["wife"]["name"] == "Marge"); assert (ds["Simpsons"]["wife"]["name"] == "Marge");
assert (ds["Simpsons"]["wife"]["age"] == 36); assert (ds["Simpsons"]["wife"]["age"] == 36);
assert (ds["Simpsons"]["children"].isArray()); assert (ds["Simpsons"]["children"].isArray());
assert (ds["Simpsons"]["children"][0] == "Bart"); assert (ds["Simpsons"]["children"][0] == "Bart");
assert (ds["Simpsons"]["children"][1] == "Lisa"); assert (ds["Simpsons"]["children"][1] == "Lisa");
assert (ds["Simpsons"]["children"][2] == "Maggie"); assert (ds["Simpsons"]["children"][2] == "Maggie");
assert (ds["Simpsons"]["address"].isStruct()); assert (ds["Simpsons"]["address"].isStruct());
assert (ds["Simpsons"]["address"]["number"] == 742); assert (ds["Simpsons"]["address"]["number"] == 742);
assert (ds["Simpsons"]["address"]["street"] == "Evergreen Terrace"); assert (ds["Simpsons"]["address"]["street"] == "Evergreen Terrace");
@@ -1625,7 +1625,7 @@ void JSONTest::testInvalidJanssonFiles()
parser.parse(fis); parser.parse(fis);
result = parser.asVar(); result = parser.asVar();
// We shouldn't get here. // We shouldn't get here.
std::cout << "We didn't get an exception. This is the result: " << result.convert<std::string>() << std::endl; std::cout << "We didn't get an exception. This is the result: " << result.convert<std::string>() << std::endl;
fail(result.convert<std::string>()); fail(result.convert<std::string>());
} }
catch(JSONException&) catch(JSONException&)
@@ -1668,7 +1668,7 @@ void JSONTest::testInvalidUnicodeJanssonFiles()
parser.parse(fis); parser.parse(fis);
result = parser.asVar(); result = parser.asVar();
// We shouldn't get here. // We shouldn't get here.
std::cout << "We didn't get an exception. This is the result: " << result.convert<std::string>() << std::endl; std::cout << "We didn't get an exception. This is the result: " << result.convert<std::string>() << std::endl;
fail(result.convert<std::string>()); fail(result.convert<std::string>());
} }
catch(JSONException&) catch(JSONException&)
@@ -1782,6 +1782,38 @@ void JSONTest::testSmallBuffer()
parser.parse(jsonStr); parser.parse(jsonStr);
} }
void JSONTest::testEscape0()
{
Poco::JSON::Object::Ptr json = new Poco::JSON::Object();
std::string nullString("B\0b", 3);
json->set("name", nullString);
std::stringstream ss;
json->stringify(ss);
assert(ss.str().compare("{\"name\":\"B\\u0000b\"}") == 0);
}
void JSONTest::testEscapeUnicode()
{
Poco::JSON::Object::Ptr json = new Poco::JSON::Object();
std::string chinese("{ \"name\" : \"\\u4e2d\" }");
Poco::JSON::Parser parser(new Poco::JSON::ParseHandler());
Var result = parser.parse(chinese);
assert(result.type() == typeid(Object::Ptr));
Object::Ptr object = result.extract<Object::Ptr>();
std::stringstream ss;
object->stringify(ss);
//assert(ss.str().compare("{\"name\":\"B\\u0000b\"}") == 0);
std::cout << ss.str() << std::endl;
}
std::string JSONTest::getTestFilesPath(const std::string& type) std::string JSONTest::getTestFilesPath(const std::string& type)
{ {
@@ -1798,6 +1830,7 @@ std::string JSONTest::getTestFilesPath(const std::string& type)
ostr.str(""); ostr.str("");
ostr << "/JSON/testsuite/data/" << type << '/'; ostr << "/JSON/testsuite/data/" << type << '/';
validDir = Poco::Environment::get("POCO_BASE") + ostr.str(); validDir = Poco::Environment::get("POCO_BASE") + ostr.str();
std::cout << validDir << std::endl;
pathPattern = validDir; pathPattern = validDir;
if (Poco::File(pathPattern).exists()) if (Poco::File(pathPattern).exists())
@@ -1855,6 +1888,8 @@ CppUnit::Test* JSONTest::suite()
CppUnit_addTest(pSuite, JSONTest, testTemplate); CppUnit_addTest(pSuite, JSONTest, testTemplate);
CppUnit_addTest(pSuite, JSONTest, testUnicode); CppUnit_addTest(pSuite, JSONTest, testUnicode);
CppUnit_addTest(pSuite, JSONTest, testSmallBuffer); CppUnit_addTest(pSuite, JSONTest, testSmallBuffer);
CppUnit_addTest(pSuite, JSONTest, testEscape0);
CppUnit_addTest(pSuite, JSONTest, testEscapeUnicode);
return pSuite; return pSuite;
} }

View File

@@ -74,10 +74,11 @@ public:
void testInvalidJanssonFiles(); void testInvalidJanssonFiles();
void testTemplate(); void testTemplate();
void testItunes(); void testItunes();
void testUnicode(); void testUnicode();
void testInvalidUnicodeJanssonFiles(); void testInvalidUnicodeJanssonFiles();
void testSmallBuffer(); void testSmallBuffer();
void testEscape0();
void testEscapeUnicode();
void setUp(); void setUp();
void tearDown(); void tearDown();