+++ /dev/null
-import math\r
-from json.tests import PyTest, CTest\r
-\r
-\r
-class TestFloat(object):\r
- def test_floats(self):\r
- for num in [1617161771.7650001, math.pi, math.pi**100,\r
- math.pi**-100, 3.1]:\r
- self.assertEqual(float(self.dumps(num)), num)\r
- self.assertEqual(self.loads(self.dumps(num)), num)\r
- self.assertEqual(self.loads(unicode(self.dumps(num))), num)\r
-\r
- def test_ints(self):\r
- for num in [1, 1L, 1<<32, 1<<64]:\r
- self.assertEqual(self.dumps(num), str(num))\r
- self.assertEqual(int(self.dumps(num)), num)\r
- self.assertEqual(self.loads(self.dumps(num)), num)\r
- self.assertEqual(self.loads(unicode(self.dumps(num))), num)\r
-\r
- def test_out_of_range(self):\r
- self.assertEqual(self.loads('[23456789012E666]'), [float('inf')])\r
- self.assertEqual(self.loads('[-23456789012E666]'), [float('-inf')])\r
-\r
- def test_allow_nan(self):\r
- for val in (float('inf'), float('-inf'), float('nan')):\r
- out = self.dumps([val])\r
- if val == val: # inf\r
- self.assertEqual(self.loads(out), [val])\r
- else: # nan\r
- res = self.loads(out)\r
- self.assertEqual(len(res), 1)\r
- self.assertNotEqual(res[0], res[0])\r
- self.assertRaises(ValueError, self.dumps, [val], allow_nan=False)\r
-\r
-\r
-class TestPyFloat(TestFloat, PyTest): pass\r
-class TestCFloat(TestFloat, CTest): pass\r