diff options
author | Mark Dickinson <dickinsm@gmail.com> | 2016-08-22 09:56:06 (GMT) |
---|---|---|
committer | Mark Dickinson <dickinsm@gmail.com> | 2016-08-22 09:56:06 (GMT) |
commit | 0add84b9b855c10e9c6434286c2b1157a754a39f (patch) | |
tree | b17328d4cb3258611a6617e0a14ad4c98ff03431 /Lib | |
parent | dc65c685249758c576f3fd915f7f913cdc0a0d2b (diff) | |
parent | 844796530a21f2a8689f2b9e01035d4a64a95275 (diff) | |
download | cpython-0add84b9b855c10e9c6434286c2b1157a754a39f.zip cpython-0add84b9b855c10e9c6434286c2b1157a754a39f.tar.gz cpython-0add84b9b855c10e9c6434286c2b1157a754a39f.tar.bz2 |
Issue #27539: Merge from 3.5.
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/fractions.py | 6 | ||||
-rw-r--r-- | Lib/test/test_fractions.py | 13 |
2 files changed, 18 insertions, 1 deletions
diff --git a/Lib/fractions.py b/Lib/fractions.py index 64d746b..a712052 100644 --- a/Lib/fractions.py +++ b/Lib/fractions.py @@ -460,10 +460,14 @@ class Fraction(numbers.Rational): return Fraction(a._numerator ** power, a._denominator ** power, _normalize=False) - else: + elif a._numerator >= 0: return Fraction(a._denominator ** -power, a._numerator ** -power, _normalize=False) + else: + return Fraction((-a._denominator) ** -power, + (-a._numerator) ** -power, + _normalize=False) else: # A fractional power will generally produce an # irrational number. diff --git a/Lib/test/test_fractions.py b/Lib/test/test_fractions.py index 73d2dd3..664c735 100644 --- a/Lib/test/test_fractions.py +++ b/Lib/test/test_fractions.py @@ -356,6 +356,19 @@ class FractionTest(unittest.TestCase): z = pow(F(-1), F(1, 2)) self.assertAlmostEqual(z.real, 0) self.assertEqual(z.imag, 1) + # Regression test for #27539. + p = F(-1, 2) ** 0 + self.assertEqual(p, F(1, 1)) + self.assertEqual(p.numerator, 1) + self.assertEqual(p.denominator, 1) + p = F(-1, 2) ** -1 + self.assertEqual(p, F(-2, 1)) + self.assertEqual(p.numerator, -2) + self.assertEqual(p.denominator, 1) + p = F(-1, 2) ** -2 + self.assertEqual(p, F(4, 1)) + self.assertEqual(p.numerator, 4) + self.assertEqual(p.denominator, 1) def testMixedArithmetic(self): self.assertTypedEquals(F(11, 10), F(1, 10) + 1) |