| """Unit tests for numbers.py.""" |
| |
| import math |
| import operator |
| import unittest |
| from numbers import Complex, Real, Rational, Integral |
| |
| class TestNumbers(unittest.TestCase): |
| def test_int(self): |
| self.assertTrue(issubclass(int, Integral)) |
| self.assertTrue(issubclass(int, Complex)) |
| |
| self.assertEqual(7, int(7).real) |
| self.assertEqual(0, int(7).imag) |
| self.assertEqual(7, int(7).conjugate()) |
| self.assertEqual(-7, int(-7).conjugate()) |
| self.assertEqual(7, int(7).numerator) |
| self.assertEqual(1, int(7).denominator) |
| |
| def test_float(self): |
| self.assertFalse(issubclass(float, Rational)) |
| self.assertTrue(issubclass(float, Real)) |
| |
| self.assertEqual(7.3, float(7.3).real) |
| self.assertEqual(0, float(7.3).imag) |
| self.assertEqual(7.3, float(7.3).conjugate()) |
| self.assertEqual(-7.3, float(-7.3).conjugate()) |
| |
| def test_complex(self): |
| self.assertFalse(issubclass(complex, Real)) |
| self.assertTrue(issubclass(complex, Complex)) |
| |
| c1, c2 = complex(3, 2), complex(4,1) |
| # XXX: This is not ideal, but see the comment in math_trunc(). |
| self.assertRaises(TypeError, math.trunc, c1) |
| self.assertRaises(TypeError, operator.mod, c1, c2) |
| self.assertRaises(TypeError, divmod, c1, c2) |
| self.assertRaises(TypeError, operator.floordiv, c1, c2) |
| self.assertRaises(TypeError, float, c1) |
| self.assertRaises(TypeError, int, c1) |
| |
| |
| if __name__ == "__main__": |
| unittest.main() |