Commit 1bfa188d authored by Milo Yip's avatar Milo Yip

Improve encodings coverage

parent 105c92ee
...@@ -423,3 +423,28 @@ TEST(EncodingsTest, UTF32) { ...@@ -423,3 +423,28 @@ TEST(EncodingsTest, UTF32) {
} }
} }
} }
TEST(EncodingsTest, ASCII) {
StringBuffer os, os2;
for (unsigned codepoint = 0; codepoint < 128; codepoint++) {
os.Clear();
ASCII<>::Encode(os, codepoint);
const ASCII<>::Ch* encodedStr = os.GetString();
{
StringStream is(encodedStr);
unsigned decodedCodepoint;
bool result = ASCII<>::Decode(is, &decodedCodepoint);
if (!result || codepoint != decodedCodepoint)
std::cout << std::hex << codepoint << " " << decodedCodepoint << std::endl;
}
// Validate
{
StringStream is(encodedStr);
os2.Clear();
bool result = ASCII<>::Validate(is, os2);
EXPECT_TRUE(result);
EXPECT_EQ(0, StrCmp(encodedStr, os2.GetString()));
}
}
}
...@@ -18,6 +18,7 @@ ...@@ -18,6 +18,7 @@
#include "rapidjson/reader.h" #include "rapidjson/reader.h"
#include "rapidjson/writer.h" #include "rapidjson/writer.h"
#include "rapidjson/stringbuffer.h" #include "rapidjson/stringbuffer.h"
#include "rapidjson/memorybuffer.h"
using namespace rapidjson; using namespace rapidjson;
...@@ -107,35 +108,58 @@ TEST(Writer, Double) { ...@@ -107,35 +108,58 @@ TEST(Writer, Double) {
} }
// UTF8 -> TargetEncoding -> UTF8
template <typename TargetEncoding>
void TestTranscode(const char* json) {
StringStream s(json);
GenericStringBuffer<TargetEncoding> buffer;
Writer<GenericStringBuffer<TargetEncoding>, UTF8<>, TargetEncoding> writer(buffer);
Reader reader;
reader.Parse(s, writer);
StringBuffer buffer2;
Writer<StringBuffer> writer2(buffer2);
GenericReader<TargetEncoding, UTF8<> > reader2;
GenericStringStream<TargetEncoding> s2(buffer.GetString());
reader2.Parse(s2, writer2);
EXPECT_STREQ(json, buffer2.GetString());
}
TEST(Writer, Transcode) { TEST(Writer, Transcode) {
const char json[] = "{\"hello\":\"world\",\"t\":true,\"f\":false,\"n\":null,\"i\":123,\"pi\":3.1416,\"a\":[1,2,3],\"dollar\":\"\x24\",\"cents\":\"\xC2\xA2\",\"euro\":\"\xE2\x82\xAC\",\"gclef\":\"\xF0\x9D\x84\x9E\"}"; const char json[] = "{\"hello\":\"world\",\"t\":true,\"f\":false,\"n\":null,\"i\":123,\"pi\":3.1416,\"a\":[1,2,3],\"dollar\":\"\x24\",\"cents\":\"\xC2\xA2\",\"euro\":\"\xE2\x82\xAC\",\"gclef\":\"\xF0\x9D\x84\x9E\"}";
// UTF8 -> UTF16 -> UTF8 // UTF8 -> UTF16 -> UTF8
{ TestTranscode<UTF8<> >(json);
StringStream s(json);
StringBuffer buffer; // UTF8 -> ASCII -> UTF8
Writer<StringBuffer, UTF16<>, UTF8<> > writer(buffer); TestTranscode<ASCII<> >(json);
GenericReader<UTF8<>, UTF16<> > reader;
reader.Parse(s, writer); // UTF8 -> UTF16 -> UTF8
EXPECT_STREQ(json, buffer.GetString()); TestTranscode<UTF16<> >(json);
}
// UTF8 -> UTF32 -> UTF8
TestTranscode<UTF32<> >(json);
// UTF8 -> UTF8 -> ASCII -> UTF8 -> UTF8 // UTF8 -> AutoUTF (UTF16BE) -> UTF8
{ {
StringStream s(json); StringStream s(json);
StringBuffer buffer; MemoryBuffer buffer;
Writer<StringBuffer, UTF8<>, ASCII<> > writer(buffer); AutoUTFOutputStream<unsigned, MemoryBuffer> os(buffer, kUTF16BE, true);
Writer<AutoUTFOutputStream<unsigned, MemoryBuffer>, UTF8<>, AutoUTF<unsigned> > writer(os);
Reader reader; Reader reader;
reader.Parse(s, writer); reader.Parse(s, writer);
StringBuffer buffer2; StringBuffer buffer2;
Writer<StringBuffer> writer2(buffer2); Writer<StringBuffer> writer2(buffer2);
GenericReader<ASCII<>, UTF8<> > reader2; GenericReader<AutoUTF<unsigned>, UTF8<> > reader2;
StringStream s2(buffer.GetString()); MemoryStream s2(buffer.GetBuffer(), buffer.GetSize());
reader2.Parse(s2, writer2); AutoUTFInputStream<unsigned, MemoryStream> is(s2);
reader2.Parse(is, writer2);
EXPECT_STREQ(json, buffer2.GetString()); EXPECT_STREQ(json, buffer2.GetString());
} }
} }
#include <sstream> #include <sstream>
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment