diff -r 000000000000 -r ae805ac0140d python-2.5.2/win32/Lib/test/test_float.py --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/python-2.5.2/win32/Lib/test/test_float.py Fri Apr 03 17:19:34 2009 +0100 @@ -0,0 +1,123 @@ + +import unittest, struct +from test import test_support + +class FormatFunctionsTestCase(unittest.TestCase): + + def setUp(self): + self.save_formats = {'double':float.__getformat__('double'), + 'float':float.__getformat__('float')} + + def tearDown(self): + float.__setformat__('double', self.save_formats['double']) + float.__setformat__('float', self.save_formats['float']) + + def test_getformat(self): + self.assert_(float.__getformat__('double') in + ['unknown', 'IEEE, big-endian', 'IEEE, little-endian']) + self.assert_(float.__getformat__('float') in + ['unknown', 'IEEE, big-endian', 'IEEE, little-endian']) + self.assertRaises(ValueError, float.__getformat__, 'chicken') + self.assertRaises(TypeError, float.__getformat__, 1) + + def test_setformat(self): + for t in 'double', 'float': + float.__setformat__(t, 'unknown') + if self.save_formats[t] == 'IEEE, big-endian': + self.assertRaises(ValueError, float.__setformat__, + t, 'IEEE, little-endian') + elif self.save_formats[t] == 'IEEE, little-endian': + self.assertRaises(ValueError, float.__setformat__, + t, 'IEEE, big-endian') + else: + self.assertRaises(ValueError, float.__setformat__, + t, 'IEEE, big-endian') + self.assertRaises(ValueError, float.__setformat__, + t, 'IEEE, little-endian') + self.assertRaises(ValueError, float.__setformat__, + t, 'chicken') + self.assertRaises(ValueError, float.__setformat__, + 'chicken', 'unknown') + +BE_DOUBLE_INF = '\x7f\xf0\x00\x00\x00\x00\x00\x00' +LE_DOUBLE_INF = ''.join(reversed(BE_DOUBLE_INF)) +BE_DOUBLE_NAN = '\x7f\xf8\x00\x00\x00\x00\x00\x00' +LE_DOUBLE_NAN = ''.join(reversed(BE_DOUBLE_NAN)) + +BE_FLOAT_INF = '\x7f\x80\x00\x00' +LE_FLOAT_INF = ''.join(reversed(BE_FLOAT_INF)) +BE_FLOAT_NAN = '\x7f\xc0\x00\x00' +LE_FLOAT_NAN = ''.join(reversed(BE_FLOAT_NAN)) + +# on non-IEEE platforms, attempting to unpack a bit pattern +# representing an infinity or a NaN should raise an exception. + +class UnknownFormatTestCase(unittest.TestCase): + def setUp(self): + self.save_formats = {'double':float.__getformat__('double'), + 'float':float.__getformat__('float')} + float.__setformat__('double', 'unknown') + float.__setformat__('float', 'unknown') + + def tearDown(self): + float.__setformat__('double', self.save_formats['double']) + float.__setformat__('float', self.save_formats['float']) + + def test_double_specials_dont_unpack(self): + for fmt, data in [('>d', BE_DOUBLE_INF), + ('>d', BE_DOUBLE_NAN), + ('f', BE_FLOAT_INF), + ('>f', BE_FLOAT_NAN), + ('d', BE_DOUBLE_INF), + ('>d', BE_DOUBLE_NAN), + ('f', BE_FLOAT_INF), + ('>f', BE_FLOAT_NAN), + ('