forked from Rust-related/RustPython
Update test_complex.py from CPython v3.12.0
This commit is contained in:
56
Lib/test/test_complex.py
vendored
56
Lib/test/test_complex.py
vendored
@@ -109,6 +109,8 @@ class ComplexTest(unittest.TestCase):
|
||||
complex(random(), random()))
|
||||
|
||||
self.assertAlmostEqual(complex.__truediv__(2+0j, 1+1j), 1-1j)
|
||||
self.assertRaises(TypeError, operator.truediv, 1j, None)
|
||||
self.assertRaises(TypeError, operator.truediv, None, 1j)
|
||||
|
||||
for denom_real, denom_imag in [(0, NAN), (NAN, 0), (NAN, NAN)]:
|
||||
z = complex(0, 0) / complex(denom_real, denom_imag)
|
||||
@@ -140,6 +142,7 @@ class ComplexTest(unittest.TestCase):
|
||||
def test_richcompare(self):
|
||||
self.assertIs(complex.__eq__(1+1j, 1<<10000), False)
|
||||
self.assertIs(complex.__lt__(1+1j, None), NotImplemented)
|
||||
self.assertIs(complex.__eq__(1+1j, None), NotImplemented)
|
||||
self.assertIs(complex.__eq__(1+1j, 1+1j), True)
|
||||
self.assertIs(complex.__eq__(1+1j, 2+2j), False)
|
||||
self.assertIs(complex.__ne__(1+1j, 1+1j), False)
|
||||
@@ -162,6 +165,7 @@ class ComplexTest(unittest.TestCase):
|
||||
self.assertIs(operator.eq(1+1j, 2+2j), False)
|
||||
self.assertIs(operator.ne(1+1j, 1+1j), False)
|
||||
self.assertIs(operator.ne(1+1j, 2+2j), True)
|
||||
self.assertIs(operator.eq(1+1j, 2.0), False)
|
||||
|
||||
# TODO: RUSTPYTHON
|
||||
@unittest.expectedFailure
|
||||
@@ -182,6 +186,27 @@ class ComplexTest(unittest.TestCase):
|
||||
check(2 ** pow, range(1, 101), lambda delta: False, float(i))
|
||||
check(2 ** 53, range(-100, 0), lambda delta: True)
|
||||
|
||||
def test_add(self):
|
||||
self.assertEqual(1j + int(+1), complex(+1, 1))
|
||||
self.assertEqual(1j + int(-1), complex(-1, 1))
|
||||
self.assertRaises(OverflowError, operator.add, 1j, 10**1000)
|
||||
self.assertRaises(TypeError, operator.add, 1j, None)
|
||||
self.assertRaises(TypeError, operator.add, None, 1j)
|
||||
|
||||
def test_sub(self):
|
||||
self.assertEqual(1j - int(+1), complex(-1, 1))
|
||||
self.assertEqual(1j - int(-1), complex(1, 1))
|
||||
self.assertRaises(OverflowError, operator.sub, 1j, 10**1000)
|
||||
self.assertRaises(TypeError, operator.sub, 1j, None)
|
||||
self.assertRaises(TypeError, operator.sub, None, 1j)
|
||||
|
||||
def test_mul(self):
|
||||
self.assertEqual(1j * int(20), complex(0, 20))
|
||||
self.assertEqual(1j * int(-1), complex(0, -1))
|
||||
self.assertRaises(OverflowError, operator.mul, 1j, 10**1000)
|
||||
self.assertRaises(TypeError, operator.mul, 1j, None)
|
||||
self.assertRaises(TypeError, operator.mul, None, 1j)
|
||||
|
||||
def test_mod(self):
|
||||
# % is no longer supported on complex numbers
|
||||
with self.assertRaises(TypeError):
|
||||
@@ -214,11 +239,18 @@ class ComplexTest(unittest.TestCase):
|
||||
def test_pow(self):
|
||||
self.assertAlmostEqual(pow(1+1j, 0+0j), 1.0)
|
||||
self.assertAlmostEqual(pow(0+0j, 2+0j), 0.0)
|
||||
self.assertEqual(pow(0+0j, 2000+0j), 0.0)
|
||||
self.assertEqual(pow(0, 0+0j), 1.0)
|
||||
self.assertEqual(pow(-1, 0+0j), 1.0)
|
||||
self.assertRaises(ZeroDivisionError, pow, 0+0j, 1j)
|
||||
self.assertRaises(ZeroDivisionError, pow, 0+0j, -1000)
|
||||
self.assertAlmostEqual(pow(1j, -1), 1/1j)
|
||||
self.assertAlmostEqual(pow(1j, 200), 1)
|
||||
self.assertRaises(ValueError, pow, 1+1j, 1+1j, 1+1j)
|
||||
self.assertRaises(OverflowError, pow, 1e200+1j, 1e200+1j)
|
||||
self.assertRaises(TypeError, pow, 1j, None)
|
||||
self.assertRaises(TypeError, pow, None, 1j)
|
||||
self.assertAlmostEqual(pow(1j, 0.5), 0.7071067811865476+0.7071067811865475j)
|
||||
|
||||
a = 3.33+4.43j
|
||||
self.assertEqual(a ** 0j, 1)
|
||||
@@ -303,6 +335,7 @@ class ComplexTest(unittest.TestCase):
|
||||
for i in range(100):
|
||||
self.assertTrue(complex(random() + 1e-6, random() + 1e-6))
|
||||
self.assertTrue(not complex(0.0, 0.0))
|
||||
self.assertTrue(1j)
|
||||
|
||||
def test_conjugate(self):
|
||||
self.assertClose(complex(5.3, 9.8).conjugate(), 5.3-9.8j)
|
||||
@@ -318,6 +351,8 @@ class ComplexTest(unittest.TestCase):
|
||||
self.assertRaises(TypeError, complex, {})
|
||||
self.assertRaises(TypeError, complex, NS(1.5))
|
||||
self.assertRaises(TypeError, complex, NS(1))
|
||||
self.assertRaises(TypeError, complex, object())
|
||||
self.assertRaises(TypeError, complex, NS(4.25+0.5j), object())
|
||||
|
||||
self.assertAlmostEqual(complex("1+10j"), 1+10j)
|
||||
self.assertAlmostEqual(complex(10), 10+0j)
|
||||
@@ -363,6 +398,8 @@ class ComplexTest(unittest.TestCase):
|
||||
self.assertAlmostEqual(complex('1e-500'), 0.0 + 0.0j)
|
||||
self.assertAlmostEqual(complex('-1e-500j'), 0.0 - 0.0j)
|
||||
self.assertAlmostEqual(complex('-1e-500+1e-500j'), -0.0 + 0.0j)
|
||||
self.assertEqual(complex('1-1j'), 1.0 - 1j)
|
||||
self.assertEqual(complex('1J'), 1j)
|
||||
|
||||
class complex2(complex): pass
|
||||
self.assertAlmostEqual(complex(complex2(1+1j)), 1+1j)
|
||||
@@ -533,8 +570,12 @@ class ComplexTest(unittest.TestCase):
|
||||
self.assertFloatsAreIdentical(z.real, x)
|
||||
self.assertFloatsAreIdentical(z.imag, y)
|
||||
|
||||
# TODO: RUSTPYTHON
|
||||
@unittest.expectedFailure
|
||||
def test_constructor_negative_nans_from_string(self):
|
||||
self.assertEqual(copysign(1., complex("-nan").real), -1.)
|
||||
self.assertEqual(copysign(1., complex("-nanj").imag), -1.)
|
||||
self.assertEqual(copysign(1., complex("-nan-nanj").real), -1.)
|
||||
self.assertEqual(copysign(1., complex("-nan-nanj").imag), -1.)
|
||||
|
||||
def test_underscores(self):
|
||||
# check underscores
|
||||
for lit in VALID_UNDERSCORE_LITERALS:
|
||||
@@ -553,6 +594,8 @@ class ComplexTest(unittest.TestCase):
|
||||
x /= 3.0 # now check against floating point
|
||||
self.assertEqual(hash(x), hash(complex(x, 0.)))
|
||||
|
||||
self.assertNotEqual(hash(2000005 - 1j), -1)
|
||||
|
||||
def test_abs(self):
|
||||
nums = [complex(x/3., y/7.) for x in range(-9,9) for y in range(-9,9)]
|
||||
for num in nums:
|
||||
@@ -575,6 +618,7 @@ class ComplexTest(unittest.TestCase):
|
||||
test(complex(NAN, 1), "(nan+1j)")
|
||||
test(complex(1, NAN), "(1+nanj)")
|
||||
test(complex(NAN, NAN), "(nan+nanj)")
|
||||
test(complex(-NAN, -NAN), "(nan+nanj)")
|
||||
|
||||
test(complex(0, INF), "infj")
|
||||
test(complex(0, -INF), "-infj")
|
||||
@@ -601,6 +645,14 @@ class ComplexTest(unittest.TestCase):
|
||||
test(complex(-0., 0.), "(-0+0j)")
|
||||
test(complex(-0., -0.), "(-0-0j)")
|
||||
|
||||
def test_pos(self):
|
||||
class ComplexSubclass(complex):
|
||||
pass
|
||||
|
||||
self.assertEqual(+(1+6j), 1+6j)
|
||||
self.assertEqual(+ComplexSubclass(1, 6), 1+6j)
|
||||
self.assertIs(type(+ComplexSubclass(1, 6)), complex)
|
||||
|
||||
def test_neg(self):
|
||||
self.assertEqual(-(1+6j), -1-6j)
|
||||
|
||||
|
||||
Reference in New Issue
Block a user