|  | """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() |