blob: 074c1489f9f193a96fcc8d3b1657dd7848eeac4b [file] [log] [blame]
Tim Peterse2a60002001-09-04 06:17:36 +00001from __future__ import division
2# When true division is the default, get rid of this and add it to
3# test_long.py instead. In the meantime, it's too obscure to try to
4# trick just part of test_long into using future division.
5
Barry Warsaw04f357c2002-07-23 19:04:11 +00006from test.test_support import TestFailed, verify, verbose
Tim Peterse2a60002001-09-04 06:17:36 +00007
8def test_true_division():
9 if verbose:
10 print "long true division"
11 huge = 1L << 40000
12 mhuge = -huge
13 verify(huge / huge == 1.0)
14 verify(mhuge / mhuge == 1.0)
15 verify(huge / mhuge == -1.0)
16 verify(mhuge / huge == -1.0)
17 verify(1 / huge == 0.0)
18 verify(1L / huge == 0.0)
19 verify(1 / mhuge == 0.0)
Tim Petersbc1c7a02001-09-04 06:33:00 +000020 verify(1L / mhuge == 0.0)
Tim Peterse2a60002001-09-04 06:17:36 +000021 verify((666 * huge + (huge >> 1)) / huge == 666.5)
22 verify((666 * mhuge + (mhuge >> 1)) / mhuge == 666.5)
23 verify((666 * huge + (huge >> 1)) / mhuge == -666.5)
24 verify((666 * mhuge + (mhuge >> 1)) / huge == -666.5)
25 verify(huge / (huge << 1) == 0.5)
Tim Petersbc1c7a02001-09-04 06:33:00 +000026 verify((1000000 * huge) / huge == 1000000)
Tim Peterse2a60002001-09-04 06:17:36 +000027
28 namespace = {'huge': huge, 'mhuge': mhuge}
Tim Petersbc1c7a02001-09-04 06:33:00 +000029
Tim Peterse2a60002001-09-04 06:17:36 +000030 for overflow in ["float(huge)", "float(mhuge)",
31 "huge / 1", "huge / 2L", "huge / -1", "huge / -2L",
32 "mhuge / 100", "mhuge / 100L"]:
33 try:
34 eval(overflow, namespace)
35 except OverflowError:
36 pass
37 else:
38 raise TestFailed("expected OverflowError from %r" % overflow)
39
Tim Peters4bd810a2001-09-06 22:03:36 +000040 for underflow in ["1 / huge", "2L / huge", "-1 / huge", "-2L / huge",
41 "100 / mhuge", "100L / mhuge"]:
42 result = eval(underflow, namespace)
43 if result != 0.0:
Tim Peters9652de92001-09-07 00:47:00 +000044 raise TestFailed("expected underflow to 0 from %r" % underflow)
Tim Peters4bd810a2001-09-06 22:03:36 +000045
Tim Petersbc1c7a02001-09-04 06:33:00 +000046 for zero in ["huge / 0", "huge / 0L",
47 "mhuge / 0", "mhuge / 0L"]:
48 try:
49 eval(zero, namespace)
50 except ZeroDivisionError:
51 pass
52 else:
53 raise TestFailed("expected ZeroDivisionError from %r" % zero)
54
Tim Peterse2a60002001-09-04 06:17:36 +000055test_true_division()