diff options
author | Raymond Hettinger <python@rcn.com> | 2008-07-10 14:34:57 (GMT) |
---|---|---|
committer | Raymond Hettinger <python@rcn.com> | 2008-07-10 14:34:57 (GMT) |
commit | b01713e7dc26721e821a2b3ed8a67600d68940fb (patch) | |
tree | 719287beb7ed98a8e8aecfe2e647314325569d3f /Lib | |
parent | 3cd1e42dca01308a9f5897ba2efc2aab0bebb661 (diff) | |
download | cpython-b01713e7dc26721e821a2b3ed8a67600d68940fb.zip cpython-b01713e7dc26721e821a2b3ed8a67600d68940fb.tar.gz cpython-b01713e7dc26721e821a2b3ed8a67600d68940fb.tar.bz2 |
Issue 3285: Fractions from_float() and from_decimal() accept Integral arguments.
Diffstat (limited to 'Lib')
-rwxr-xr-x | Lib/fractions.py | 8 | ||||
-rw-r--r-- | Lib/test/test_fractions.py | 12 |
2 files changed, 10 insertions, 10 deletions
diff --git a/Lib/fractions.py b/Lib/fractions.py index 6bde774..4adb184 100755 --- a/Lib/fractions.py +++ b/Lib/fractions.py @@ -110,7 +110,9 @@ class Fraction(Rational): Beware that Fraction.from_float(0.3) != Fraction(3, 10). """ - if not isinstance(f, float): + if isinstance(f, numbers.Integral): + f = float(f) + elif not isinstance(f, float): raise TypeError("%s.from_float() only takes floats, not %r (%s)" % (cls.__name__, f, type(f).__name__)) if math.isnan(f) or math.isinf(f): @@ -121,7 +123,9 @@ class Fraction(Rational): def from_decimal(cls, dec): """Converts a finite Decimal instance to a rational number, exactly.""" from decimal import Decimal - if not isinstance(dec, Decimal): + if isinstance(dec, numbers.Integral): + dec = Decimal(int(dec)) + elif not isinstance(dec, Decimal): raise TypeError( "%s.from_decimal() only takes Decimals, not %r (%s)" % (cls.__name__, dec, type(dec).__name__)) diff --git a/Lib/test/test_fractions.py b/Lib/test/test_fractions.py index d61294f..979fef7 100644 --- a/Lib/test/test_fractions.py +++ b/Lib/test/test_fractions.py @@ -137,10 +137,8 @@ class FractionTest(unittest.TestCase): self.assertNotEquals(F(4, 2), r) def testFromFloat(self): - self.assertRaisesMessage( - TypeError, "Fraction.from_float() only takes floats, not 3 (int)", - F.from_float, 3) - + self.assertRaises(TypeError, F.from_float, 3+4j) + self.assertEquals((10, 1), _components(F.from_float(10))) self.assertEquals((0, 1), _components(F.from_float(-0.0))) self.assertEquals((10, 1), _components(F.from_float(10.0))) self.assertEquals((-5, 2), _components(F.from_float(-2.5))) @@ -164,10 +162,8 @@ class FractionTest(unittest.TestCase): F.from_float, nan) def testFromDecimal(self): - self.assertRaisesMessage( - TypeError, - "Fraction.from_decimal() only takes Decimals, not 3 (int)", - F.from_decimal, 3) + self.assertRaises(TypeError, F.from_decimal, 3+4j) + self.assertEquals(F(10, 1), F.from_decimal(10)) self.assertEquals(F(0), F.from_decimal(Decimal("-0"))) self.assertEquals(F(5, 10), F.from_decimal(Decimal("0.5"))) self.assertEquals(F(5, 1000), F.from_decimal(Decimal("5e-3"))) |