summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_fractions.py
diff options
context:
space:
mode:
authorMark Dickinson <dickinsm@gmail.com>2010-04-03 11:18:52 (GMT)
committerMark Dickinson <dickinsm@gmail.com>2010-04-03 11:18:52 (GMT)
commit98127c37167a6735dba576819514c334c89e5b9c (patch)
treed481c794b5c67ae901a9f627bc225452c7701284 /Lib/test/test_fractions.py
parentac256ab2843dfb6c28af0227202df67664ed462e (diff)
downloadcpython-98127c37167a6735dba576819514c334c89e5b9c.zip
cpython-98127c37167a6735dba576819514c334c89e5b9c.tar.gz
cpython-98127c37167a6735dba576819514c334c89e5b9c.tar.bz2
Merged revisions 79629 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r79629 | mark.dickinson | 2010-04-02 23:27:36 +0100 (Fri, 02 Apr 2010) | 2 lines Issue #8294: Allow float and Decimal arguments in Fraction constructor. ........
Diffstat (limited to 'Lib/test/test_fractions.py')
-rw-r--r--Lib/test/test_fractions.py27
1 files changed, 26 insertions, 1 deletions
diff --git a/Lib/test/test_fractions.py b/Lib/test/test_fractions.py
index 5ad0742..dd51f9b 100644
--- a/Lib/test/test_fractions.py
+++ b/Lib/test/test_fractions.py
@@ -12,6 +12,11 @@ from pickle import dumps, loads
F = fractions.Fraction
gcd = fractions.gcd
+# decorator for skipping tests on non-IEEE 754 platforms
+requires_IEEE_754 = unittest.skipUnless(
+ float.__getformat__("double").startswith("IEEE"),
+ "test requires IEEE 754 doubles")
+
class DummyFloat(object):
"""Dummy float class for testing comparisons with Fractions"""
@@ -130,13 +135,33 @@ class FractionTest(unittest.TestCase):
self.assertRaisesMessage(ZeroDivisionError, "Fraction(12, 0)",
F, 12, 0)
- self.assertRaises(TypeError, F, 1.5)
self.assertRaises(TypeError, F, 1.5 + 3j)
self.assertRaises(TypeError, F, "3/2", 3)
self.assertRaises(TypeError, F, 3, 0j)
self.assertRaises(TypeError, F, 3, 1j)
+ @requires_IEEE_754
+ def testInitFromFloat(self):
+ self.assertEquals((5, 2), _components(F(2.5)))
+ self.assertEquals((0, 1), _components(F(-0.0)))
+ self.assertEquals((3602879701896397, 36028797018963968),
+ _components(F(0.1)))
+ self.assertRaises(TypeError, F, float('nan'))
+ self.assertRaises(TypeError, F, float('inf'))
+ self.assertRaises(TypeError, F, float('-inf'))
+
+ def testInitFromDecimal(self):
+ self.assertEquals((11, 10),
+ _components(F(Decimal('1.1'))))
+ self.assertEquals((7, 200),
+ _components(F(Decimal('3.5e-2'))))
+ self.assertEquals((0, 1),
+ _components(F(Decimal('.000e20'))))
+ self.assertRaises(TypeError, F, Decimal('nan'))
+ self.assertRaises(TypeError, F, Decimal('snan'))
+ self.assertRaises(TypeError, F, Decimal('inf'))
+ self.assertRaises(TypeError, F, Decimal('-inf'))
def testFromString(self):
self.assertEquals((5, 1), _components(F("5")))