| from json.tests import PyTest, CTest | |
| # Fri Dec 30 18:57:26 2005 | |
| 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 | |
| '["Illegal backslash escape: \\\'"]', | |
| # 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://code.google.com/p/simplejson/issues/detail?id=3 | |
| u'["A\u001FZ control characters in string"]', | |
| ] | |
| SKIPS = { | |
| 1: "why not have a string payload?", | |
| 18: "spec doesn't specify any nesting limitations", | |
| } | |
| class TestFail(object): | |
| 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 |