mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 13:52:43 +00:00 
			
		
		
		
	 23c72c6728
			
		
	
	
		23c72c6728
		
	
	
	
	
		
			
			Parse JSON floating point literals properly, No longer throwing a SyntaxError when the decimal portion of the number exceeds the capacity of u32. Added tests to AK/TestJSON and LibJS/builtins/JSON/JSON.parse
		
			
				
	
	
		
			52 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| test("basic functionality", () => {
 | |
|     expect(JSON.parse).toHaveLength(2);
 | |
| 
 | |
|     const properties = [
 | |
|         ["5", 5],
 | |
|         ["null", null],
 | |
|         ["true", true],
 | |
|         ["false", false],
 | |
|         ['"test"', "test"],
 | |
|         ['[1,2,"foo"]', [1, 2, "foo"]],
 | |
|         ['{"foo":1,"bar":"baz"}', { foo: 1, bar: "baz" }],
 | |
|     ];
 | |
| 
 | |
|     properties.forEach(testCase => {
 | |
|         expect(JSON.parse(testCase[0])).toEqual(testCase[1]);
 | |
|     });
 | |
| });
 | |
| 
 | |
| test("syntax errors", () => {
 | |
|     [
 | |
|         undefined,
 | |
|         NaN,
 | |
|         -NaN,
 | |
|         Infinity,
 | |
|         -Infinity,
 | |
|         '{ "foo" }',
 | |
|         '{ foo: "bar" }',
 | |
|         "[1,2,3,]",
 | |
|         "[1,2,3, ]",
 | |
|         '{ "foo": "bar",}',
 | |
|         '{ "foo": "bar", }',
 | |
|     ].forEach(test => {
 | |
|         expect(() => {
 | |
|             JSON.parse(test);
 | |
|         }).toThrow(SyntaxError);
 | |
|     });
 | |
| });
 | |
| 
 | |
| test("negative zero", () => {
 | |
|     ["-0", " \n-0", "-0  \t", "\n\t -0\n   ", "-0.0"].forEach(testCase => {
 | |
|         expect(JSON.parse(testCase)).toEqual(-0.0);
 | |
|     });
 | |
| 
 | |
|     expect(JSON.parse(-0)).toEqual(0);
 | |
| });
 | |
| 
 | |
| // The underlying parser resolves decimal numbers by storing the decimal portion in an integer
 | |
| // This test handles a regression where the decimal portion was only using a u32 vs. u64
 | |
| // and would fail to parse.
 | |
| test("long decimal parse", () => {
 | |
|     expect(JSON.parse("1644452550.6489999294281")).toEqual(1644452550.6489999294281);
 | |
| });
 |