cpython/Lib/test/decimaltestdata/tointegralx.decTest

256 lines
12 KiB
Plaintext
Raw Normal View History

Merged revisions 58095-58132,58136-58148,58151-58197 via svnmerge from svn+ssh://pythondev@svn.python.org/python/trunk ........ r58096 | brett.cannon | 2007-09-10 23:38:27 +0200 (Mon, 10 Sep 2007) | 4 lines Fix a possible segfault from recursing too deep to get the repr of a list. Closes issue #1096. ........ r58097 | bill.janssen | 2007-09-10 23:51:02 +0200 (Mon, 10 Sep 2007) | 33 lines More work on SSL support. * Much expanded test suite: All protocols tested against all other protocols. All protocols tested with all certificate options. Tests for bad key and bad cert. Test of STARTTLS functionality. Test of RAND_* functions. * Fixes for threading/malloc bug. * Issue 1065 fixed: sslsocket class renamed to SSLSocket. sslerror class renamed to SSLError. Function "wrap_socket" now used to wrap an existing socket. * Issue 1583946 finally fixed: Support for subjectAltName added. Subject name now returned as proper DN list of RDNs. * SSLError exported from socket as "sslerror". * RAND_* functions properly exported from ssl.py. * Documentation improved: Example of how to create a self-signed certificate. Better indexing. ........ r58098 | guido.van.rossum | 2007-09-11 00:02:25 +0200 (Tue, 11 Sep 2007) | 9 lines Patch # 1140 (my code, approved by Effbot). Make sure the type of the return value of re.sub(x, y, z) is the type of y+x (i.e. unicode if either is unicode, str if they are both str) even if there are no substitutions or if x==z (which triggered various special cases in join_list()). Could be backported to 2.5; no need to port to 3.0. ........ r58099 | guido.van.rossum | 2007-09-11 00:36:02 +0200 (Tue, 11 Sep 2007) | 8 lines Patch # 1026 by Benjamin Aranguren (with Alex Martelli): Backport abc.py and isinstance/issubclass overloading to 2.6. I had to backport test_typechecks.py myself, and make one small change to abc.py to avoid duplicate work when x.__class__ and type(x) are the same. ........ r58100 | bill.janssen | 2007-09-11 01:41:24 +0200 (Tue, 11 Sep 2007) | 3 lines A better way of finding an open port to test with. ........ r58101 | bill.janssen | 2007-09-11 03:09:19 +0200 (Tue, 11 Sep 2007) | 4 lines Make sure test_ssl doesn't reference the ssl module in a context where it can't be imported. ........ r58102 | bill.janssen | 2007-09-11 04:42:07 +0200 (Tue, 11 Sep 2007) | 3 lines Fix some documentation bugs. ........ r58103 | nick.coghlan | 2007-09-11 16:01:18 +0200 (Tue, 11 Sep 2007) | 1 line Always use the -E flag when spawning subprocesses in test_cmd_line (Issue 1056) ........ r58106 | thomas.heller | 2007-09-11 21:17:48 +0200 (Tue, 11 Sep 2007) | 3 lines Disable some tests that fail on the 'ppc Debian unstable' buildbot to find out if they cause the segfault on the 'alpha Debian' machine. ........ r58108 | brett.cannon | 2007-09-11 23:02:28 +0200 (Tue, 11 Sep 2007) | 6 lines Generators had their throw() method allowing string exceptions. That's a no-no. Fixes issue #1147. Need to fix 2.5 to raise a proper warning if a string exception is passed in. ........ r58112 | georg.brandl | 2007-09-12 20:03:51 +0200 (Wed, 12 Sep 2007) | 3 lines New documentation page for the bdb module. (This doesn't need to be merged to Py3k.) ........ r58114 | georg.brandl | 2007-09-12 20:05:57 +0200 (Wed, 12 Sep 2007) | 2 lines Bug #1152: use non-deprecated name in example. ........ r58115 | georg.brandl | 2007-09-12 20:08:33 +0200 (Wed, 12 Sep 2007) | 2 lines Fix #1122: wrong return type documented for various _Size() functions. ........ r58117 | georg.brandl | 2007-09-12 20:10:56 +0200 (Wed, 12 Sep 2007) | 2 lines Fix #1139: PyFile_Encoding really is PyFile_SetEncoding. ........ r58119 | georg.brandl | 2007-09-12 20:29:18 +0200 (Wed, 12 Sep 2007) | 2 lines bug #1154: release memory allocated by "es" PyArg_ParseTuple format specifier. ........ r58121 | bill.janssen | 2007-09-12 20:52:05 +0200 (Wed, 12 Sep 2007) | 1 line root certificate for https://svn.python.org/, used in test_ssl ........ r58122 | georg.brandl | 2007-09-12 21:00:07 +0200 (Wed, 12 Sep 2007) | 3 lines Bug #1153: repr.repr() now doesn't require set and dictionary items to be orderable to properly represent them. ........ r58125 | georg.brandl | 2007-09-12 21:29:28 +0200 (Wed, 12 Sep 2007) | 4 lines #1120: put explicit version in the shebang lines of pydoc, idle and smtpd.py scripts that are installed by setup.py. That way, they work when only "make altinstall" is used. ........ r58139 | mark.summerfield | 2007-09-13 16:54:30 +0200 (Thu, 13 Sep 2007) | 9 lines Replaced variable o with obj in operator.rst because o is easy to confuse. Added a note about Python 3's collections.Mapping etc., above section that describes isMappingType() etc. Added xrefs between os, os.path, fileinput, and open(). ........ r58143 | facundo.batista | 2007-09-13 20:13:15 +0200 (Thu, 13 Sep 2007) | 7 lines Merged the decimal-branch (revisions 54886 to 58140). Decimal is now fully updated to the latests Decimal Specification (v1.66) and the latests test cases (v2.56). Thanks to Mark Dickinson for all his help during this process. ........ r58145 | facundo.batista | 2007-09-13 20:42:09 +0200 (Thu, 13 Sep 2007) | 7 lines Put the parameter watchexp back in (changed watchexp from an int to a bool). Also second argument to watchexp is now converted to Decimal, just as with all the other two-argument operations. Thanks Mark Dickinson. ........ r58147 | andrew.kuchling | 2007-09-14 00:49:34 +0200 (Fri, 14 Sep 2007) | 1 line Add various items ........ r58148 | andrew.kuchling | 2007-09-14 00:50:10 +0200 (Fri, 14 Sep 2007) | 1 line Make target unique ........ r58154 | facundo.batista | 2007-09-14 20:58:34 +0200 (Fri, 14 Sep 2007) | 3 lines Included the new functions, and new descriptions. ........ r58155 | thomas.heller | 2007-09-14 21:40:35 +0200 (Fri, 14 Sep 2007) | 2 lines ctypes.util.find_library uses dump(1) instead of objdump(1) on Solaris. Fixes issue #1777530; will backport to release25-maint. ........ r58159 | facundo.batista | 2007-09-14 23:29:52 +0200 (Fri, 14 Sep 2007) | 3 lines Some additions (examples and a bit on the tutorial). ........ r58160 | georg.brandl | 2007-09-15 18:53:36 +0200 (Sat, 15 Sep 2007) | 2 lines Remove bdb from the "undocumented modules" list. ........ r58164 | bill.janssen | 2007-09-17 00:06:00 +0200 (Mon, 17 Sep 2007) | 15 lines Add support for asyncore server-side SSL support. This requires adding the 'makefile' method to ssl.SSLSocket, and importing the requisite fakefile class from socket.py, and making the appropriate changes to it to make it use the SSL connection. Added sample HTTPS server to test_ssl.py, and test that uses it. Change SSL tests to use https://svn.python.org/, instead of www.sf.net and pop.gmail.com. Added utility function to ssl module, get_server_certificate, to wrap up the several things to be done to pull a certificate from a remote server. ........ r58173 | bill.janssen | 2007-09-17 01:16:46 +0200 (Mon, 17 Sep 2007) | 1 line use binary mode when reading files for testAsyncore to make Windows happy ........ r58175 | raymond.hettinger | 2007-09-17 02:55:00 +0200 (Mon, 17 Sep 2007) | 7 lines Sync-up named tuples with the latest version of the ASPN recipe. Allows optional commas in the field-name spec (help when named tuples are used in conjuction with sql queries). Adds the __fields__ attribute for introspection and to support conversion to dictionary form. Adds a __replace__() method similar to str.replace() but using a named field as a target. Clean-up spelling and presentation in doc-strings. ........ r58176 | brett.cannon | 2007-09-17 05:28:34 +0200 (Mon, 17 Sep 2007) | 5 lines Add a bunch of GIL release/acquire points in tp_print implementations and for PyObject_Print(). Closes issue #1164. ........ r58177 | sean.reifschneider | 2007-09-17 07:45:04 +0200 (Mon, 17 Sep 2007) | 2 lines issue1597011: Fix for bz2 module corner-case error due to error checking bug. ........ r58180 | facundo.batista | 2007-09-17 18:26:50 +0200 (Mon, 17 Sep 2007) | 3 lines Decimal is updated, :) ........ r58181 | facundo.batista | 2007-09-17 19:30:13 +0200 (Mon, 17 Sep 2007) | 5 lines The methods always return Decimal classes, even if they're executed through a subclass (thanks Mark Dickinson). Added a bit of testing for this. ........ r58183 | sean.reifschneider | 2007-09-17 22:53:21 +0200 (Mon, 17 Sep 2007) | 2 lines issue1082: Fixing platform and system for Vista. ........ r58185 | andrew.kuchling | 2007-09-18 03:36:16 +0200 (Tue, 18 Sep 2007) | 1 line Add item; sort properly ........ r58186 | raymond.hettinger | 2007-09-18 05:33:19 +0200 (Tue, 18 Sep 2007) | 1 line Handle corner cased on 0-tuples and 1-tuples. Add verbose option so people can see how it works. ........ r58192 | georg.brandl | 2007-09-18 09:24:40 +0200 (Tue, 18 Sep 2007) | 2 lines A bit of reordering, also show more subheadings in the lang ref index. ........ r58193 | facundo.batista | 2007-09-18 18:53:18 +0200 (Tue, 18 Sep 2007) | 4 lines Speed up of the various division operations (remainder, divide, divideint and divmod). Thanks Mark Dickinson. ........ r58197 | raymond.hettinger | 2007-09-19 00:18:02 +0200 (Wed, 19 Sep 2007) | 1 line Cleanup docs for NamedTuple. ........
2007-09-19 00:06:30 -03:00
------------------------------------------------------------------------
-- tointegralx.decTest -- round decimal to integral value, exact --
-- Copyright (c) IBM Corporation, 2001, 2007. All rights reserved. --
------------------------------------------------------------------------
-- Please see the document "General Decimal Arithmetic Testcases" --
-- at http://www2.hursley.ibm.com/decimal for the description of --
-- these testcases. --
-- --
-- These testcases are experimental ('beta' versions), and they --
-- may contain errors. They are offered on an as-is basis. In --
-- particular, achieving the same results as the tests here is not --
-- a guarantee that an implementation complies with any Standard --
-- or specification. The tests are not exhaustive. --
-- --
-- Please send comments, suggestions, and corrections to the author: --
-- Mike Cowlishaw, IBM Fellow --
-- IBM UK, PO Box 31, Birmingham Road, Warwick CV34 5JL, UK --
-- mfc@uk.ibm.com --
------------------------------------------------------------------------
version: 2.56
-- This set of tests tests the extended specification 'round-to-integral
-- value' operation (from IEEE 854, later modified in 754r).
-- All non-zero results are defined as being those from either copy or
-- quantize, so those are assumed to have been tested.
-- This tests toIntegraExact, which may set Inexact
extended: 1
precision: 9
rounding: half_up
maxExponent: 999
minExponent: -999
intxx001 tointegralx 0 -> 0
intxx002 tointegralx 0.0 -> 0
intxx003 tointegralx 0.1 -> 0 Inexact Rounded
intxx004 tointegralx 0.2 -> 0 Inexact Rounded
intxx005 tointegralx 0.3 -> 0 Inexact Rounded
intxx006 tointegralx 0.4 -> 0 Inexact Rounded
intxx007 tointegralx 0.5 -> 1 Inexact Rounded
intxx008 tointegralx 0.6 -> 1 Inexact Rounded
intxx009 tointegralx 0.7 -> 1 Inexact Rounded
intxx010 tointegralx 0.8 -> 1 Inexact Rounded
intxx011 tointegralx 0.9 -> 1 Inexact Rounded
intxx012 tointegralx 1 -> 1
intxx013 tointegralx 1.0 -> 1 Rounded
intxx014 tointegralx 1.1 -> 1 Inexact Rounded
intxx015 tointegralx 1.2 -> 1 Inexact Rounded
intxx016 tointegralx 1.3 -> 1 Inexact Rounded
intxx017 tointegralx 1.4 -> 1 Inexact Rounded
intxx018 tointegralx 1.5 -> 2 Inexact Rounded
intxx019 tointegralx 1.6 -> 2 Inexact Rounded
intxx020 tointegralx 1.7 -> 2 Inexact Rounded
intxx021 tointegralx 1.8 -> 2 Inexact Rounded
intxx022 tointegralx 1.9 -> 2 Inexact Rounded
-- negatives
intxx031 tointegralx -0 -> -0
intxx032 tointegralx -0.0 -> -0
intxx033 tointegralx -0.1 -> -0 Inexact Rounded
intxx034 tointegralx -0.2 -> -0 Inexact Rounded
intxx035 tointegralx -0.3 -> -0 Inexact Rounded
intxx036 tointegralx -0.4 -> -0 Inexact Rounded
intxx037 tointegralx -0.5 -> -1 Inexact Rounded
intxx038 tointegralx -0.6 -> -1 Inexact Rounded
intxx039 tointegralx -0.7 -> -1 Inexact Rounded
intxx040 tointegralx -0.8 -> -1 Inexact Rounded
intxx041 tointegralx -0.9 -> -1 Inexact Rounded
intxx042 tointegralx -1 -> -1
intxx043 tointegralx -1.0 -> -1 Rounded
intxx044 tointegralx -1.1 -> -1 Inexact Rounded
intxx045 tointegralx -1.2 -> -1 Inexact Rounded
intxx046 tointegralx -1.3 -> -1 Inexact Rounded
intxx047 tointegralx -1.4 -> -1 Inexact Rounded
intxx048 tointegralx -1.5 -> -2 Inexact Rounded
intxx049 tointegralx -1.6 -> -2 Inexact Rounded
intxx050 tointegralx -1.7 -> -2 Inexact Rounded
intxx051 tointegralx -1.8 -> -2 Inexact Rounded
intxx052 tointegralx -1.9 -> -2 Inexact Rounded
-- next two would be NaN using quantize(x, 0)
intxx053 tointegralx 10E+30 -> 1.0E+31
intxx054 tointegralx -10E+30 -> -1.0E+31
-- numbers around precision
precision: 9
intxx060 tointegralx '56267E-10' -> '0' Inexact Rounded
intxx061 tointegralx '56267E-5' -> '1' Inexact Rounded
intxx062 tointegralx '56267E-2' -> '563' Inexact Rounded
intxx063 tointegralx '56267E-1' -> '5627' Inexact Rounded
intxx065 tointegralx '56267E-0' -> '56267'
intxx066 tointegralx '56267E+0' -> '56267'
intxx067 tointegralx '56267E+1' -> '5.6267E+5'
intxx068 tointegralx '56267E+2' -> '5.6267E+6'
intxx069 tointegralx '56267E+3' -> '5.6267E+7'
intxx070 tointegralx '56267E+4' -> '5.6267E+8'
intxx071 tointegralx '56267E+5' -> '5.6267E+9'
intxx072 tointegralx '56267E+6' -> '5.6267E+10'
intxx073 tointegralx '1.23E+96' -> '1.23E+96'
intxx074 tointegralx '1.23E+384' -> '1.23E+384'
intxx075 tointegralx '1.23E+999' -> '1.23E+999'
intxx080 tointegralx '-56267E-10' -> '-0' Inexact Rounded
intxx081 tointegralx '-56267E-5' -> '-1' Inexact Rounded
intxx082 tointegralx '-56267E-2' -> '-563' Inexact Rounded
intxx083 tointegralx '-56267E-1' -> '-5627' Inexact Rounded
intxx085 tointegralx '-56267E-0' -> '-56267'
intxx086 tointegralx '-56267E+0' -> '-56267'
intxx087 tointegralx '-56267E+1' -> '-5.6267E+5'
intxx088 tointegralx '-56267E+2' -> '-5.6267E+6'
intxx089 tointegralx '-56267E+3' -> '-5.6267E+7'
intxx090 tointegralx '-56267E+4' -> '-5.6267E+8'
intxx091 tointegralx '-56267E+5' -> '-5.6267E+9'
intxx092 tointegralx '-56267E+6' -> '-5.6267E+10'
intxx093 tointegralx '-1.23E+96' -> '-1.23E+96'
intxx094 tointegralx '-1.23E+384' -> '-1.23E+384'
intxx095 tointegralx '-1.23E+999' -> '-1.23E+999'
-- subnormal inputs
intxx100 tointegralx 1E-999 -> 0 Inexact Rounded
intxx101 tointegralx 0.1E-999 -> 0 Inexact Rounded
intxx102 tointegralx 0.01E-999 -> 0 Inexact Rounded
intxx103 tointegralx 0E-999 -> 0
-- specials and zeros
intxx120 tointegralx 'Inf' -> Infinity
intxx121 tointegralx '-Inf' -> -Infinity
intxx122 tointegralx NaN -> NaN
intxx123 tointegralx sNaN -> NaN Invalid_operation
intxx124 tointegralx 0 -> 0
intxx125 tointegralx -0 -> -0
intxx126 tointegralx 0.000 -> 0
intxx127 tointegralx 0.00 -> 0
intxx128 tointegralx 0.0 -> 0
intxx129 tointegralx 0 -> 0
intxx130 tointegralx 0E-3 -> 0
intxx131 tointegralx 0E-2 -> 0
intxx132 tointegralx 0E-1 -> 0
intxx133 tointegralx 0E-0 -> 0
intxx134 tointegralx 0E+1 -> 0E+1
intxx135 tointegralx 0E+2 -> 0E+2
intxx136 tointegralx 0E+3 -> 0E+3
intxx137 tointegralx 0E+4 -> 0E+4
intxx138 tointegralx 0E+5 -> 0E+5
intxx139 tointegralx -0.000 -> -0
intxx140 tointegralx -0.00 -> -0
intxx141 tointegralx -0.0 -> -0
intxx142 tointegralx -0 -> -0
intxx143 tointegralx -0E-3 -> -0
intxx144 tointegralx -0E-2 -> -0
intxx145 tointegralx -0E-1 -> -0
intxx146 tointegralx -0E-0 -> -0
intxx147 tointegralx -0E+1 -> -0E+1
intxx148 tointegralx -0E+2 -> -0E+2
intxx149 tointegralx -0E+3 -> -0E+3
intxx150 tointegralx -0E+4 -> -0E+4
intxx151 tointegralx -0E+5 -> -0E+5
-- propagating NaNs
intxx152 tointegralx NaN808 -> NaN808
intxx153 tointegralx sNaN080 -> NaN80 Invalid_operation
intxx154 tointegralx -NaN808 -> -NaN808
intxx155 tointegralx -sNaN080 -> -NaN80 Invalid_operation
intxx156 tointegralx -NaN -> -NaN
intxx157 tointegralx -sNaN -> -NaN Invalid_operation
-- examples
rounding: half_up
precision: 9
intxx200 tointegralx 2.1 -> 2 Inexact Rounded
intxx201 tointegralx 100 -> 100
intxx202 tointegralx 100.0 -> 100 Rounded
intxx203 tointegralx 101.5 -> 102 Inexact Rounded
intxx204 tointegralx -101.5 -> -102 Inexact Rounded
intxx205 tointegralx 10E+5 -> 1.0E+6
intxx206 tointegralx 7.89E+77 -> 7.89E+77
intxx207 tointegralx -Inf -> -Infinity
-- all rounding modes
rounding: half_even
intxx210 tointegralx 55.5 -> 56 Inexact Rounded
intxx211 tointegralx 56.5 -> 56 Inexact Rounded
intxx212 tointegralx 57.5 -> 58 Inexact Rounded
intxx213 tointegralx -55.5 -> -56 Inexact Rounded
intxx214 tointegralx -56.5 -> -56 Inexact Rounded
intxx215 tointegralx -57.5 -> -58 Inexact Rounded
rounding: half_up
intxx220 tointegralx 55.5 -> 56 Inexact Rounded
intxx221 tointegralx 56.5 -> 57 Inexact Rounded
intxx222 tointegralx 57.5 -> 58 Inexact Rounded
intxx223 tointegralx -55.5 -> -56 Inexact Rounded
intxx224 tointegralx -56.5 -> -57 Inexact Rounded
intxx225 tointegralx -57.5 -> -58 Inexact Rounded
rounding: half_down
intxx230 tointegralx 55.5 -> 55 Inexact Rounded
intxx231 tointegralx 56.5 -> 56 Inexact Rounded
intxx232 tointegralx 57.5 -> 57 Inexact Rounded
intxx233 tointegralx -55.5 -> -55 Inexact Rounded
intxx234 tointegralx -56.5 -> -56 Inexact Rounded
intxx235 tointegralx -57.5 -> -57 Inexact Rounded
rounding: up
intxx240 tointegralx 55.3 -> 56 Inexact Rounded
intxx241 tointegralx 56.3 -> 57 Inexact Rounded
intxx242 tointegralx 57.3 -> 58 Inexact Rounded
intxx243 tointegralx -55.3 -> -56 Inexact Rounded
intxx244 tointegralx -56.3 -> -57 Inexact Rounded
intxx245 tointegralx -57.3 -> -58 Inexact Rounded
rounding: down
intxx250 tointegralx 55.7 -> 55 Inexact Rounded
intxx251 tointegralx 56.7 -> 56 Inexact Rounded
intxx252 tointegralx 57.7 -> 57 Inexact Rounded
intxx253 tointegralx -55.7 -> -55 Inexact Rounded
intxx254 tointegralx -56.7 -> -56 Inexact Rounded
intxx255 tointegralx -57.7 -> -57 Inexact Rounded
rounding: ceiling
intxx260 tointegralx 55.3 -> 56 Inexact Rounded
intxx261 tointegralx 56.3 -> 57 Inexact Rounded
intxx262 tointegralx 57.3 -> 58 Inexact Rounded
intxx263 tointegralx -55.3 -> -55 Inexact Rounded
intxx264 tointegralx -56.3 -> -56 Inexact Rounded
intxx265 tointegralx -57.3 -> -57 Inexact Rounded
rounding: floor
intxx270 tointegralx 55.7 -> 55 Inexact Rounded
intxx271 tointegralx 56.7 -> 56 Inexact Rounded
intxx272 tointegralx 57.7 -> 57 Inexact Rounded
intxx273 tointegralx -55.7 -> -56 Inexact Rounded
intxx274 tointegralx -56.7 -> -57 Inexact Rounded
intxx275 tointegralx -57.7 -> -58 Inexact Rounded
-- Int and uInt32 edge values for testing conversions
precision: 16
intxx300 tointegralx -2147483646 -> -2147483646
intxx301 tointegralx -2147483647 -> -2147483647
intxx302 tointegralx -2147483648 -> -2147483648
intxx303 tointegralx -2147483649 -> -2147483649
intxx304 tointegralx 2147483646 -> 2147483646
intxx305 tointegralx 2147483647 -> 2147483647
intxx306 tointegralx 2147483648 -> 2147483648
intxx307 tointegralx 2147483649 -> 2147483649
intxx308 tointegralx 4294967294 -> 4294967294
intxx309 tointegralx 4294967295 -> 4294967295
intxx310 tointegralx 4294967296 -> 4294967296
intxx311 tointegralx 4294967297 -> 4294967297