Wire Sysio Wire Sysion 1.0.0
Loading...
Searching...
No Matches
encodedstreamtest.cpp
Go to the documentation of this file.
1// Tencent is pleased to support the open source community by making RapidJSON available.
2//
3// Copyright (C) 2015 THL A29 Limited, a Tencent company, and Milo Yip. All rights reserved.
4//
5// Licensed under the MIT License (the "License"); you may not use this file except
6// in compliance with the License. You may obtain a copy of the License at
7//
8// http://opensource.org/licenses/MIT
9//
10// Unless required by applicable law or agreed to in writing, software distributed
11// under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
12// CONDITIONS OF ANY KIND, either express or implied. See the License for the
13// specific language governing permissions and limitations under the License.
14
15#include "unittest.h"
22
23using namespace rapidjson;
24
26public:
28 virtual ~EncodedStreamTest();
29
30 virtual void SetUp() {
31 json_ = ReadFile("utf8.json", true, &length_);
32 }
33
34 virtual void TearDown() {
35 free(json_);
36 json_ = 0;
37 }
38
39private:
41 EncodedStreamTest& operator=(const EncodedStreamTest&);
42
43protected:
44 static FILE* Open(const char* filename) {
45 const char *paths[] = {
46 "encodings",
47 "bin/encodings",
48 "../bin/encodings",
49 "../../bin/encodings",
50 "../../../bin/encodings"
51 };
52 char buffer[1024];
53 for (size_t i = 0; i < sizeof(paths) / sizeof(paths[0]); i++) {
54 sprintf(buffer, "%s/%s", paths[i], filename);
55 FILE *fp = fopen(buffer, "rb");
56 if (fp)
57 return fp;
58 }
59 return 0;
60 }
61
62 static char *ReadFile(const char* filename, bool appendPath, size_t* outLength) {
63 FILE *fp = appendPath ? Open(filename) : fopen(filename, "rb");
64
65 if (!fp) {
66 *outLength = 0;
67 return 0;
68 }
69
70 fseek(fp, 0, SEEK_END);
71 *outLength = static_cast<size_t>(ftell(fp));
72 fseek(fp, 0, SEEK_SET);
73 char* buffer = static_cast<char*>(malloc(*outLength + 1));
74 size_t readLength = fread(buffer, 1, *outLength, fp);
75 buffer[readLength] = '\0';
76 fclose(fp);
77 return buffer;
78 }
79
80 template <typename FileEncoding, typename MemoryEncoding>
81 void TestEncodedInputStream(const char* filename) {
82 // Test FileReadStream
83 {
84 char buffer[16];
85 FILE *fp = Open(filename);
86 ASSERT_TRUE(fp != 0);
87 FileReadStream fs(fp, buffer, sizeof(buffer));
90
91 while (eis.Peek() != '\0') {
92 unsigned expected, actual;
93 EXPECT_TRUE(UTF8<>::Decode(s, &expected));
94 EXPECT_TRUE(MemoryEncoding::Decode(eis, &actual));
95 EXPECT_EQ(expected, actual);
96 }
97 EXPECT_EQ('\0', s.Peek());
98 fclose(fp);
99 }
100
101 // Test MemoryStream
102 {
103 size_t size;
104 char* data = ReadFile(filename, true, &size);
105 MemoryStream ms(data, size);
108
109 while (eis.Peek() != '\0') {
110 unsigned expected, actual;
111 EXPECT_TRUE(UTF8<>::Decode(s, &expected));
112 EXPECT_TRUE(MemoryEncoding::Decode(eis, &actual));
113 EXPECT_EQ(expected, actual);
114 }
115 EXPECT_EQ('\0', s.Peek());
116 free(data);
117 EXPECT_EQ(size, eis.Tell());
118 }
119 }
120
121 void TestAutoUTFInputStream(const char *filename, bool expectHasBOM) {
122 // Test FileReadStream
123 {
124 char buffer[16];
125 FILE *fp = Open(filename);
126 ASSERT_TRUE(fp != 0);
127 FileReadStream fs(fp, buffer, sizeof(buffer));
129 EXPECT_EQ(expectHasBOM, eis.HasBOM());
131 while (eis.Peek() != '\0') {
132 unsigned expected, actual;
133 EXPECT_TRUE(UTF8<>::Decode(s, &expected));
135 EXPECT_EQ(expected, actual);
136 }
137 EXPECT_EQ('\0', s.Peek());
138 fclose(fp);
139 }
140
141 // Test MemoryStream
142 {
143 size_t size;
144 char* data = ReadFile(filename, true, &size);
145 MemoryStream ms(data, size);
147 EXPECT_EQ(expectHasBOM, eis.HasBOM());
149
150 while (eis.Peek() != '\0') {
151 unsigned expected, actual;
152 EXPECT_TRUE(UTF8<>::Decode(s, &expected));
154 EXPECT_EQ(expected, actual);
155 }
156 EXPECT_EQ('\0', s.Peek());
157 free(data);
158 EXPECT_EQ(size, eis.Tell());
159 }
160 }
161
162 template <typename FileEncoding, typename MemoryEncoding>
163 void TestEncodedOutputStream(const char* expectedFilename, bool putBOM) {
164 // Test FileWriteStream
165 {
166 char filename[L_tmpnam];
167 FILE* fp = TempFile(filename);
168 char buffer[16];
169 FileWriteStream os(fp, buffer, sizeof(buffer));
172 while (s.Peek() != '\0') {
173 bool success = Transcoder<UTF8<>, MemoryEncoding>::Transcode(s, eos);
174 EXPECT_TRUE(success);
175 }
176 eos.Flush();
177 fclose(fp);
178 EXPECT_TRUE(CompareFile(filename, expectedFilename));
179 remove(filename);
180 }
181
182 // Test MemoryBuffer
183 {
184 MemoryBuffer mb;
187 while (s.Peek() != '\0') {
188 bool success = Transcoder<UTF8<>, MemoryEncoding>::Transcode(s, eos);
189 EXPECT_TRUE(success);
190 }
191 eos.Flush();
192 EXPECT_TRUE(CompareBufferFile(mb.GetBuffer(), mb.GetSize(), expectedFilename));
193 }
194 }
195
196 void TestAutoUTFOutputStream(UTFType type, bool putBOM, const char *expectedFilename) {
197 // Test FileWriteStream
198 {
199 char filename[L_tmpnam];
200 FILE* fp = TempFile(filename);
201
202 char buffer[16];
203 FileWriteStream os(fp, buffer, sizeof(buffer));
206 while (s.Peek() != '\0') {
207 bool success = Transcoder<UTF8<>, AutoUTF<unsigned> >::Transcode(s, eos);
208 EXPECT_TRUE(success);
209 }
210 eos.Flush();
211 fclose(fp);
212 EXPECT_TRUE(CompareFile(filename, expectedFilename));
213 remove(filename);
214 }
215
216 // Test MemoryBuffer
217 {
218 MemoryBuffer mb;
221 while (s.Peek() != '\0') {
222 bool success = Transcoder<UTF8<>, AutoUTF<unsigned> >::Transcode(s, eos);
223 EXPECT_TRUE(success);
224 }
225 eos.Flush();
226 EXPECT_TRUE(CompareBufferFile(mb.GetBuffer(), mb.GetSize(), expectedFilename));
227 }
228 }
229
230 bool CompareFile(const char* filename, const char* expectedFilename) {
231 size_t actualLength, expectedLength;
232 char* actualBuffer = ReadFile(filename, false, &actualLength);
233 char* expectedBuffer = ReadFile(expectedFilename, true, &expectedLength);
234 bool ret = (expectedLength == actualLength) && memcmp(expectedBuffer, actualBuffer, actualLength) == 0;
235 free(actualBuffer);
236 free(expectedBuffer);
237 return ret;
238 }
239
240 bool CompareBufferFile(const char* actualBuffer, size_t actualLength, const char* expectedFilename) {
241 size_t expectedLength;
242 char* expectedBuffer = ReadFile(expectedFilename, true, &expectedLength);
243 bool ret = (expectedLength == actualLength) && memcmp(expectedBuffer, actualBuffer, actualLength) == 0;
244 free(expectedBuffer);
245 return ret;
246 }
247
248 char *json_;
249 size_t length_;
250};
251
253
255 TestEncodedInputStream<UTF8<>, UTF8<> >("utf8.json");
256 TestEncodedInputStream<UTF8<>, UTF8<> >("utf8bom.json");
257 TestEncodedInputStream<UTF16LE<>, UTF16<> >("utf16le.json");
258 TestEncodedInputStream<UTF16LE<>, UTF16<> >("utf16lebom.json");
259 TestEncodedInputStream<UTF16BE<>, UTF16<> >("utf16be.json");
260 TestEncodedInputStream<UTF16BE<>, UTF16<> >("utf16bebom.json");
261 TestEncodedInputStream<UTF32LE<>, UTF32<> >("utf32le.json");
262 TestEncodedInputStream<UTF32LE<>, UTF32<> >("utf32lebom.json");
263 TestEncodedInputStream<UTF32BE<>, UTF32<> >("utf32be.json");
264 TestEncodedInputStream<UTF32BE<>, UTF32<> >("utf32bebom.json");
265}
266
268 TestAutoUTFInputStream("utf8.json", false);
269 TestAutoUTFInputStream("utf8bom.json", true);
270 TestAutoUTFInputStream("utf16le.json", false);
271 TestAutoUTFInputStream("utf16lebom.json",true);
272 TestAutoUTFInputStream("utf16be.json", false);
273 TestAutoUTFInputStream("utf16bebom.json",true);
274 TestAutoUTFInputStream("utf32le.json", false);
275 TestAutoUTFInputStream("utf32lebom.json",true);
276 TestAutoUTFInputStream("utf32be.json", false);
277 TestAutoUTFInputStream("utf32bebom.json", true);
278
279 {
280 // Auto detection fail, use user defined UTF type
281 const char json[] = "{ }";
282 MemoryStream ms(json, sizeof(json));
284 EXPECT_FALSE(eis.HasBOM());
285 EXPECT_EQ(kUTF8, eis.GetType());
286 }
287}
288
290 TestEncodedOutputStream<UTF8<>, UTF8<> >("utf8.json", false);
291 TestEncodedOutputStream<UTF8<>, UTF8<> >("utf8bom.json", true);
292 TestEncodedOutputStream<UTF16LE<>, UTF16<> >("utf16le.json", false);
293 TestEncodedOutputStream<UTF16LE<>, UTF16<> >("utf16lebom.json",true);
294 TestEncodedOutputStream<UTF16BE<>, UTF16<> >("utf16be.json", false);
295 TestEncodedOutputStream<UTF16BE<>, UTF16<> >("utf16bebom.json",true);
296 TestEncodedOutputStream<UTF32LE<>, UTF32<> >("utf32le.json", false);
297 TestEncodedOutputStream<UTF32LE<>, UTF32<> >("utf32lebom.json",true);
298 TestEncodedOutputStream<UTF32BE<>, UTF32<> >("utf32be.json", false);
299 TestEncodedOutputStream<UTF32BE<>, UTF32<> >("utf32bebom.json",true);
300}
301
303 TestAutoUTFOutputStream(kUTF8, false, "utf8.json");
304 TestAutoUTFOutputStream(kUTF8, true, "utf8bom.json");
305 TestAutoUTFOutputStream(kUTF16LE, false, "utf16le.json");
306 TestAutoUTFOutputStream(kUTF16LE, true, "utf16lebom.json");
307 TestAutoUTFOutputStream(kUTF16BE, false, "utf16be.json");
308 TestAutoUTFOutputStream(kUTF16BE, true, "utf16bebom.json");
309 TestAutoUTFOutputStream(kUTF32LE, false, "utf32le.json");
310 TestAutoUTFOutputStream(kUTF32LE, true, "utf32lebom.json");
311 TestAutoUTFOutputStream(kUTF32BE, false, "utf32be.json");
312 TestAutoUTFOutputStream(kUTF32BE, true, "utf32bebom.json");
313}
Input stream wrapper with dynamically bound encoding and automatic encoding detection.
size_t Tell() const
bool HasBOM() const
UTFType GetType() const
Output stream wrapper with dynamically bound encoding and automatic encoding detection.
Input byte stream wrapper with a statically bound encoding.
size_t Tell() const
Output byte stream wrapper with statically bound encoding.
bool CompareFile(const char *filename, const char *expectedFilename)
bool CompareBufferFile(const char *actualBuffer, size_t actualLength, const char *expectedFilename)
void TestAutoUTFOutputStream(UTFType type, bool putBOM, const char *expectedFilename)
void TestEncodedOutputStream(const char *expectedFilename, bool putBOM)
virtual void TearDown()
static FILE * Open(const char *filename)
void TestAutoUTFInputStream(const char *filename, bool expectHasBOM)
static char * ReadFile(const char *filename, bool appendPath, size_t *outLength)
void TestEncodedInputStream(const char *filename)
File byte stream for input using fread().
Wrapper of C file stream for output using fwrite().
UTFType
Runtime-specified UTF encoding type of a stream.
Definition encodings.h:603
@ kUTF32BE
UTF-32 big endian.
Definition encodings.h:608
@ kUTF16BE
UTF-16 big endian.
Definition encodings.h:606
@ kUTF8
UTF-8.
Definition encodings.h:604
@ kUTF32LE
UTF-32 little endian.
Definition encodings.h:607
@ kUTF16LE
UTF-16 little endian.
Definition encodings.h:605
os_t os
#define TEST_F(test_fixture, test_name)
Definition gtest.h:2304
#define EXPECT_EQ(val1, val2)
Definition gtest.h:1954
#define EXPECT_TRUE(condition)
Definition gtest.h:1895
#define ASSERT_TRUE(condition)
Definition gtest.h:1901
#define EXPECT_FALSE(condition)
Definition gtest.h:1898
main RapidJSON namespace
Dynamically select encoding according to stream's runtime-specified UTF encoding type.
Definition encodings.h:615
Represents an in-memory output byte stream.
const Ch * GetBuffer() const
size_t GetSize() const
Read-only string stream.
Definition stream.h:154
Represents an in-memory input byte stream.
Encoding conversion.
Definition encodings.h:658
UTF-16 encoding.
Definition encodings.h:269
UTF-32 encoding.
Definition encodings.h:418
UTF-8 encoding.
Definition encodings.h:96
FILE * TempFile(char *filename)
Definition unittest.h:80
CK_RV ret
char * s