mirror of
				https://github.com/python/cpython.git
				synced 2025-10-31 21:51:50 +00:00 
			
		
		
		
	#18273: move the tests in Lib/test/json_tests to Lib/test/test_json and make them discoverable by unittest. Patch by Zachary Ware.
This commit is contained in:
		
							parent
							
								
									0d2d2b8393
								
							
						
					
					
						commit
						66f2ea042a
					
				
					 21 changed files with 25 additions and 44 deletions
				
			
		
							
								
								
									
										105
									
								
								Lib/test/test_json/test_fail.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										105
									
								
								Lib/test/test_json/test_fail.py
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,105 @@ | |||
| from test.test_json import PyTest, CTest | ||||
| 
 | ||||
| # 2007-10-05 | ||||
| JSONDOCS = [ | ||||
|     # http://json.org/JSON_checker/test/fail1.json | ||||
|     '"A JSON payload should be an object or array, not a string."', | ||||
|     # http://json.org/JSON_checker/test/fail2.json | ||||
|     '["Unclosed array"', | ||||
|     # http://json.org/JSON_checker/test/fail3.json | ||||
|     '{unquoted_key: "keys must be quoted"}', | ||||
|     # http://json.org/JSON_checker/test/fail4.json | ||||
|     '["extra comma",]', | ||||
|     # http://json.org/JSON_checker/test/fail5.json | ||||
|     '["double extra comma",,]', | ||||
|     # http://json.org/JSON_checker/test/fail6.json | ||||
|     '[   , "<-- missing value"]', | ||||
|     # http://json.org/JSON_checker/test/fail7.json | ||||
|     '["Comma after the close"],', | ||||
|     # http://json.org/JSON_checker/test/fail8.json | ||||
|     '["Extra close"]]', | ||||
|     # http://json.org/JSON_checker/test/fail9.json | ||||
|     '{"Extra comma": true,}', | ||||
|     # http://json.org/JSON_checker/test/fail10.json | ||||
|     '{"Extra value after close": true} "misplaced quoted value"', | ||||
|     # http://json.org/JSON_checker/test/fail11.json | ||||
|     '{"Illegal expression": 1 + 2}', | ||||
|     # http://json.org/JSON_checker/test/fail12.json | ||||
|     '{"Illegal invocation": alert()}', | ||||
|     # http://json.org/JSON_checker/test/fail13.json | ||||
|     '{"Numbers cannot have leading zeroes": 013}', | ||||
|     # http://json.org/JSON_checker/test/fail14.json | ||||
|     '{"Numbers cannot be hex": 0x14}', | ||||
|     # http://json.org/JSON_checker/test/fail15.json | ||||
|     '["Illegal backslash escape: \\x15"]', | ||||
|     # http://json.org/JSON_checker/test/fail16.json | ||||
|     '[\\naked]', | ||||
|     # http://json.org/JSON_checker/test/fail17.json | ||||
|     '["Illegal backslash escape: \\017"]', | ||||
|     # http://json.org/JSON_checker/test/fail18.json | ||||
|     '[[[[[[[[[[[[[[[[[[[["Too deep"]]]]]]]]]]]]]]]]]]]]', | ||||
|     # http://json.org/JSON_checker/test/fail19.json | ||||
|     '{"Missing colon" null}', | ||||
|     # http://json.org/JSON_checker/test/fail20.json | ||||
|     '{"Double colon":: null}', | ||||
|     # http://json.org/JSON_checker/test/fail21.json | ||||
|     '{"Comma instead of colon", null}', | ||||
|     # http://json.org/JSON_checker/test/fail22.json | ||||
|     '["Colon instead of comma": false]', | ||||
|     # http://json.org/JSON_checker/test/fail23.json | ||||
|     '["Bad value", truth]', | ||||
|     # http://json.org/JSON_checker/test/fail24.json | ||||
|     "['single quote']", | ||||
|     # http://json.org/JSON_checker/test/fail25.json | ||||
|     '["\ttab\tcharacter\tin\tstring\t"]', | ||||
|     # http://json.org/JSON_checker/test/fail26.json | ||||
|     '["tab\\   character\\   in\\  string\\  "]', | ||||
|     # http://json.org/JSON_checker/test/fail27.json | ||||
|     '["line\nbreak"]', | ||||
|     # http://json.org/JSON_checker/test/fail28.json | ||||
|     '["line\\\nbreak"]', | ||||
|     # http://json.org/JSON_checker/test/fail29.json | ||||
|     '[0e]', | ||||
|     # http://json.org/JSON_checker/test/fail30.json | ||||
|     '[0e+]', | ||||
|     # http://json.org/JSON_checker/test/fail31.json | ||||
|     '[0e+-1]', | ||||
|     # http://json.org/JSON_checker/test/fail32.json | ||||
|     '{"Comma instead if closing brace": true,', | ||||
|     # http://json.org/JSON_checker/test/fail33.json | ||||
|     '["mismatch"}', | ||||
|     # http://code.google.com/p/simplejson/issues/detail?id=3 | ||||
|     '["A\u001FZ control characters in string"]', | ||||
| ] | ||||
| 
 | ||||
| SKIPS = { | ||||
|     1: "why not have a string payload?", | ||||
|     18: "spec doesn't specify any nesting limitations", | ||||
| } | ||||
| 
 | ||||
| class TestFail: | ||||
|     def test_failures(self): | ||||
|         for idx, doc in enumerate(JSONDOCS): | ||||
|             idx = idx + 1 | ||||
|             if idx in SKIPS: | ||||
|                 self.loads(doc) | ||||
|                 continue | ||||
|             try: | ||||
|                 self.loads(doc) | ||||
|             except ValueError: | ||||
|                 pass | ||||
|             else: | ||||
|                 self.fail("Expected failure for fail{0}.json: {1!r}".format(idx, doc)) | ||||
| 
 | ||||
|     def test_non_string_keys_dict(self): | ||||
|         data = {'a' : 1, (1, 2) : 2} | ||||
| 
 | ||||
|         #This is for c encoder | ||||
|         self.assertRaises(TypeError, self.dumps, data) | ||||
| 
 | ||||
|         #This is for python encoder | ||||
|         self.assertRaises(TypeError, self.dumps, data, indent=True) | ||||
| 
 | ||||
| 
 | ||||
| class TestPyFail(TestFail, PyTest): pass | ||||
| class TestCFail(TestFail, CTest): pass | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Ezio Melotti
						Ezio Melotti