mirror of
				https://github.com/RetroDECK/ES-DE.git
				synced 2025-04-10 19:15:13 +00:00 
			
		
		
		
	
		
			
	
	
		
			144 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
		
		
			
		
	
	
			144 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
|   | // Tencent is pleased to support the open source community by making RapidJSON available.
 | ||
|  | // 
 | ||
|  | // Copyright (C) 2015 THL A29 Limited, a Tencent company, and Milo Yip.
 | ||
|  | //
 | ||
|  | // Licensed under the MIT License (the "License"); you may not use this file except
 | ||
|  | // in compliance with the License. You may obtain a copy of the License at
 | ||
|  | //
 | ||
|  | // http://opensource.org/licenses/MIT
 | ||
|  | //
 | ||
|  | // Unless required by applicable law or agreed to in writing, software distributed 
 | ||
|  | // under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR 
 | ||
|  | // CONDITIONS OF ANY KIND, either express or implied. See the License for the 
 | ||
|  | // specific language governing permissions and limitations under the License.
 | ||
|  | 
 | ||
|  | #include "unittest.h"
 | ||
|  | 
 | ||
|  | #include "rapidjson/document.h"
 | ||
|  | 
 | ||
|  | using namespace rapidjson; | ||
|  | 
 | ||
|  | static char* ReadFile(const char* filename, size_t& length) { | ||
|  |     const char *paths[] = { | ||
|  |         "jsonchecker", | ||
|  |         "bin/jsonchecker", | ||
|  |         "../bin/jsonchecker", | ||
|  |         "../../bin/jsonchecker", | ||
|  |         "../../../bin/jsonchecker" | ||
|  |     }; | ||
|  |     char buffer[1024]; | ||
|  |     FILE *fp = 0; | ||
|  |     for (size_t i = 0; i < sizeof(paths) / sizeof(paths[0]); i++) { | ||
|  |         sprintf(buffer, "%s/%s", paths[i], filename); | ||
|  |         fp = fopen(buffer, "rb"); | ||
|  |         if (fp) | ||
|  |             break; | ||
|  |     } | ||
|  | 
 | ||
|  |     if (!fp) | ||
|  |         return 0; | ||
|  | 
 | ||
|  |     fseek(fp, 0, SEEK_END); | ||
|  |     length = static_cast<size_t>(ftell(fp)); | ||
|  |     fseek(fp, 0, SEEK_SET); | ||
|  |     char* json = static_cast<char*>(malloc(length + 1)); | ||
|  |     size_t readLength = fread(json, 1, length, fp); | ||
|  |     json[readLength] = '\0'; | ||
|  |     fclose(fp); | ||
|  |     return json; | ||
|  | } | ||
|  | 
 | ||
|  | struct NoOpHandler { | ||
|  |     bool Null() { return true; } | ||
|  |     bool Bool(bool) { return true; } | ||
|  |     bool Int(int) { return true; } | ||
|  |     bool Uint(unsigned) { return true; } | ||
|  |     bool Int64(int64_t) { return true; } | ||
|  |     bool Uint64(uint64_t) { return true; } | ||
|  |     bool Double(double) { return true; } | ||
|  |     bool RawNumber(const char*, SizeType, bool) { return true; } | ||
|  |     bool String(const char*, SizeType, bool) { return true; } | ||
|  |     bool StartObject() { return true; } | ||
|  |     bool Key(const char*, SizeType, bool) { return true; } | ||
|  |     bool EndObject(SizeType) { return true; } | ||
|  |     bool StartArray() { return true; } | ||
|  |     bool EndArray(SizeType) { return true; } | ||
|  | }; | ||
|  | 
 | ||
|  | 
 | ||
|  | TEST(JsonChecker, Reader) { | ||
|  |     char filename[256]; | ||
|  | 
 | ||
|  |     // jsonchecker/failXX.json
 | ||
|  |     for (int i = 1; i <= 33; i++) { | ||
|  |         if (i == 1) // fail1.json is valid in rapidjson, which has no limitation on type of root element (RFC 7159).
 | ||
|  |             continue; | ||
|  |         if (i == 18)    // fail18.json is valid in rapidjson, which has no limitation on depth of nesting.
 | ||
|  |             continue; | ||
|  | 
 | ||
|  |         sprintf(filename, "fail%d.json", i); | ||
|  |         size_t length; | ||
|  |         char* json = ReadFile(filename, length); | ||
|  |         if (!json) { | ||
|  |             printf("jsonchecker file %s not found", filename); | ||
|  |             ADD_FAILURE(); | ||
|  |             continue; | ||
|  |         } | ||
|  | 
 | ||
|  |         // Test stack-based parsing.
 | ||
|  |         GenericDocument<UTF8<>, CrtAllocator> document; // Use Crt allocator to check exception-safety (no memory leak)
 | ||
|  |         document.Parse(json); | ||
|  |         EXPECT_TRUE(document.HasParseError()) << filename; | ||
|  | 
 | ||
|  |         // Test iterative parsing.
 | ||
|  |         document.Parse<kParseIterativeFlag>(json); | ||
|  |         EXPECT_TRUE(document.HasParseError()) << filename; | ||
|  | 
 | ||
|  |         // Test iterative pull-parsing.
 | ||
|  |         Reader reader; | ||
|  |         StringStream ss(json); | ||
|  |         NoOpHandler h; | ||
|  |         reader.IterativeParseInit(); | ||
|  |         while (!reader.IterativeParseComplete()) { | ||
|  |             if (!reader.IterativeParseNext<kParseDefaultFlags>(ss, h)) | ||
|  |                 break; | ||
|  |         } | ||
|  |         EXPECT_TRUE(reader.HasParseError()) << filename; | ||
|  |          | ||
|  |         free(json); | ||
|  |     } | ||
|  | 
 | ||
|  |     // passX.json
 | ||
|  |     for (int i = 1; i <= 3; i++) { | ||
|  |         sprintf(filename, "pass%d.json", i); | ||
|  |         size_t length; | ||
|  |         char* json = ReadFile(filename, length); | ||
|  |         if (!json) { | ||
|  |             printf("jsonchecker file %s not found", filename); | ||
|  |             continue; | ||
|  |         } | ||
|  | 
 | ||
|  |         // Test stack-based parsing.
 | ||
|  |         GenericDocument<UTF8<>, CrtAllocator> document; // Use Crt allocator to check exception-safety (no memory leak)
 | ||
|  |         document.Parse(json); | ||
|  |         EXPECT_FALSE(document.HasParseError()) << filename; | ||
|  | 
 | ||
|  |         // Test iterative parsing.
 | ||
|  |         document.Parse<kParseIterativeFlag>(json); | ||
|  |         EXPECT_FALSE(document.HasParseError()) << filename; | ||
|  |          | ||
|  |         // Test iterative pull-parsing.
 | ||
|  |         Reader reader; | ||
|  |         StringStream ss(json); | ||
|  |         NoOpHandler h; | ||
|  |         reader.IterativeParseInit(); | ||
|  |         while (!reader.IterativeParseComplete()) { | ||
|  |             if (!reader.IterativeParseNext<kParseDefaultFlags>(ss, h)) | ||
|  |                 break; | ||
|  |         } | ||
|  |         EXPECT_FALSE(reader.HasParseError()) << filename; | ||
|  | 
 | ||
|  |         free(json); | ||
|  |     } | ||
|  | } |