Uname: Linux web3.us.cloudlogin.co 5.10.226-xeon-hst #2 SMP Fri Sep 13 12:28:44 UTC 2024 x86_64
Software: Apache
PHP version: 8.1.31 [ PHP INFO ] PHP os: Linux
Server Ip: 162.210.96.117
Your Ip: 18.223.117.234
User: edustar (269686) | Group: tty (888)
Safe Mode: OFF
Disable Function:
NONE

name : test_decimal.cpython-310.pyc
o

`b"F�@s�dZddlZddlZddlZddlZddlZddlZddlZddlZddl	Z	ddl
Z
ddlmZm
Z
mZmZmZmZddlmZmZmZmZddlmZddlmZddlZddlZddlZddlZe�d�phdZe�d	�podZd
evpwdevZ devZ!ej"d
kr�ed�eddgd�Z#eddgd�Z$ddl%Z&eddgd�Z'e$ej(d<eddgd�Z)e#ej(d<e#e'e$e)iZ*e&ej(d<e#e#r�e+e#�,�j-�.��nde$e+e$�,�j-�.��iZ/e#e#r�e#j0e#j1e#j2e#j3e#j4e#j5e#j6e#j7e#j8g	nde$e$j0e$j1e$j2e$j3e$j4e$j5e$j6e$j7e$j8g	iZ9dd�Z:e$j;Z;e$j<Z<e$j=Z=e$j>Z>e$j?Z?e$j@Z@e$jAZAe$jBZBe;e<e=e>e?e@eAeBgZCe#e#�r0e#�,���nde$e$�,���iZDdd�ZEdZFeGdk�rJejHdZIneJZIejK�LeI��pUejMZNeNejOeFejOZPejK�QeP�aRdZSeTe#d��rqdndZUe�VeUd�ZWe�XeUd�ZYGdd �d ejZ�Z[Gd!d"�d"e[�Z\Gd#d$�d$e[�Z]Gd%d&�d&ejZ�Z^Gd'd(�d(e^�Z_Gd)d*�d*e^�Z`Gd+d,�d,ejZ�ZaGd-d.�d.ea�ZbGd/d0�d0ea�ZcGd1d2�d2ejZ�ZdGd3d4�d4ed�ZeGd5d6�d6ed�ZfGd7d8�d8ejZ�ZgGd9d:�d:eg�ZhGd;d<�d<eg�Zid=d>�Zjd?d@�ZkGdAdB�dBejZ�ZlGdCdD�dDel�ZmGdEdF�dFel�ZnGdGdH�dHejZ�ZoGdIdJ�dJeo�ZpGdKdL�dLeo�ZqGdMdN�dNejZ�ZrGdOdP�dPer�ZsGdQdR�dRer�ZtGdSdT�dTejZ�ZuGdUdV�dVeu�ZvGdWdX�dXeu�ZwGdYdZ�dZejZ�ZxGd[d\�d\ex�ZyGd]d^�d^ex�ZzGd_d`�d`ejZ�Z{Gdadb�dbe{�Z|Gdcdd�dde{�Z}Gdedf�dfejZ�Z~Gdgdh�dhe~�ZGdidj�dje~�Z�Gdkdl�dlejZ�Z�Gdmdn�dne��Z�Gdodp�dpe��Z�Gdqdr�drejZ�Z�Gdsdt�dte��Z�Gdudv�dve��Z�eYGdwdx�dxejZ��Z�Gdydz�dzejZ�Z�Gd{d|�d|e��Z�Gd}d~�d~e��Z�Gdd��d�ejZ�Z�Gd�d��d�ejZ�Z�Gd�d��d�ejZ�Z�Gd�d��d�ejZ�Z�ee�Ve#d��Gd�d��d�ejZ���Z�ge_�e`�eb�ec�ee�ef�eh�ei�em�en�ep�eq�es�et�ev�ew�ey�ez�e|�e}�e�e��e��e��e��e��e��e��e��e��e��e��e\�e]�Z�e#�s�e�d�dd��Z�ne���de��e���d�e��d�d�d��Z�eGdk�r�ddl�Z�e���d��Z�e�j�d�d�d�d�d��e�j�d�d�d�d�d��e����\Z�Z�e�j��r�e�ddd��dSe��r�e�dde�e�j�d��dSe�ddd��dSdS)�ag
These are the test cases for the Decimal module.

There are two groups of tests, Arithmetic and Behaviour. The former test
the Decimal arithmetic using the tests provided by Mike Cowlishaw. The latter
test the pythonic behaviour according to PEP 327.

Cowlishaw's tests can be downloaded from:

   http://speleotrove.com/decimal/dectest.zip

This test module can be called from command line with one parameter (Arithmetic
or Behaviour) to test each part, or without parameter to test both parts. If
you're working through IDLE, you can import this test module and call test_main()
with the corresponding argument.
�N)�run_unittest�run_doctest�is_resource_enabled�requires_IEEE_754�requires_docstrings�requires_legacy_unicode_capi)�
TestFailed�run_with_locale�cpython_only�darwin_malloc_err_warning)�import_fresh_module)�warnings_helperZCFLAGS�ZCONFIG_ARGSz-fsanitize=memoryz--with-memory-sanitizerz-fsanitize=address�darwinZtest_decimal�decimalZ_decimal)Zfresh)Zblocked�	fractionscs,t||��|�t��fdd��D���dS)Nc3s*�|]}|�vr�|n�|VqdS�N���.0�s��d�expectedr�:/usr/local/python-3.10/lib/python3.10/test/test_decimal.py�	<genexpr>^s�(z!assert_signals.<locals>.<genexpr>)�getattr�
assertTrue�all)�cls�context�attrrrrr�assert_signals\s
"r"cCs2|sdS|jdtt�t|d�d�}|�|�dS)N�	r)�prec�rounding�traps)�Context�ROUND_HALF_EVEN�dict�fromkeys�Signals�
setcontext)�mZDefaultTestContextrrr�initus
�r.Zdecimaltestdata�__main__F�
DecClampedTz.test requires build with -DEXTRA_FUNCTIONALITYztest requires regular buildc@speZdZdZdd�Zdd�Zdd�Zdd	�Zd
d�Zdd
�Z	dd�Z
dd�Zdd�Zdd�Z
dd�Zdd�ZdS)�IBMTestCasesz?Class which tests the Decimal class against the IBM test cases.c
Cs|j��|_|j��|_dg|_tgd��|_|jtkrL|j�d�|j�d�|j�d�|j�d�|j�d�|j�d�|j�d	�|j�d
�|j	|j
|j|j|j
d�|_idd
�dd�dd�dd�dd�dd�dd�dd�dd�dd�d d!�d"d#�d$d%�d&d'�d(d)�d*d+�d,d-�id.d/�d0d1�d2d3�d4d5�d6d7�d8d9�d:d;�d<d=�d>d?�d@dA�dBdC�dDdE�dFdG�dHdI�dJdK�dLdM�dNdO��dPdQdRdS��|_ttttttttdT�|_|jj|jj|jj|jj|jj|jj|jj|jj|jj|jj|jj|jj dU�|_!dV|_"dS)WN�#)Zscbx164Zscbx165Zexpx901Zexpx902Zexpx903Zexpx905Zlnx901Zlnx902Zlnx903Zlnx905Zlogx901Zlogx902Zlogx903Zlogx905Zpowx1183Zpowx1184Zpowx4001Zpowx4002Zpowx4003Zpowx4005Zpowx4008Zpowx4010Zpowx4012Zpowx4014Zpwsx803Zpwsx805Zpowx4302Zpowx4303Zpowx4342Zpowx4343Zpwmx325Zpwmx326)Z	precisionr%ZmaxexponentZminexponent�clamp�and�logical_andZapply�_apply�class�number_classZ
comparesig�compare_signalZcomparetotal�
compare_totalZ
comparetotmag�compare_total_mag�copy�copy_decimalZcopyabs�copy_absZ
copynegate�copy_negate�copysign�	copy_signZ	divideint�
divide_int�invert�logical_invertZiscanonical�is_canonical�isfinite�	is_finiteZ
isinfinite�is_infinite�isnan�is_nanZisnormal�	is_normalZisqnan�is_qnanZissigned�	is_signedZissnan�is_snanZissubnormal�is_subnormalZiszero�is_zeroZmaxmag�max_magZminmag�min_magZ	nextminus�
next_minusZnextplus�	next_plusZ
nexttoward�next_toward�or�
logical_or�reduce�	normalizeZ
remaindernear�remainder_nearZsamequantum�same_quantumZ
squareroot�sqrtZtoeng�
to_eng_stringZ
tointegral�to_integral_value�to_integral_exact�
to_sci_string�logical_xor)ZtointegralxZtosci�xor)ZceilingZdown�floorZ	half_downZ	half_evenZhalf_upZupZ05up)ZclampedZconversion_syntaxZdivision_by_zeroZdivision_impossibleZdivision_undefinedZinexactZinvalid_contextZinvalid_operationZoverflowZroundedZ	subnormalZ	underflow)rErGrHrJrKrLrMrNrOrPr[)#rr'r �readcontext�ignore_list�set�skipped_test_ids�C�add�change_precision�change_rounding_method�change_max_exponent�change_min_exponent�change_clamp�
ChangeDict�NameAdapter�
ROUND_CEILING�
ROUND_DOWN�ROUND_FLOOR�ROUND_HALF_DOWNr(�
ROUND_HALF_UP�ROUND_UP�
ROUND_05UP�RoundingDict�Clamped�InvalidOperation�DivisionByZero�Inexact�Overflow�Rounded�	Subnormal�	Underflow�
ErrorNames�LogicalFunctions��selfrrr�setUp�s�
$���������	�
���
������������������� �!�"
�'�
�
zIBMTestCases.setUpcCsT|jtkr#|jjdkr#|j�d�|j�d�|j�d�|j�|�S|j�||�S)a2Work around the limitations of the 32-bit _decimal version. The
           guaranteed maximum values for prec, Emax etc. are 425000000,
           but higher values usually work, except for rare corner cases.
           In particular, all of the IBM tests pass with maximum values
           of 1070000000.�@�Ti���?i�9�)	rrh�MAX_EMAXrd�_unsafe_setprec�_unsafe_setemax�_unsafe_setemin�create_decimal�Decimal)r��vr rrr�read_unlimited"szIBMTestCases.read_unlimitedcCs�trtj�t|dd��@}|D]4}|�dd��dd�}z|�|�}Wq|jjyB}z|�d|j	j
d|�WYd}~qd}~wwWd�dS1sNwYdS)N�utf-8)�encodingz
r�
zException "z" raised on line )�
skip_expected�unittestZSkipTest�open�replace�	eval_liner�DecimalException�fail�	__class__�__name__)r��file�f�line�t�	exceptionrrr�	eval_file0s&���"�zIBMTestCases.eval_filecCs�|�d�dkr,|dd�dkr,|�d�s,|�d�dd|�d�d�d�d��}n	|�d�d��}|jD]}|�|�dkrDdSq8|sIdSd|vrR|�|�S|�|�S)	Nz -> r��--z  --�->��:)�find�
startswith�split�stripre�eval_directive�
eval_equation)r�r�ignorerrrr�?s (��
�

zIBMTestCases.eval_linecCsjdd�|�d�D�\}}|dkr|j|}nzt|�}Wn	ty%Ynw|j�|dd��}||�dS)Ncss�|]	}|����VqdSr)r��lower�r�xrrrrRs�z.IBMTestCases.eval_directive.<locals>.<genexpr>r�r%cWsdSrr)�argsrrr�<lambda>[sz-IBMTestCases.eval_directive.<locals>.<lambda>)r�rx�int�
ValueErrorro�get)r�r�funct�valuerrrr�Qs�zIBMTestCases.eval_directivecs�ts
t��dkr
dS�j��z:|�d�}|d����}|d}tr*td|dd�|d��}|dd�}|d����}|d}|dd�}Wnt	t
tfyW�jj
�wd	d
�}	|�jvrcdS�j�||�}
|
dkrpdSt�j|
�}g}d}d}
�fd
d�|D��t�jD]}d�jj|<q��D]}d�jj|<q�t|�D]�\}}|�d�ddkr�d|
}
|
r�|d|}q�||}d}|	|�}|
dv�r"t�r�D]J}d�jj|<z
|�j�|��Wn(|y�Yn)t�j�y
}z��d|||f�WYd}~nd}~ww��d||f�d�jj|<qЈj�|�}n��|�j�}|�|�q�|	|�}t�r�|
dv�r�D]H}d�jj|<z||�Wn)|�yUYn)t�j�yt}z��d|||f�WYd}~nd}~ww��d||f�d�jj|<�q=�fdd�t�jD�}|D]F}d�jj|<z||�Wn-|�y�Y�q�t�j�y�}z��dt|�||f�WYd}~�q�d}~ww��d||f��q�|D]	}d�jj|<�q�t�r�td�j�zt||��}|
�jv�rttt |���}Wn't�j�y%}z��d||f�WYd}~n
d}~wtd|����!�}|j"t#d��j"t#d���$||d|d|���$|�d|dt|��dS)Ng�������?r�rzTest � )�endr�r�cSs@|�dd��dd�}|�dd��dd�}|�dd��dd�}|S)Nz''ZSingleQuotez""ZDoubleQuote�'r�")r�)�valrrr�	FixQuotesrsz-IBMTestCases.eval_equation.<locals>.FixQuotesZrescalercsg|]	}�j|���qSr)r�r�r�r�rr�
<listcomp>�sz.IBMTestCases.eval_equation.<locals>.<listcomp>r�)r`r]z Raised %s in %s when %s disabledzDid not raise %s in %scsg|]}|�vr|�qSrr�r�e)�theirexceptionsrrr���zRaised %s in %s; expected %sr�zRaised %s in %szERROR:��keyzIncorrect answer for z -- got zIncorrect flags set in )%�TEST_ALL�randomr �clear_flagsr�r��DEBUG�printr��	TypeError�AttributeError�
IndexErrorrrzrgrpr�rr+r&�	enumerate�count�EXTENDEDERRORTESTr�r�r��append�OrderedSignals�type�strr�r��eval�
getexceptions�sort�repr�assertEqual)r�rZSides�L�idr�Zvalstemp�ans�
exceptionsr�ZfnameZvalsZconglomerate�quoter��ir�r��errorr�Zordered_errors�resultZmyexceptionsr)r�r�rr�^s�

�

�����������
��zIBMTestCases.eval_equationcs�fdd�t�jD�S)Ncsg|]
}�jj|r|�qSr)r �flagsr�r�rrr��sz.IBMTestCases.getexceptions.<locals>.<listcomp>)r+rr�rr�rr��szIBMTestCases.getexceptionscC�2|jtkr|jjdkr|j�|�dS||j_dS�Nr�)rrh�MAX_PRECr r�r$)r�r$rrrrj��zIBMTestCases.change_precisioncC�||j_dSr)r r%)r�r%rrrrk��z#IBMTestCases.change_rounding_methodcCr�r�)rrhr�r r��Emin�r��exprrrrm�r�z IBMTestCases.change_min_exponentcCr�r�)rrhr�r r��Emaxr�rrrrl�r�z IBMTestCases.change_max_exponentcCr�r)r r3)r�r3rrrrn�r�zIBMTestCases.change_clampN)r��
__module__�__qualname__�__doc__r�r�r�r�r�r�r�rjrkrmrlrnrrrrr1�s 
r1c@�eZdZeZdS)�
CIBMTestCasesN�r�r�r�rhrrrrrr���r�c@r�)�PyIBMTestCasesN�r�r�r��Prrrrrr��r�r�c@s�eZdZdZdd�Zdd�Zdd�Zdd	�Zee	e
jed
�dd����Z
d
d�Zdd�Zdd�Zdd�Zedd��Zdd�Zdd�Zdd�ZdS)�ExplicitConstructionTestz6Unit tests for Explicit Construction cases of Decimal.cCs|jj}|�|�|d��dS)N�0�rr�r��r�r�rrr�test_explicit_empty��z,ExplicitConstructionTest.test_explicit_emptycCs|jj}|�t|d�dSr)rr��assertRaisesr�r�rrr�test_explicit_from_Nonesz0ExplicitConstructionTest.test_explicit_from_NonecCs�|jj}|d�}|�t|�d�|d�}|�t|�d�|d�}|�t|�d�|d�}|�t|�d�tdd	�D]%}d
D] }tdd�D]}|d
||}||�}|�t|�t|��qDq=q9dS)N�-�45�{e��	500000123�����-45rr�� ����r�����r�)rr�r�r��range)r�r�r�n�signr�r�rrr�test_explicit_from_ints$���z/ExplicitConstructionTest.test_explicit_from_intcCs�|jj}|jj}|jj}|�t|d��d�|�t|d��d�|�t|d��d�|�t|d��d�|�t|d��d�|�t|d��d	�|�t|d
��d�|�t|d��d
�|�t|d��d�|�t|d��d�dD]}dD]}|�t||d|��d�qvqr|��H}d|j|<|�||d�|�t|ddd�|�||d�|�||d�|�||d�|�||d�|�||d�|�||d�Wd�dS1s�wYdS)Nr�NaNr��45.34Z45e2z4.5E+3�uglyz1.3E4 
z1.3E+4z  -7.89z-7.89z  3.45679  z3.45679z	1_3.3e4_0z1.33E+41Z1_0_0_0�1000)rr�� u z	9.311E+28T�xyz�1234r��yu1 2 3u 1 2 ru  z123z1_2_3)	rr�rz�localcontextr�r�r&r�r�)r�r�rzrZlead�trail�crrr�test_explicit_from_string"s<��
"�z2ExplicitConstructionTest.test_explicit_from_string��categorycCsRddl}|jj}|j��}|�d�}|�t||��d�|�t|�|��d�dS)Nr�9.999999)�	_testcapirr�r'�unicode_legacy_stringr�r�r�)r�rr�r rrrr�test_from_legacy_stringsZs

z1ExplicitConstructionTest.test_from_legacy_stringscCs6|jj}|d�}|�t|�d�|d�}|�t|�d�|d�}|�t|�d�|d�}|�t|�d�|d	�}|�t|�d
�|�t|d�|�t|d�|�t|d
�|�t||d�ddf�|�t|d�|�t|d�|�t|d�|�t|d�|�t|d�|�t|d�|�t|d�|�t|d�dS)N�r�rrr��r�)�rrr�r�r!r�r!���r
�r��	r!r$r!r#r�r$rr$r!����-4.34913534E-17)rr�F�Infinity)r��r!r$r!r#r�)�r,r�)�r,r�r�r,r�)r�r,zwrong!)r�r,r.)r�r,�1)r�rr�)r�)r!r$r!Nr�r�)r�)r!���r!r#r�r�)r�)r!�
r!r#r�r�)r�)r!r$r!�ar�r�)rr�r�r�r�r��r�r�rrrr�test_explicit_from_tuplesfs.z2ExplicitConstructionTest.test_explicit_from_tuplescCs�|jj}|ddgdg�}|�t|�d�|dgd�dg�}|�t|�d�|gd��}|�t|�d�|dgd�df�}|�t|�d�dS)Nrr�r�r'r(r)r&�rr�r�r�r3rrr�test_explicit_from_list�sz0ExplicitConstructionTest.test_explicit_from_listcCs\|jj}|�t|d��d�|�t|d��d�|�|d�|d��|�|d�|d��dS)NrFr�T)rr��assertIs�boolr�r�rrr�test_explicit_from_bool�s
z0ExplicitConstructionTest.test_explicit_from_boolcCs�|jj}|d�}||�}|�t|�d�|d�}||�}|�t|�d�|d�}||�}|�t|�d�|d�}||�}|�t|�d�dS)	Nr�r�r�rrrrr�r5�r�r�rr�rrr�test_explicit_from_Decimal�sz3ExplicitConstructionTest.test_explicit_from_DecimalcCs2|jj}|d�}|�t|�|�|�t|�d�|�|td�����|�|td�����|�|td�����|�t|td���t|d���|�t|td���t|d���|�t|td���t|d���|�t|td	���t|d
���t	d�D]}t
�d�t
�
�d
d}|�|t||���q}dS)N皙�����?�90.1000000000000000055511151231257827021181583404541015625�nan�inf�-infrr+�	-Infinity�-0.0�-0���{�G�z�?�@��?)rr�r�r�r�r�floatrLrHrr��expovariate)r�r��rr�r�rrr�test_explicit_from_float�s2
�
�
�
�
��z1ExplicitConstructionTest.test_explicit_from_floatcCs�|jj}|jj}|jj}t�|j���}d|_|�}|�t|�d�|�	�}|�t|�d�|�
t|j	d�|�	d�}|�||�|�|�	d�|�	d��|d�}|�t|�d�|�	d�}|�t|�d�|�t|�	d��d	�|d
�}|�t|�d�|�	d
�}|�t|�d�|d
�}||�}|�t|�d�|�	|�}|�t|�d�d|_d|j
|<dD]}|�	|�}|�t||��|�t|�|�q�d|_d|j
|<|�
||j	d�d|_|�t|�	d��d�|�t|�	d��d�|�t|�	d��d�|�t|�	d��d�|�
||j	d�|�
t|j	d�|�
t|j	dd�|�
||j	d�|�
||j	d�d|_|�
||j	d �|�
||j	|d ��d!|j
|<|�t|�	d ��d	�|�|j|�d!|j|<|�t|�	|d ���d	�|�|j|�dS)"Nr$r���in�z457E+2Z456789z4.57E+5z3.14
rr&r)z	-4.35E-17r�rz5.00E+8�T)	l����l����l����i�r��l��������z0E-017z0E-17r��-InfrA�NaN123r)r�rr(rZ5678z 1234Z12_34ZNaN12345F)rr�rzr~r<�
getcontextr$r�r�r�r�r��assertIsInstancer&r�
isinstancer�r�r�)r�r�rzr~�ncrZprevdecr�rrr�$test_explicit_context_create_decimal�sv
�






�

z=ExplicitConstructionTest.test_explicit_context_create_decimalcCs\|jj}|j��}|�d�}|�t|�|�|�t|�d�|�|�td���	��|�|�td���
��|�|�td���
��|�t|�td���t|�d���|�t|�td���t|�d���|�t|�td���t|�d���|�t|�td	���t|�d
���d|_td�D]}t
�d
�t
�
�dd}|�|t|�|���q�dS)Nr<z0.1000000000000000055511151231r>r?r@rr+rArBrC�drDrErFrG)rr�r'r�r�r�r�rrHrLrHr$rr�rI)r�r�rWrJr�r�rrr�'test_explicit_context_create_from_float0s2

�����z@ExplicitConstructionTest.test_explicit_context_create_from_floatcCs>|jj}dddd�}|��D]\}}|�t||��|�qdS)Nr/z	0.0000372z-NaN2400)u1u٠.٠٣٧٢e-٣u-nan౨౪౦౦)rr��itemsr�r�)r�r��test_values�inputrrrr�test_unicode_digitsHs��z,ExplicitConstructionTest.test_unicode_digitsN)r�r�r�r�r�r�rrr
rr
�ignore_warnings�DeprecationWarningrr4r6r9r;rrKrXrZr^rrrrr��s&8
	+
Yr�c@r�)�CExplicitConstructionTestNr�rrrrraSr�rac@r�)�PyExplicitConstructionTestNr�rrrrrbUr�rbc@s@eZdZdZdd�Zdd�Zdd�Zdd	�Zd
d�Zdd
�Z	dS)�ImplicitConstructionTestz6Unit tests for Implicit Construction cases of Decimal.cC�|jj}|�ttdt��dS)NzDecimal(5) + None�rr�r�r�r��localsr�rrr�test_implicit_from_None[r�z0ImplicitConstructionTest.test_implicit_from_NonecCs<|jj}|�t|d�d�d�|�|d�d|d��dS)Nrr�Z50l2}rr5r�rrr�test_implicit_from_int_sz/ImplicitConstructionTest.test_implicit_from_intcCrd)NzDecimal(5) + "3"rer�rrr�test_implicit_from_stringgr�z2ImplicitConstructionTest.test_implicit_from_stringcCrd)NzDecimal(5) + 2.2rer�rrr�test_implicit_from_floatkr�z1ImplicitConstructionTest.test_implicit_from_floatcCs(|jj}|�|d�|d�|d��dS)Nrr��2r�r�rrr�test_implicit_from_Decimalos z3ImplicitConstructionTest.test_implicit_from_Decimalcs*|jj}Gdd�d�}|�t|�|d��d�|�t|d�|��d�|�td�d�|�td�d	�|�td
�d�|�td�d
�|�td�d�|�td�d�gd�}|D]9\}��t|��fdd��t|��fdd��|�td|d�d�d�|�td|d�d�d�qYdS)Nc@sLeZdZdd�Zdd�Zdd�Zdd�Zd	d
�Zdd�Zd
d�Z	dd�Z
dS)z,ImplicitConstructionTest.test_rop.<locals>.EcS�dt|�S)Nzdivmod �r��r��otherrrr�
__divmod__xr�z7ImplicitConstructionTest.test_rop.<locals>.E.__divmod__cSst|�dS)Nz rdivmodrnrorrr�__rdivmod__zr�z8ImplicitConstructionTest.test_rop.<locals>.E.__rdivmod__cSrm)Nzlt rnrorrr�__lt__|r�z3ImplicitConstructionTest.test_rop.<locals>.E.__lt__cSrm)Nzgt rnrorrr�__gt__~r�z3ImplicitConstructionTest.test_rop.<locals>.E.__gt__cSrm)Nzle rnrorrr�__le__�r�z3ImplicitConstructionTest.test_rop.<locals>.E.__le__cSrm)Nzge rnrorrr�__ge__�r�z3ImplicitConstructionTest.test_rop.<locals>.E.__ge__cSrm)Nzeq rnrorrr�__eq__�r�z3ImplicitConstructionTest.test_rop.<locals>.E.__eq__cSrm)Nzne rnrorrr�__ne__�r�z3ImplicitConstructionTest.test_rop.<locals>.E.__ne__N)r�r�r�rqrrrsrtrurvrwrxrrrr�Ewsryr1z	divmod 10z
10 rdivmodzDecimal(10) < E()zgt 10zDecimal(10) > E()zlt 10zDecimal(10) <= E()zge 10zDecimal(10) >= E()zle 10zDecimal(10) == E()zeq 10zDecimal(10) != E()zne 10))�+�__add__�__radd__)�-�__sub__�__rsub__)�*�__mul__�__rmul__)�/�__truediv__�__rtruediv__)�%�__mod__�__rmod__)z//�__floordiv__�
__rfloordiv__)z**�__pow__�__rpow__csd�t|�S�Nr�rnro)�loprrr���z3ImplicitConstructionTest.test_rop.<locals>.<lambda>cst|��dSr�rnro)�roprrr��r�zE()zDecimal(10)r��10)rr�r��divmodr��setattr)r�r�ryZoplistZsymr)r�r�r�test_ropss*

�
��z!ImplicitConstructionTest.test_ropN)
r�r�r�r�rgrhrirjrlr�rrrrrcXsrcc@r�)�CImplicitConstructionTestNr�rrrrr��r�r�c@r�)�PyImplicitConstructionTestNr�rrrrr��r�r�c@s:eZdZdZdd�Zdd�Zedd�dd	��Zd
d�ZdS)
�
FormatTestz#Unit tests for the format function.cCsN|jj}gd�}|D]\}}}|�t||�|�|�q
|�t|d�jd�dS)N)�)r��0E-15z0e-15)r�z2.3E-15z2.3e-15)r�z2.30E+2z2.30e+2)r�z2.30000E-15z2.30000e-15)r�z1.23456789123456789e40z1.23456789123456789e+40)r��1.5z1.5e+0)r�z0.15z1.5e-1)r�z0.015z1.5e-2)r�z0.0000000000015z1.5e-12)r�z15.0z1.50e+1)r��-15z-1.5e+1)r�r�z0e+0)r��0E1�0e+1)r��0.0z0e-1)r��0.00�0e-2)�.6er�z0.000000e-9)r�r�z0.000000e+6)r�rz9.999999e+0)r�z	9.9999999z1.000000e+1)r�z-1.23e5z-1.230000e+5)r�z
1.23456789e-3z1.234568e-3)r�r�r�)r�r�r�)r��0E-2r�)r�z0.00E-8z0.0000000000)r�r�r�)r�z3.2E1�32)r�z3.2E2�320)r�z3.20E2r�)r�z3.200E2z320.0)r�z3.2E-6z	0.0000032)�.6fr��0.000000)r�r�r�)r�r�r�)�.0fr�r�)r�r�r�)r��
3.14159265�3)z.1fr��3.1)z.4fr��3.1416)r�r��3.141593)z.7fr��	3.1415926)z.8fr�r�)z.9fr�z3.141592650)�gr�r�)r�r�r�)r�r�r�)�Gr�z0E+1)r�z0E-5z0.00000)r�z0E-6r�)r�z0E-7z0e-7)r�z-0E2z-0e+2)�.0gr�r�)z.0nr�r�)z.1gr�r�)z.2gr�r�)z.5gr�r�)z.7gr�r�)z.8gr�r�)z.9gr�r�)z.10gr�r�)r�r��0%)r�Z0E0r�)r�z0E-1r�)r�r�r�)r�z0E-3z0.0%)r�z0E-4z0.00%)�.3%r��0.000%)r��0E10r�)r�z0E-10r�)r�z2.34z234.000%)r�z1.234567z123.457%)�.0%�1.23z123%)r�rr)r��-NaN123r�)z+gZNaN456z+NaN456)z.3e�Infr+)z.16frRrA)r��-sNaNr�)r�1.00r�)�6�123�   123)z<6r�z123   )z>6r�r�)z^6r�z 123  )z=+6r�z+  123)�#<10rz
NaN#######)r�z-4.3z
-4.3######)z#<+10�0.0130z
+0.0130###)z#< 10r�z
 0.0130###)z@>10rRz
@-Infinity)z#>5rRrA)z?^5r�z?123?)z%^6r�z%123%%)z ^6�-45.6z-45.6 )z/=10r�z
-/////45.6)z/=+10�45.6z
+/////45.6)z/= 10r�z
 /////45.6)z=10r@z
-Infinity)z^16r@z-Infinity)z>10�1.2345z
1.2345)z<10r�z
1.2345)�,Z1234567z	1,234,567)r��123456�123,456)r�Z12345�12,345)r�rz1,234)r�r�r�)r��12r�)r�r/r/)r�r�r�)r�z-1234567z
-1,234,567)r��-123456�-123,456)z7,r�r�)z8,r�� 123,456)�08,r�z	0,123,456)z+08,r�z+123,456)z 08,r�r�)r�r�r�)z+09,r�z
+0,123,456)z07,�1234.56�1,234.56)r�r�r�)z09,r�z	01,234.56)z010,r�z
001,234.56)z011,r��0,001,234.56)z012,r�r�)z08,.1fz1234.5z01,234.5)r��
1.23456789r�)z,%z
123.456789z12,345.6789%)z,er�z
1.23456e+5)z,Er�z
1.23456E+5)za=-7.0z0.12345zaaaa0.1)z	<^+15.20%r?z<<+Infinity%<<<)z>,%ZsNaN1234567zsNaN1234567%)z=10.10%rSz
   NaN123%r�s-020)rr�r��formatr�r��
__format__)r�r�r\�fmtrr�rrr�test_formatting�szFormatTest.test_formattingc	s8�jj�zddlm}Wnty��d�Ynw�fdd�}dA��fdd�	}d	|gd
��dd�}d||g�d
d�}d|gd
��dd�}d|ddd|g�dd�}d�d�|gd
��d�d�d�}��|�d�|�d���|�d�|�d���|�d�|�d���|�d�|�d���|d|�d���|d|�d���|d|�d���|d|�d���|d|d �d!���|d|d �d"���|d|d �d"���|d|d �d#���|d$|d%�d&���|d$|d'�d&���|d$|d(�d)���|d$|d*�d+���|d,|d(�d-���|d,|d*�d-���|d,|d.�d/���|d,|d0�d1���|d,|d2�d1���|d,|d3�d4���|d5|d*�d6���|d5|d.�d6���|d5|d0�d6���|d5|d2�d7���|d5|d3�d8���|d5|d9�d8���|d5|d:�d;���|d5|d<�d=���|�d>�|d?�d@�dS)BNr��CHAR_MAX�locale.CHAR_MAX not availablecs"�jtkrd�dd�|D��S|S)NrcS�g|]}t|��qSr��chrr�rrrr�T�zCFormatTest.test_n_format.<locals>.make_grouping.<locals>.<listcomp>)rrh�join�Zlstr�rr�
make_groupingSs"z/FormatTest.test_n_format.<locals>.make_groupingr	cs,�jtkr
�|��||�S�|�j||d�S)N)�_localeconv)rrhr��r��overrider��r�r�rr�get_fmtVs
z)FormatTest.test_n_format.<locals>.get_fmt�.�r$r$rr���
decimal_point�grouping�
thousands_seprr��&r�r!r�r}s¿r�s´z12.7z12,7z1-2&7i�[z123,456,789Z	123456789z123 456 789l��c}z123456-78-9012-3z.6nz
1.23457e+8z
1,23457e+8z
1&23457e+8rQZ03nrZ04nZ05nZ01234Z06nZ001234�90r�Z07nz012,345Z08nz	0,012,345Z09nZ010nz
00,012,345i@�z1-2345-6z	01-2345-6z0-01-2345-6Z011nZ012nz00-01-2345-6Z013nz
000-01-2345-6�-1.5Z020nu-0´000´000´000´001¿5�Nr	)rr��localer��ImportError�skipTest�decoder�)	r�r�r�r��en_US�fr_FR�ru_RUZcrazyZdotsep_widerr�r�
test_n_formatKsz�
��
��
��zFormatTest.test_n_format�LC_ALL�ps_AFcCsn|jj}t��d}t��d}|dkr|�d�|d��|dkr*|�d�|d��|�t|d�d�d	�dS)
Nr�r�u٫z5inappropriate decimal point separator ({!a} not {!a})u٬z1inappropriate thousands separator ({!a} not {!a})z
100000000.123r	u100٬000٬000٫123)rr�r��
localeconvr�r�r�)r�r�r�r�rrr�&test_wide_char_separator_decimal_point�s���z1FormatTest.test_wide_char_separator_decimal_pointcCsPGdd�d|jj�}|�d�}|�|jj|j�|�d�}|�|jj|j�dS)Nc@�eZdZdd�ZdS)z;FormatTest.test_decimal_from_float_argument_type.<locals>.AcSst|�|_dSr)r��a_type)r�r2rrr�__init__�szDFormatTest.test_decimal_from_float_argument_type.<locals>.A.__init__N�r�r�r�r�rrrr�A��r�g@E@�*)rr��
from_floatr�r�)r�r�r2rrr�%test_decimal_from_float_argument_type�s


z0FormatTest.test_decimal_from_float_argument_typeN)	r�r�r�r�r�r�r	r�rrrrrr��s Y
r�c@r�)�CFormatTestNr�rrrrr�r�rc@r�)�PyFormatTestNr�rrrrr�r�rc@sheZdZdZdd�Zdd�Zdd�Zdd	�Zd
d�Zdd
�Z	dd�Z
dd�Zdd�Zdd�Z
dd�ZdS)�ArithmeticOperatorsTestz:Unit tests for all arithmetic operators, binary and unary.cCs�|jj}|d�}|d�}|�|||d��|�|||d��|d}|�||d��|�t|�t|��d|}|�||d��|�t|�t|��||7}|�||d��|d7}|�||d��dS)N�-11.1�22.2z11.1rz-6.1�16.1�rr�r�r��r�r��d1�d2rrrr�
test_addition��z%ArithmeticOperatorsTest.test_additioncCs�|jj}|d�}|d�}|�|||d��|�|||d��|d}|�||d��|�t|�t|��d|}|�||d��|�t|�t|��||8}|�||d��|d8}|�||d��dS)	Nrrz-33.3z33.3rz-16.1rz-38.3rrrrr�test_subtraction�rz(ArithmeticOperatorsTest.test_subtractioncCs�|jj}|d�}|d�}|�|||d��|�|||d��|d}|�||d��|�t|�t|��d|}|�||d��|�t|�t|��||9}|�||d��|d9}|�||d��dS)N�-5r�r�rz-25z-75rrrrr�test_multiplication�rz+ArithmeticOperatorsTest.test_multiplicationcCs�|jj}|d�}|d�}|�|||d��|�|||d��|d}|�||d��|�t|�t|��d|}|�||d��|�t|�t|��||}|�||d��|d}|�||d��dS)	Nr�2�-2.5z-0.4r!z-1.25z-0.8z-0.625rrrrr�
test_divisionrz%ArithmeticOperatorsTest.test_divisioncCs�|jj}|d�}|d�}|�|||d��|�|||d��|d}|�||d��|�t|�t|��d|}|�||d��|�t|�t|��||}|�||d��|d}|�||d��dS)N�5rr�r!r/�r�rrrrr�test_floor_division7rz+ArithmeticOperatorsTest.test_floor_divisioncCs�|jj}|d�}|d�}|�|||d��|�|||d��|d}|�||d��|�t|�t|��d|}|�||d��|�t|�t|��||C}|�||d��|dC}|�||d	��dS)
NrrZ25r�r!Z625rZ16807Z390625rrrrr�
test_poweringSrz%ArithmeticOperatorsTest.test_poweringcCs�|jj}|d�}|d�}|�|||d��|�|||d��|d}|�||d��|�t|�t|��d|}|�||d��|�t|�t|��||;}|�||d��|d;}|�||d��dS�Nrrr/r!rrrrrr�test_moduleorz#ArithmeticOperatorsTest.test_modulecCs|jj}|d�}|d�}t||�\}}|�||d��|�||d��|�t|�t|��|�t|�t|��t|d�\}}|�||d��|�||d��|�t|�t|��|�t|�t|��td|�\}}|�||d��|�||d��|�t|�t|��|�t|�t|��dSr)rr�r�r�r�)r�r�r	r
�p�qrrr�test_floor_div_module�s$z-ArithmeticOperatorsTest.test_floor_div_modulecCsT|jj}|�|d�
|d��|�|d�|d��|�t|d��t|d���dS)Nr�r)rr�r��absr�rrr�test_unary_operators�s z,ArithmeticOperatorsTest.test_unary_operatorscCs�|jj}|jj}|jj}|d�}|d�}|d�}|d�}||f||f||f||f||ff}||f||f||f||f||f||f||ff}	tjtjtjtjf}
tj	tj
f}||	D](\}}
|
|D]}|||
�}|tj
urndnd}|�||d�||j
||
|��q`qX|��k}d|j|<|D]&\}}
|D]}|||
�}|tj
ur�dnd}|�||d�||j
||
|��q�q�|	D]\}}
|D]}|�|tj	||
�|�|tj
||
�q�q�||	D]\}}
|
D]
}|�||||
�q�q�Wd�dS1s�wYdS)	Nr�sNaNr�rTFz8expected {0!r} for operator.{1}({2!r}, {3!r}); got {4!r}r�)rr�rzr�operator�lt�le�gt�ge�eq�ner7r�r�r&r�)r�r�rzrr	rr�r�Z
qnan_pairsZ
snan_pairsZ	order_opsZequality_opsr�r�opZgotr�ctxrrr�test_nan_comparisons�s\".
���	

���	���"�z,ArithmeticOperatorsTest.test_nan_comparisonscCsH|jj}|d��|d��}|�|d��d�|�|�t|d�jd�dS)Nr�r%�-2)rr�rAr�r�r�r3rrr�test_copy_sign�sz&ArithmeticOperatorsTest.test_copy_signN)r�r�r�r�rr
rrrrrrrr(r*rrrrr�s7rc@r�)�CArithmeticOperatorsTestNr�rrrrr+�r�r+c@r�)�PyArithmeticOperatorsTestNr�rrrrr,�r�r,c	Cs�|jj}|jj}|jj}|jj}|jj}|jj}|jj}|jj}|d�}	|d�}
|	|
}|j	�
�|j��|	|
}|��a}
|�
|
j|�|�||
j|	d�|�
|
j|�|��,}|�
|j|�|�
|j|�|�||j|	|d��|�
|j|�~Wd�n1s�wY|�|
j|�~
Wd�n1s�wY|�||d��|�||d��|�}|�
|j|�||||fD]
}|�|j|�q�dS)Nr�r$rr�0.333333333333333333333333)rr�rzr{r}r�r|rTr�finish1rf�synchro�waitrr�r��divide�compare�assertFalser�)rr�rzr{r}r�r|rTrr	�d3�test1�test2�c2�c3�c1�sigrrr�thfunc1�sF

��
�r;c	Cs�|jj}|jj}|jj}|jj}|jj}|jj}|jj}|jj}|d�}	|d�}
|	|
}|�}d|_	|	|
}
|��q}|�
|j|�|�||j
|d�d�|�
|j|�||��1}|�
|j|�|�|j|�d|j|<|�||j|d�d�|�
|j|�~Wd�n1s�wY|�|j|�|�|j|�~Wd�n1s�wY|j��|j��|�||d��|�|
|d	��|�|j|�|�
|j|�||||fD]
}|�|j|�q�dS)
Nr�r$�Z1e425000000��Tz1e-425000000r-z0.333333333333333333)rr�rzr{r}r�r|rTrr$rr�r��multiplyr3r&r1r/rf�finish2r�)rr�rzr{r}r�r|rTrr	r4r5Zthiscontextr6r7r8r:rrr�thfunc2sN

��

�r@c@�eZdZdZdd�ZdS)�
ThreadingTestz0Unit tests for thread local contexts in Decimal.cCs�|jj}|jtkr|jjs|�d�|j}|j}|j}d|_d|_d|_t�	�|_
t�	�|_t�	�|_tj
t|fd�}tj
t|fd�}|��|��|j��|j��t|jD]
}|�|j|�qZ|��|��||_||_||_dS)Nzcompiled without threading�r����)�targetr�)r�DefaultContextrh�HAVE_THREADSr�r$r�r��	threading�Eventr/r.r?�Threadr;r@�startr0r+r3r�r�)r�rFZ	save_precZ	save_emaxZ	save_eminZth1Zth2r:rrr�test_threadingKs2






zThreadingTest.test_threadingN)r�r�r�r�rLrrrrrBEsrBc@r�)�CThreadingTestNr�rrrrrMrr�rMc@r�)�PyThreadingTestNr�rrrrrNur�rNc@s�eZdZdZdd�Zdd�Zdd�Zdd	�Zd
d�Zdd
�Z	dd�Z
dd�Zdd�Zdd�Z
dd�Zdd�Zdd�Zdd�Zdd�Zd d!�Zd"d#�Zd$d%�Zd&d'�Zd(d)�Zd*S)+�
UsabilityTestz*Unit tests for Usability cases of Decimal.cCs|jj}|d�}|d�}|d�}|�||�|�||�|�||�|�||�|�||�|�||�|�||�|�||�|�|d�|�d|�|�|d�|�|d�|�|d�|�|t��|�|t�t	t
|td���}|dd�}t�
|�|��|�||�dS)Nz23.42r��r�rg�����Y@@rY)rr��
assertGreater�assertGreaterEqual�
assertLess�assertLessEqualr��assertNotEqual�object�list�maprr��shuffler�)r�r��da�db�dcr2�brrr�test_comparison_operators{s0
z'UsabilityTest.test_comparison_operatorscCs�|jj}|d�}|d�}|�|d�|�|d�|�|d�|�|d�|�|d�|�|d�|�d|�|�d|�|�d|�|�d|�|�d|�|�d|�|�d|d��dS)N�0.25�3.0�@��?g�?r<�0.1)rr�rSrTrQrRrUr��r�r�rZr[rrr�test_decimal_float_comparison�s z+UsabilityTest.test_decimal_float_comparisoncCs�|jj}|d�}|d�}|�|d�|�d|�|�|d�|�d|�|�d|�|�|d�|�|d�|�d|�|�|�d�t�|�|�d�t�|�|�d�t�|�|�d�t�dS)Nr_r`y�?y�?y@y@�?)	rr�rUr�r7rs�NotImplementedrurtrdrrr�test_decimal_complex_comparison�sz-UsabilityTest.test_decimal_complex_comparisonc
Cs�|jj}t|jj}|jj}|jj}|jj}trtjnd}tr"tj	nd}tr)tj
nd}|||d�}	||	���||	_|�|d�|dd��|�|dd�|d��|�|dd�|d	t
|���|�|d
t
|��|dd��|�|dd�|d	t
|���|�|d
t
|��|dd��|�|d�|dd
��|�|dd
�|d��d|	_|�|d�d|dd��|�|dd�|d�d�|�|dd�|dt
|���|�|dt
|��|dd��|�|d�|dd��|�|d�|dd��|�|d�|dd��|�|d�|dd��|�||d�j|dd��|�t|dd��|d���|�|d�|dd��|�|dd�|d��Wd�dS1�sFwYdS)N�ɚ;�6e�ilʈ�r�r�rr�l	��Z��mH;5�BrZ1ez-1el��!�0QYrcr1i,r$i�6l�c(	Z9er?l�g�]�{l�����g�]r@r>i����)rr�rZFractionr'rrzrhr��MIN_EMIN�	MIN_ETINYr$rSr�r�rUrTrRrQr�rtr7rfrs)
r��Dr*r'rrz�emax�eminZetinyrrrr� test_decimal_fraction_comparison�sB$�z.UsabilityTest.test_decimal_fraction_comparisoncCsP|jj}|d�}t�|�}|�t|�t|��t�|�}|�t|�t|��dS)Nz43.24)rr�r<r�r��deepcopy)r�r�rrr\rrr�test_copy_and_deepcopy_methods�s

z,UsabilityTest.test_copy_and_deepcopy_methodscs��jj��jj}�fdd�}|�d��|�d��|�d��|�d��|�d���fdd	�d
D�}|��d��d��d
��d��d��d��d��d��d��d��d��d��d��d��d��d�g�|D]}��||�tt|���qlgd�}|D]}t|�}�|�}��||�t|��q�|��A}	�d�}
d|	_||
�}d|	_||
�}d|	_||
�}
��||���||
�d |	_d!d"}
��|�|
��||
��Wd�dS1s�wYdS)#Ncs t|�}|��}��||�|Sr)�hash�__hash__r�)rr2r]r�rr�hashit�sz.UsabilityTest.test_hash_method.<locals>.hashitrPr+rAZnan123�-NaNcs:g|]}tdd�D]}dD]}�|d||��q
q	qS)���r1rr�)r)rr-r	r
�r�rrr�s���z2UsabilityTest.test_hash_method.<locals>.<listcomp>)r������r�!�=�>�?�@�A�B�-1rCr�z-0.000r�z-0E12�10.0z	-23.00000Z1230E100z
-4.5678E50l��z	1.634E100z
90.697E100z
188.83E100z
1652.9E100Z	56531E100)r?rRr�z-.0e1z34.0�2.5z
112390.625z	-0.515625z123456789.1�r1r|�'iLi�)	rr�r�extendr�rtr�rHr$)r�rrvr\r�Ztest_stringsrr�rrr�Zh1Zh2Zh3rr�r�test_hash_method�sd
��"�zUsabilityTest.test_hash_methodcCsz|jj}|�tt|d��|d�}|�t|�t�|��Gdd�d�}Gdd�d||�}|d�}|�t|�t�|��dS)Nrrc@r�)z-UsabilityTest.test_hash_method_nan.<locals>.HcS�dS)Nr�rr�rrrruM�z6UsabilityTest.test_hash_method_nan.<locals>.H.__hash__N)r�r�r�rurrrr�HLr�r�c@seZdZdS)z-UsabilityTest.test_hash_method_nan.<locals>.DN)r�r�r�rrrrrnOsrn)rr�r�r�rtr�rVru)r�r�r�r�rnrrr�test_hash_method_nanGsz"UsabilityTest.test_hash_method_nancCs�|jj}|d�}|d�}d}d}|�t||�|�|�t||�|�|�t||�|�|�t||�|�|�t||�|�|�t||�|�|�t||�|�|�t||�|�dS)N�15.32z28.5r{rM)rr�r7�min�max)r�r�r	r
�l1�l2rrr�test_min_and_max_methodsTsz&UsabilityTest.test_min_and_max_methodscCs(|jj}|�|d��|�|d��dS)Nrz0.372)rr�r3rr�rrr�test_as_nonzerohszUsabilityTest.test_as_nonzerocCs4|jj}|d�}|�t|�d�|�t|�d�dS)Nr�zDecimal('15.32'))rr�r�r�r�r3rrr�test_tostring_methodspsz#UsabilityTest.test_tostring_methodsc
Cs4|jj}|d�}|d�}|�t|�d�|�t|�d�|�t|�d�|�t|�d�gd�}|D]\}}|�t�||��|�q2|�ttj|d��|�ttj|d��|�ttj|d	��|�t	tj|d
��|�t	tj|d��gd�}|D]\}}|�t�
||��|�qz|�ttj
|d��|�ttj
|d��|�ttj
|d	��|�t	tj
|d
��|�t	tj
|d��gd
�}|D]\}}|�t||��|�q�|�tt|d��|�tt|d��|�tt|d	��|�t	t|d
��|�t	t|d��gd�}|D]\}}}	|�tt||�|��|	��qdS)NZ66r�r�r{g�p=
ף.@)	�z123.00rk��3.2r$)�3.54r$)�3.899r$)�-2.3r0�z-11.0i�����r�r�z-0E3r)�89891211712379812736.1l�{�#'s�{MrwrrSr�rR)	r�)r�r!�r�r!�r�r!�r�r%r�r�r�)r�l�{�#'s�{M)r�r�r�r�r�r�r�r�)z-3.5���)rr%)r�r%)�-0.5r)�0.5r)r�r�)r�r�)z3.5r!))�123.456r�z0E+4)r�r0z0E+3)r�r%z1E+2)r�rz1.2E+2)r�rr�)r�r�z123.5)r�r��123.46)r�r$r�)r�r!z123.4560)z123.455r�r�)z123.445r�z123.44)r�r!r)rRi��r)ZsNaN314r$ZNaN314)
rr�r�r�rH�mathrcr�r��
OverflowError�ceil�roundr�)
r�r�r	r
Z
test_pairsrr�Ztest_triplesr	rJrrr�test_tonum_methodsxsF�z UsabilityTest.test_tonum_methodscCsX|jj}dD]#}t||��}|�t�|��t�d|�}|�||�d�r&dnd�qdS)N)r>Znan1234�-nanz-nan2468rGr}g�)	rr�rHrr�rIr@r�r�)r�r�rr�r
rrr�test_nan_to_float�s�zUsabilityTest.test_nan_to_floatcCs,|jj}dD]
}||�}|�tt|�qdS)N)�snanz-snanZsnan1357z	-snan1234)rr�r�r�rH)r�r�rrrrr�test_snan_to_float�s
�z UsabilityTest.test_snan_to_floatcCs||jj}|d�}|�|tt|���|d�}|�|tt|���|d�}|�|tt|���|d�}|�|tt|���dS)Nrr r"r&)rr�r�r�r�r3rrr�test_eval_round_trip�sz"UsabilityTest.test_eval_round_tripcCsD|jj}|d�}|�|��d�|d�}|�|��d�|d�}|�|��d�|d�}|�|��d�|d	�}|�|��d
�|d�}|�|��d�|d
�}|�|��d�|d�}|�|��d�|d�}|�|��d�|d�}|�|��d�|d�}|�|��d�|d�}|�|��d�|d�}|�|��d�dS)Nrrrr r)r&r+)rrr*)r�rrr!rrr$r!r%)r�r!rrr$r!r%)r��rrr�%)r�rr�)r�rr�)rr�r	)rr�r	)r�r��N�r�rr�)r�rr	)rr#r*)r�)rr�rr�r*)r�rr*)rr�r��as_tupler3rrr�
test_as_tuples6zUsabilityTest.test_as_tuplec		Cs|jj}|�t|j|d��|�t|j|d��|�t|j|d��|�t|j|d��tdd�D]M}td�D]F}dD]A}|d	|||f�}|��}|\}}|�|t�|�|t	�|�|t	�|�
|d
�|�t�
||�d�|�||�||�|�q;q7q1dS)Nr?r@r�Zsnan123r�r���)rzr}z%s%dE%drr�)rr�r�r��as_integer_ratior�rrU�tupler�rQr�r��gcd)	r�r�r�Zcoeffr
rZpqrrrrr�test_as_integer_ratio/s8
�
�
�
����z#UsabilityTest.test_as_integer_ratiocCsd|jj}Gdd�d|�}|d�}|d�}||}|�t|�|�|�|�}|�t|�|�t�|�}|�t|�|�|�||�t�|�}|�t|�|�|�||�|d�}||�}|�t|�|�|�||�||�}|�t|�|�|�||�|�|jd�||�}|�t|�|�|�||�d|_||�}|�t|�|�|�||�|�|jd�dS)Nc@seZdZdZdS)z1UsabilityTest.test_subclassing.<locals>.MyDecimalN)r�r�r�rrrrr�	MyDecimalTr�r�r�r��1.0r#)	rr�r7r�r�r<r�rrr)r�r�r�r	r
rr�r-rrr�test_subclassingPs<


zUsabilityTest.test_subclassingcCs@|jj}|jj}|�}|�t|d����t|�|d����dS�Nr)rr�rTr�r�r\�r�r�rTrrrr�test_implicit_contexts�z#UsabilityTest.test_implicit_contextc	Cs�|jj}|jj}|jj}|jj}|jj}|jj}|jj}|jj}|jj	}	|jj
}
|jj}||����M}d|_d|_
d|_|d�}
|d�}|d�}|��|�t|
jdd��d�|�|j|	�|�|j|
�|��|j||jdd�|�|j|�|�|jdd�d	�|�|jdd�d
�|��|�t|
jdd��d�|�|j|	�|�|j|
�|��|j||d�jdd�|�|j|�|��|�t|
jdd��d
�|�|j|	�|�|j|
�|��|j||d�jdd�|�|j|�|��|�t|
jdd��d�|j||d�jdd�|�|j|�|��|�t|
jdd��d�|j||jdd�|�|j|�|��|�t|jdd��d�|j||d�jdd�|�|j|�|��|�t|jdd��d�|j||d�jdd�|�|j|�|��|�t|jdd��d�|j||jdd�|�|j|�|�t|j dd��d�|��|�t|j!dd��d�|�|j|�|�|j|	�|�|j|
�|�|j|�|�|j|�|��|j||j!dd�|�|j|�d|_"|�t|j#dd��d�d|_"|��t|
j$|d�dd��}|�|d�|j||
j$|d�dd�|�|j|�|��t|
j%ddd��}|�|d�|j||
j%|d�dd�|�|j|�|��t|
j&ddd��}|�|d�|j||
j&ddd�|�|j|�|��t|
j'ddd��}|�|d�|j||
j'ddd�|�|j|�|��t|
j(ddd��}|�|d �|j||
j(ddd�|�|j|�|��t|
j)ddd��}|�|d�|j||
j)|d�dd�|�|j|�|��t|
j*ddd��}|�|d�|j||
j*|d�dd�|�|j|�|��t|
j+ddd��}|�|d�|j||
j+|d�dd�|�|j|�|��t|
j,ddd��}|�|d�|j||
j,|d�dd�|�|j|�|��t|
j-ddd��}|�|d �|j||j-ddd�|�|j|�|��t|
j.d!dd��}|�|d"�|j||
j.ddd�|�|j|�|��t|
j/ddd��}|�|d#�|j||
j/d$dd�|�|j|�|��t|
j0d!dd��}|�|d"�|j||
j0d$dd�|�|j|�|��t|
j1d!d%dd��}|�|d&�|j||
j1|d�d%dd�|�|j|�t2|_3t|d'�j4ddd(��}|�|d�t5|_3t|d'�j4ddd(��}|�|d)�t|d'�j4t6dd(��}|�|d�|��|j||d�j4dd�|�|j|�t2|_3t|d'�j7ddd(��}|�|d�t5|_3t|d'�j7ddd(��}|�|d)�t|d'�j7t6dd(��}|�|d�|��|j||d�j7dd�|�|j|�t2|_3t|d'�j8ddd(��}|�|d�t5|_3t|d'�j8ddd(��}|�|d)�t|d'�j8t6dd(��}|�|d�|��|j||d�j8dd�|�|j|�t6|_3t|d*�j9|d+�ddd,��}|�|d-�t5|_3t|d*�j9|d+�ddd,��}|�|d.�t|d*�j9|d+�t6dd,��}|�|d-�|��|j||j9|d/�t6dd(�|�|j|�Wd�n	1�s�wY||���E}d|_d|_
d|_|dd0��}|�|jd�|�|j
d�|�|jd�Wd�n1�s�wYWd�dSWd�dS1�s�wYdS)1Nrr=i���Z111Z1e9999z1e-9999�r z1.609487E+48FTz4.709530rz2.045323rrZ1111000z
9.999999E+999rr+r��
+Subnormalz0E-1005r�ZNan891287828Z
NaN1287828i  r�r�eZ101rkr�r�Z11100z1.11E+9r�r$Z225r��r%r r/z1.50001z1e-3)r�r%r z1.501z1.500z1e-10)r'):rr�r'rrzr{r}r�rr|r~ryr$r�r�r�r�r�r�rr�r�r7rKrO�ln�log10�logbrDrSrTrYr8r\�capitalsr]r2r9r5rWrar�rQr�rRrZ�rotate�scaleb�shift�fmar(r%�to_integralrrrvr^r_�quantize)r�r�r'rrzr{r}r�rr|r~ryrr�r�zr�r rrr�test_none_args�s���Z ��$�zUsabilityTest.test_none_argscCs |jj}|�|d��d�|d��|d���|�|d��d�|d��|d���|�|d��d�|d��|d���|�|d��d�|d��|d���|�|d��d�|d��|d���|�|d��d�|d��|d���|�|d��	d�|d��	|d���|�|d��
d�|d��
|d���|�|d��d�|d��|d���|�|d��d�|d��|d���|�|d��
d�|d��
|d���|�|d��d�|d��|d���|�|d��d�|d��|d���|�|d	��d�|d	��|d���|�|d��d
�|d��|d
���|�|d��d�|d��|d���|�|d��d
�|d��|d
���|�|d��d�|d��|d���|�|d��|d�d�|d��|d�|d���|�|d��dd�|d��|d�|d���|�|d��d|d��|d��|d�|d���dS)Nr!r$iu'��i7rkrQrYir�r�z9.123���rLri�r��C)rr�r�r2r9r:r;r5rWrar�rQr�rRrUr�rZr�r[r�r�r�r�rrr�test_conversions_from_intw	s����������������������z'UsabilityTest.test_conversions_from_intN)r�r�r�r�r^rergrqrsr�r�r�r�r�r�r�r�r�r�r�r�r�r�r�rrrrrOxs.$*	N
g
-!/	prOc@r�)�CUsabilityTestNr�rrrrr��	r�r�c@r�)�PyUsabilityTestNr�rrrrr��	r�r�c@s\eZdZdd�Zdd�Zdd�Zdd�Zd	d
�Zdd�Zd
d�Z	dd�Z
dd�Zdd�ZdS)�PythonAPItestscCsT|jj}|�t|tj��|�t|tj��|�|d�tj�|�	|d�tj�dSr�)
rr�r�
issubclass�numbers�Numberr3ZRealrUZassertNotIsInstancer�rrr�test_abc�	s
zPythonAPItests.test_abccCs�ttjd�D]�}|jj}tjd}|jtjd<|d�}t�||�}t�|�}|�	||�t
r�t
�d�}t�d�}t
tjd<t�||�}	ttjd<t�|	�}
|�|
tj�|�	|
|�ttjd<t�||�}t
tjd<t�|�}
|�|
t
j�|�	|
|�t
�d��
�}t�d��
�}t
tjd<t�||�}	ttjd<t�|	�}
|�|
tj�|�	|
|�ttjd<t�||�}t
tjd<t�|�}
|�|
t
j�|�	|
|�|tjd<qdS)Nr�rz-3.141590000z-3.123e81723)r�pickle�HIGHEST_PROTOCOLrr��sys�modules�dumps�loadsr�rhr�rUr�ZDecimalTuple)r��protor��savedecimalrrr�r�rZsxrJZsyrrr�test_pickle�	sN















�zPythonAPItests.test_picklecCs�|jj}tdd�D])}d|d}|�t||��tt|���||�}|�t�}|�|t|��|�q	|�t	t|d��|�t	t|d��|�t
t|d��|�t
t|d��dS)	N������%0.2f�Y@r�r�r?r@)rr�rr�r�rHr�rrr�r�r��r�r�r�rrrJrrr�test_int�	s
zPythonAPItests.test_intcCsl|jj}tdd�D]*}d|d}|�t||��tt|���||�}|�t�}|�|t�	|��|�q	dS)Nr�r�r�r�)
rr�rr�r�rHr�rrr��truncr�rrr�
test_trunc�	s
�zPythonAPItests.test_trunccCsz|jj}Gdd�d|�}|�t||��|�d�}|�t|�|�|�t|�d�|�|jd�d}|�|�|�||��|�|�t	d���
��|�|�t	d�����|�|�t	d	�����|�t|�t	d���t|d
���|�t|�t	d���t|d���|�t|�t	d	���t|d���|�t
|jd
�td�D]}t�d�t��dd}|�|t	|�|���q�dS)Nc@r�)z1PythonAPItests.test_from_float.<locals>.MyDecimalcSs
d|_dS)Nr)r�)r��_rrrr�
�
z:PythonAPItests.test_from_float.<locals>.MyDecimal.__init__Nr�rrrrr�
r�r�r<r=rls\�&�5$3�|	r>r?r@rr+rA�abcrDrErFrG)rr�rr�r�r�r�r�r�rHrLrHr�r�rr�rI)r�r�r�rJZbigintr�r�rrr�test_from_float
s8

�
�
�
��zPythonAPItests.test_from_floatcCs�|jj}|jj}|jj}|dtd�}|�|�tj�|d��|dt	d�}|�|�tj�|d��|d|gd�}|�
||jtj�|�t|�d��d�|�t|�d��d	�|�t|�d
��d�dS)Nr)r$r%z3.1415r�)r$r&��z
Decimal('-0')rGzDecimal('1')r1z
Decimal('10'))rr�r'r|rrr��create_decimal_from_floatr��pirvr�r�)r�r�r'r|r rrr�test_create_decimal_from_float'
s8
�
�����z-PythonAPItests.test_create_decimal_from_floatcCs�|jj}|jj}|jj}|ddd�}|�|d��|d��|d��|�|d�j|d�td�|d��|j||d	�j|d
�|d�|�}|d�}|j||d
�td�}|�||d��dS)Ni��iay��rjz7.335z.01z7.34�r%z7.33Z10e99999Z1e100000r�z0.871831e800Z1e797)r r�r%z	8.71E+799)rr�r'rzr�r�rrr�)r�r�r'rzrrr�rrr�
test_quantizeC
s(���zPythonAPItests.test_quantizecCs�|jj}|d�}|�|j|�|�|jd�|�|��|�|d�}|�t|�ttd���|�t	t
|dd�|�t	t
|dd�|�t	t
|dd�|�t	t
|d	d�dS)
Nz9.8182731e181273rr/r��realrY�imag�	conjugate�__complex__)rr�r�r�rr�complexrHr�r�r�)r�r�r�rrr�test_complex[
szPythonAPItests.test_complexcCs.|jj}|jj}|jj}|jj}|jj}|�}d|_d|_d|_|���h}|�	�|�
|d|�d�|�
|d|d�d�|�
||dd�d�|�
||d�d�|�	�|j||d|d�|�|j
|�|�|j
|�|�	�|�
|d�j|d�d	�|j||d
�j|d�|�|j
|�|�|j
|�|�	�|�
|d�j|d�|d��|j||d�j|d�|�|j
|�|�|j
|�|�
|d�j|d�|d��|�
|d�j|d�d
�|�
|d�j|d�|d��|�
|d�j|d�|d��|�
|d�j|d�d�|�
|d�j|d�d�|�
|d�j|d�d�|�
|d�j|d�|d��|�
|d�j|dd�d�|�	�|j||d�j|d�|d�|�|j
|�|�|j
|�|�
|d�j|d�|d�|d��|�
|d�j|d�|d�|d��|�
|d�j|d �|d�|d ��|�
|d!�j|d"�|d�|d#��|�
|d!�j|d"�|d�|d��|�
|d�j|d$�|d�|d%��|�	�|j||d�j |d&�|d�|�|j
|�|�|j
|�|�
|d'�j!|d(�|d�|d)��|�
|d*�j"|d+�|d	d,�|d-��|jt#|d�j$|d�|jt#|d�j%|d�|jt#|d�j&|d�|jt#|d�j'|d�|jt#|d�j(|d�|jt#|d�j)|d�|jt#|d�j*|d�|jt#|d�j+|d�|�|d�j,|d��|�|d�j-|d��|jt#|d�j.|d�|jt#|d�j/|d�|jt#|d�j0|d�|�
|d.�j1|d�d�|�
|d�j2|d�d�|�
|d�j3|d�d/�|�
|d0�j4|d�d0�|�
|d1�j5|d2�|d�d�|�
|d1�j6|d2�|d�d�|�
|d3�j7|d2�|d�d�|�
|d4�j8d|d�d�|�
|d4�j8d|d�d�|�	�|j||d4�j9d|d�|�|j
|�|�|j
|�|�
|d4�j:d|d�d�|jt#|j;d5|d�|jt#|d�j<|d�|�
|d��=�d�|jt#|d$�j>|d�|jt#|d$�j?|d�|jt#|d�j=d6d�|jt#|d�j=d6d7�Wd�dS1�s�wYdS)8Nr�rr#r�)r r�rrr�rr-z0.7r@r%z-0.9z9.73z1E+1Z9999�'z-2000i0���r�rkz0.0625�0.2r$)r rpr�r>�0.01z0.0101r�z-0.3z0.02z-0.03rBr�rcZ1e10�9.99r�r��9.9z0.9)�thirdr rpz7E+1i����r�z0.21Z11r�Z01Z23g�������?r�)r)@rr�r'rrzr}r$r�r�r�r�r�rr�r3r�r�r�rSrTrYr�r_r^r\r2r9r�rQr�rRrUr�rZr�r�rErGrHrJrLrNrMrPrKrO�adjustedr�radixr�rDr8r]r5rWrar�r�r�r�r��	canonicalr>r?)r�rnr'rrzr}Zxcrrrr�test_named_parametersk
s�
�""�"�"����$�z$PythonAPItests.test_named_parameterscCs�|j}|j}|j}|j}|j}|j}|j}|j}|j}	|j	}
|j
}|�t|t
��|�t||��|�t||��|�t|t��|�t||��|�t|t��|�t||
��|�t||	��|�t||��|�t||	��|�t||
��|�t||��|�t||��|�t||��|�t|	|��|�t|
|��|�t||��|�t|j|��|�t|j|��|�t|j|��|�t|jt��|�t|j|��dSr)rr�rz�FloatOperationr{r}r�rr|r~ryrr��ArithmeticErrorr��ZeroDivisionErrorZConversionSyntaxZDivisionImpossibleZDivisionUndefinedZInvalidContext)r�rr�rzrr{r}r�rr|r~ryrrr�test_exception_hierarchy�
sBz'PythonAPItests.test_exception_hierarchyN)
r�r�r�r�r�r�r�r�r�r�rrrrrrrr��	s3 pr�c@r�)�CPythonAPItestsNr�rrrrrr�rc@r�)�PyPythonAPItestsNr�rrrrrr�rc@seZdZdd�Zeeejed�dd����Z	dd�Z
dd	�Zd
d�Zdd
�Z
dd�Zdd�Zdd�Zdd�Zdd�Zdd�Zdd�Zdd�Zdd�Zd d!�Zd"d#�Zd$d%�Zd&d'�Zd(d)�Zd*d+�Zd,d-�Zd.d/�Zd0d1�Zd2d3�Z d4d5�Z!d6d7�Z"d8d9�Z#d:d;�Z$d<d=�Z%d>d?�Z&d@dA�Z'dBdC�Z(dDdE�Z)dFdG�Z*dHdI�Z+dJdK�Z,dLdM�Z-dNdO�Z.dPdQ�Z/dRdS�Z0dTdU�Z1dVdW�Z2dXdY�Z3dZd[�Z4d\d]�Z5d^d_�Z6d`da�Z7dbdc�Z8ddde�Z9dfdg�Z:dhdi�Z;djdk�Z<dldm�Z=dndo�Z>dpdq�Z?drds�Z@dtdu�ZAdvdw�ZBdxdy�ZCdzd{�ZDd|d}�ZEd~d�ZFd�S)��ContextAPItestsc
Cs�|jj}|jj}|jj}|jj}|�}|ddddddddd�}||fD]=}|�|jd�|�|jt�|�|j	d�|�|j
d�|�|jd�|�|jd�t
||dg�t
||d|||g�q#dS)	N)r$r%r�r�r�r3r�r&rM�?B��r�rr�r&)rr'rzr{r}r�r$r%r(r�r�r�r3r")r�r'rzr{r}r9r7rrrrr�
s(
���zContextAPItests.test_none_argsrcCsrddl}|j��}tD]}|�|�|_|�|j|�q|�d�}|�tt	|d|�|�d�}|�tt	|d|�dS)Nrrr%z	ROUND_UP)
rrr'�
RoundingModesrr%r�r�r�r�)r�rrZrndrrrrrs


z(ContextAPItests.test_from_legacy_stringscCsvttjd�D�]0}|jj}tjd}|jtjd<|�}t�t�||��}|�	|j
|j
�|�	|j|j�|�	|j|j�|�	|j
|j
�|�	|j|j�|�	|j|j�|�	|j|j�|�	|j|j�trottfttfgnttfg}|D]�\}}tt�D]�\}	}
tt|�D]�\}}
tt|�D]�\}}
t�dd�}
t�dd�}t�dd�}t�d�}t�d�}|tjd<|j|
||t|	||t|d|�t|d|�d�}t�||�}|tjd<t�|�}|�||j�|�	|j
|
�|�	|j|�|�	|j|�|�	|j
t|	�|�	|j|�|�	|j|�t||dt|d|��t||d	t|d|��q�q�q~qv|tjd<qdS)
Nr�rrYr�rr�)r$r�r�r%r�r3r�r&r�r&)rr�r�rr'r�r�r�r�r�r$r�r�r%r�r3r�r&rhr�r�rr�r��	randrangerUr")r�r�r'r�rr��combinationsZdumper�loaderZrir��fiZtir$rpro�capsr3rrrrrr�/sb



�

���#�zContextAPItests.test_picklecCsB|jj}|�|d�dd|d�dig�|�|d�dddig�dS)Nr1r2rG)r�r�)rr�ZassertInZassertNotInr�rrr�test_equality_with_other_typeslsz.ContextAPItests.test_equality_with_other_typescCs�|jj}|jj}|�}|��}|�t|�t|��|�t|j�t|j��|�t|j�t|j��t|j�	��}t|j�	��}|�
||�|�
|j|j�dSr)rr�r'r<rUr�r�r&rf�keysr�)r�r�r'rrZk1Zk2rrr�	test_copyrszContextAPItests.test_copycCs"|jj}|�}|�tt|d�dS)NZ_clamp)rr'r�r�r�r�r'rrrr�test__clamp�szContextAPItests.test__clampcC�J|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dS�Nrr�)rr�r'rr�r�r��r�r�r'rrrrr�test_abs��zContextAPItests.test_abscC�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dS�Nr�r/)rr�r'rir�r�r�r%rrr�test_add��zContextAPItests.test_addcCr(r))rr�r'r2r�r�r�r%rrr�test_compare�r+zContextAPItests.test_comparecCr(r))rr�r'r9r�r�r�r%rrr�test_compare_signal�r+z#ContextAPItests.test_compare_signalcCr(r))rr�r'r:r�r�r�r%rrr�test_compare_total�r+z"ContextAPItests.test_compare_totalcCr(r))rr�r'r;r�r�r�r%rrr�test_compare_total_mag�r+z&ContextAPItests.test_compare_total_magcCr#r$)rr�r'r>r�r�r�r%rrr�
test_copy_abs�r'zContextAPItests.test_copy_abscCr#r$)rr�r'r=r�r�r�r%rrr�test_copy_decimal�r'z!ContextAPItests.test_copy_decimalcCr#r$)rr�r'r?r�r�r�r%rrr�test_copy_negate�r'z ContextAPItests.test_copy_negatecC�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dS)Nr�r%r/r))rr�r'rAr�r�r�r%rrrr*�r+zContextAPItests.test_copy_signcCr3�Nr�r�r/r)rr�r'r1r�r�r�r%rrr�test_divide�r+zContextAPItests.test_dividecCr3r4)rr�r'rBr�r�r�r%rrr�test_divide_intr+zContextAPItests.test_divide_intcCr3r4)rr�r'r�r�r�r�r%rrr�test_divmodr+zContextAPItests.test_divmodcCr#�Nr1r�)rr�r'r�r�r�r�r%rrr�test_expr'zContextAPItests.test_expcCs^|jj}|jj}|�}|�|d�|d�|d��}|�|�ddd�|�|�|�|d�dd�|�|�|�d|d�d�|�|�|�dd|d��|�|�|�|d�|d�d�|�|�t|jddd�|�t|jddd�|�t|jddd�|�t|j|d�|d�d	�|�t|j|d
�|d�d�|�t|d�j|d�d	�|�t|d
�j|d�d�dS)
Nr�r$r!rr��4r+rz
not a decimalr�r�gZd;�O��?)rr�r'r�r�r�r�r%rrr�test_fma%s0
�
���zContextAPItests.test_fmacCr#r8)rr�r'rGr�r�r�r%rrr�test_is_finite?r'zContextAPItests.test_is_finitecCr#r8)rr�r'rHr�r�r�r%rrr�test_is_infiniteHr'z ContextAPItests.test_is_infinitecCr#r8)rr�r'rJr�r�r�r%rrr�test_is_nanQr'zContextAPItests.test_is_nancCr#r8)rr�r'rKr�r�r�r%rrr�test_is_normalZr'zContextAPItests.test_is_normalcCr#r8)rr�r'rLr�r�r�r%rrr�test_is_qnancr'zContextAPItests.test_is_qnancCr#r8)rr�r'rMr�r�r�r%rrr�test_is_signedlr'zContextAPItests.test_is_signedcCr#r8)rr�r'rNr�r�r�r%rrr�test_is_snanur'zContextAPItests.test_is_snancCr#r8)rr�r'rOr�r�r�r%rrr�test_is_subnormal~r'z!ContextAPItests.test_is_subnormalcCr#r8)rr�r'rPr�r�r�r%rrr�test_is_zero�r'zContextAPItests.test_is_zerocCr#r8)rr�r'r�r�r�r�r%rrr�test_ln�r'zContextAPItests.test_lncCr#r8)rr�r'r�r�r�r�r%rrr�
test_log10�r'zContextAPItests.test_log10cCr#r8)rr�r'r�r�r�r�r%rrr�	test_logb�r'zContextAPItests.test_logbcCr(r))rr�r'r5r�r�r�r%rrr�test_logical_and�r+z ContextAPItests.test_logical_andcCr#)Nr�r)rr�r'rDr�r�r�r%rrr�test_logical_invert�r'z#ContextAPItests.test_logical_invertcCr(r))rr�r'rWr�r�r�r%rrr�test_logical_or�r+zContextAPItests.test_logical_orcCr(r))rr�r'rar�r�r�r%rrr�test_logical_xor�r+z ContextAPItests.test_logical_xorcCr3r4)rr�r'r�r�r�r�r%rrr�test_max�r+zContextAPItests.test_maxcCr3r4)rr�r'rQr�r�r�r%rrr�test_max_mag�r+zContextAPItests.test_max_magcCr3r4)rr�r'r�r�r�r�r%rrr�test_min�r+zContextAPItests.test_mincCr3r4)rr�r'rRr�r�r�r%rrr�test_min_mag�r+zContextAPItests.test_min_magcCr#r8)rr�r'Zminusr�r�r�r%rrr�
test_minus
r'zContextAPItests.test_minuscCr3r4)rr�r'r>r�r�r�r%rrr�
test_multiply
r+zContextAPItests.test_multiplycCr#r8)rr�r'rSr�r�r�r%rrr�test_next_minus
r'zContextAPItests.test_next_minuscCr#r8)rr�r'rTr�r�r�r%rrr�test_next_plus&
r'zContextAPItests.test_next_pluscCr3r4)rr�r'rUr�r�r�r%rrr�test_next_toward/
r+z ContextAPItests.test_next_towardcCr#r8)rr�r'rYr�r�r�r%rrr�test_normalize;
r'zContextAPItests.test_normalizecCsn|jj}|jj}|�}|�|�d�|�|d���|�|�d�|�|d���|�|�d�|�|d���dS)Nrkrr)rr�r'r�r8)r�r�r'rrrr�test_number_classD
s z!ContextAPItests.test_number_classcCr#r8)rr�r'�plusr�r�r�r%rrr�	test_plusM
r'zContextAPItests.test_pluscCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�|�|d�|d��|�|�t|jdd�|�t|jdd�|�|jdddd�d�dS)	Nr�r!r/r:rr-r�)�modulor]r2)rr�r'�powerr�r�r�r%rrr�
test_powerV
szContextAPItests.test_powercCr3r4)rr�r'r�r�r�r�r%rrrr�d
r+zContextAPItests.test_quantizecCr3r4)rr�r'�	remainderr�r�r�r%rrr�test_remainderp
r+zContextAPItests.test_remaindercCr3r4)rr�r'rZr�r�r�r%rrr�test_remainder_near|
r+z#ContextAPItests.test_remainder_nearcCr3r4)rr�r'r�r�r�r�r%rrr�test_rotate�
r+zContextAPItests.test_rotatecCr#r8)rr�r'r\r�r�r�r%rrr�	test_sqrt�
r'zContextAPItests.test_sqrtcCr3r4)rr�r'r[r�r�r�r%rrr�test_same_quantum�
r+z!ContextAPItests.test_same_quantumcCr3r4)rr�r'r�r�r�r�r%rrr�test_scaleb�
r+zContextAPItests.test_scalebcCr3r4)rr�r'r�r�r�r�r%rrr�
test_shift�
r+zContextAPItests.test_shiftcCr3r4)rr�r'�subtractr�r�r�r%rrr�
test_subtract�
r+zContextAPItests.test_subtractcCr#r8)rr�r'r]r�r�r�r%rrr�test_to_eng_string�
r'z"ContextAPItests.test_to_eng_stringcCr#r8)rr�r'r`r�r�r�r%rrr�test_to_sci_string�
r'z"ContextAPItests.test_to_sci_stringcCr#r8)rr�r'r_r�r�r�r%rrr�test_to_integral_exact�
r'z&ContextAPItests.test_to_integral_exactcCs\|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�|�t|jdd�dS)Nr1r�r�)rr�r'r^r�r�r�r%rrr�test_to_integral_value�
sz&ContextAPItests.test_to_integral_valueN)Gr�r�r�r�r
rr
r_r`rr�rr r"r&r*r,r-r.r/r0r1r2r*r5r6r7r9r;r<r=r>r?r@rArBrCrDrErFrGrHrIrJrKrLrMrNrOrPrQrRrSrTrUrVrXr[r�r]r^r_r`rarbrcrerfrgrhrirrrrrs�
=																												rc@r�)�CContextAPItestsNr�rrrrrj�
r�rjc@r�)�PyContextAPItestsNr�rrrrrk�
r�rkc@s<eZdZdd�Zdd�Zdd�Zdd�Zd	d
�Zdd�Zd
S)�ContextWithStatementcCsv|jj}|jj}|�}|��}|�}Wd�n1swY|�}|�||d�|�||d�|�||d�dS)N�!did not restore context correctly�did not copy the context� __enter__ returned wrong context)rrTrr7�assertIsNot)r�rTr�orig_ctx�	enter_ctx�set_ctx�	final_ctxrrr�test_localcontext�
s�z&ContextWithStatement.test_localcontextc	Cs�|jj}|jj}|jj}|jj}|�}|dd�}||��}|�}Wd�n1s*wY|�}|�||d�|�|j|jd�|�||d�|�||d�dS)Nr��r$rmzdid not set correct contextrnro)rr'rTrr7r�r$rp)	r�r'rTrrq�new_ctxrrrsrtrrr�test_localcontextargs

�z)ContextWithStatement.test_localcontextargc	Cs�|jj}|jj}|jj}|jj}|jj}|jj}|�}|��|dd�}|���}	|�|	j	|j	�|�|	j
|j
�d|	j
|<d|	_|�|jd�|�
||	jd�|�|	j	|�||��4}
|�|
j	|j	�|�|
j
|j
�|�
||
j|d�d�|�|
j	|�|�|
j	|�~
Wd�n1s�wY|�|	j	|�~	Wd�n1s�wY|�|jd�|�|j	|�|�|j	|�|�|j	|�|�|j	|�dS)N��r�T���z0e-999z3.4e200r�)rr�r'rTrryr}r�r�r�r&r�rUr�r�rrZr3)r�r�r'rTrryr}rqrwr9r7rrr�test_nested_with_statementssB


��z0ContextWithStatement.test_nested_with_statementscCs�|jj}|��N}~|��1}~|��}~|��	}~Wd�n1s"wYWd�n1s1wYWd�n1s@wYWd�dSWd�dS1sXwYdSr�rr�r�rr9r7r8�c4rrr�test_with_statements_gc1<s"������"�z-ContextWithStatement.test_with_statements_gc1cCs�|jj}|��Q}||��4}~||��}~||��
}~~Wd�n1s%wYWd�n1s4wYWd�n1sCwYWd�dSWd�dS1s[wYdSrr}r~rrr�test_with_statements_gc2Hs"


������"�z-ContextWithStatement.test_with_statements_gc2c
Cs�|jj}|jj}|jj}|jj}|���}~|dd�}||�||��~}~|�|jd�~|dd�}||�~|�|�jd�|dd�}	||	�|�|�jd�||	��>}
~	|�|
jd�~
|dd�}||�~|�|�jd�|��}|�|jd�~Wd�n1s�wYWd�n1s�wYWd�n1s�wYWd�dSWd�dS1s�wYdS)Nr�rvr�r$r!)rr'rrTr,r�r$)
r�r'rrTr,r9Zn1r7Zn2Zn3r8Zn4rrrr�test_with_statements_gc3TsL





������"�z-ContextWithStatement.test_with_statements_gc3N)	r�r�r�rurxr|r�r�r�rrrrrl�
s
#rlc@r�)�CContextWithStatementNr�rrrrr�ur�r�c@r�)�PyContextWithStatementNr�rrrrr�wr�r�c@s8eZdZdd�Zdd�Zedd��Zdd�Zd	d
�ZdS)�ContextFlagsc
s��jj}�jj}�jj}�jj}�jj}�jj}�jj}�fdd�}|dddtggd�}	|	j	|d�gf|	j
|d�gf|	j|d	�|d
�gf|	j|d	�|d
�gf|	j
|d	�|d
�gfg}
|g|g|g|g|g|||||gg}|
D]o\}}
|	��||
�}dd�|	j��D�}|D]V}|	��|D]}||	|�q�||
�}t|�}|D]}||vr�|�|�q�|jtd
�dd�|	j��D�}|jtd
���||dd||f���||dd||f�q�qndS)Ncs4�jtkrd|j|<|j|r|�dS|�|�dS�NT)rrhr�r&Z_raise_error)r �flagr�rr�raise_error�s


�z7ContextFlags.test_flags_irrelevant.<locals>.raise_errorr#rDr�)r$r�r�r%r&r�z100E-425000010r�r�z
9.87654321cS�g|]\}}|r|�qSrr�r�kr�rrrr��r�z6ContextFlags.test_flags_irrelevant.<locals>.<listcomp>r�cSr�rrr�rrrr��r�z=operation produces different answers depending on flags set: zexpected %s, got %s.z9operation raises different flags depending on flags set: zexpected %s, got %s)rr�r'r|r~r�ryrr(r6r\rir>rdr�r�r[rWr�r�r�r�)r�r�r'r|r~r�ryrr�r Z
operationsZflagsets�fnr�r�r��extra_flagsr�Znew_ansZexpected_flagsZ	new_flagsrr�r�test_flags_irrelevant|sb��	�
�
��
����z"ContextFlags.test_flags_irrelevantcCs2|jj}|jj}|jj}|�}|�|j|j�|�|j|j�|j|_|�|j|j�|�|j|j�d|j|<|j|_|�|j|j�|�|j|j�i}|�|j�|�||j�|�|j|�d||<|�||j�|�|j|�|di}|�||j�|�|j|�dg}|�||j�|�|j|�dS)NTFr)	rr'r|r~rUr�r&r��update)r�r'r|r~rrrrr�test_flag_comparisons�s4
z"ContextFlags.test_flag_comparisonscCs�|jj}|jj}|jj}|���}|�|j|�|��|�|d�d�|�|j	|�|��|�|�
d�d�|�|j	|�|��|�d�}|�|j	|�|�|d�|�|j	|�|��|�d�}|�|j	|�|�|d�|�|j	|�d|j|<|��|�
||d�|�|j	|�|��|�
||j
d�|�|j	|�|��|�d�}|�|j	|�|��|�d�}|�|j	|�Wd�dS1s�wYdS)Ng@T)rr�rrr3r&r�r�rr�r�r�r�r�)r�r�rrrr�rrr�test_float_operation�sF




"�z!ContextFlags.test_float_operationcs8�jj��jj}�jj��jj}d��fdd�	��d���d��d�
d��d���d��	d	�d
�
�d���d��td
��td��d���������	�
��
��fdd�	}d���fdd�	}|�}||��.}��|j��||dd�||dd�d|j�<||�d�||�d�Wd�dS1s�wYdS)NcsN|��t||�}|�kr��|||�n��||�d���|j��dSr�)r�rr�r7rr�)r2r]r!r �signalr�)rr�rr�assert_attr s
z7ContextFlags.test_float_comparison.<locals>.assert_attrr_r`rbrar�rBr.r�r+rAr?r@csdD]
}��
�|||�qdD]
}���|||�q��
�d|d����	d|d����
d|d����	d|d����
d|d����d|d����d|d���
�d|d���d�dd|d����d|d����d|d���d�td�d|d�dS)	N)rsru)rtrvrwrxrcr<rr>)rH)rr�r!)r�r��big_d�big_f�inf_d�inf_f�	neg_inf_d�	neg_inf_f�
neg_zero_d�
neg_zero_f�small_d�small_f�zero_d�zero_frr�doit8s z0ContextFlags.test_float_comparison.<locals>.doitcs�|��td�d�g�}��t|�d���|j��|��|r.��|td�d�g�ntd�d�g�}��|j��|��d�d�dfv}��|j��|��d�d�dddiv}��|j��dS)	Nr�z100.0r�rGr�g$@r2r])r�rfr��lenrr�r��sorted)rr�rr])r�rr�rr�test_containersVsz;ContextFlags.test_float_comparison.<locals>.test_containers)r�Tr)rr�r'rrrHr3r&)r�r'rr�r�rWrr)r�rr�r�r�r�r�r�r�r�r�r�r�r�r�r�r�test_float_comparisons8	(

"�z"ContextFlags.test_float_comparisoncCs�|jj}|jj}|jj}|jj}|�}|�|j|�|�|j|�|��d|j|<d|j|<|�	|j|�|�	|j|�dSr�)
rr�r'r|rr3r�r&�clear_trapsr)r�r�r'r|rr rrr�test_float_operation_defaultus

z)ContextFlags.test_float_operation_defaultN)	r�r�r�r�r�rr�r�r�rrrrr�zsB&
5[r�c@r�)�
CContextFlagsNr�rrrrr��r�r�c@r�)�PyContextFlagsNr�rrrrr��r�r�c@� eZdZdZdd�Zdd�ZdS)�SpecialContextszTest the context templates.c
Cs.|jj}|jj}|jj}|jj}|jj}|jj}|jj}|jj}|jj	}	t
||d|||||	g�|���}
|j}|j}d}
zJz#d|_|_||fD]}||�|�}|�
||�|�|jd�qIWntyv}z	|j}
WYd}~nd}~wwW||_||_||
�|
r�|
�dS||_||_||
�|
r�|
�w)Nr&i�)r�BasicContext�ExtendedContextrTr,rzr{r}r�ryr"r<r$rpr��	Exceptionr�)r�r�r�rTr,rzr{r}r�ry�savecontextZbasic_context_precZextended_context_prec�ex�templaterr�rrr�test_context_templates�sP�
������z&SpecialContexts.test_context_templatesc
Cs8|jj}|jj}|jj}|jj}|jj}|jj}|jj}|jj}|�	|j
d�|�	|j
d�t||d|||g�|���}	|j
}
d}zMz)|�}|j
}
d|_
|�}|�	|j
|
�||�|�}|�
||�|�	|j
d�Wnty�}z	|j}WYd}~nd}~wwW|
|_
||	�|r�|�dS|
|_
||	�|r�|�w)Nr#r&i�)rrFr�r�rTr,rzr{r}r�r$r"r<rpr�r�)r�rFr�r�rTr,rzr{r}r�Zdefault_context_precr�rZsaveprecr�rrr�test_default_context�sP�
�����z$SpecialContexts.test_default_contextN)r�r�r�r�r�r�rrrrr��s$r�c@r�)�CSpecialContextsNr�rrrrr��r�r�c@r�)�PySpecialContextsNr�rrrrr��r�r�c@r�)�ContextInputValidationc	Cs@|jj}|jj}|��}dD]#}t||d�|�t||�d�|�tt||d�|�t	t||d�qt|dd�|�t|d�d�|�tt|dd�|�t	t|dd�|�t	t|d	d�|�t	t|d	d
�|�t	t|d	d�|�t	t|d	d�dD]}|�tt||d�|�tt||d
�|�t	t||gd��qy|�t
t|dd�|�t	t|dg�|�tt|di�|�tt|dddi�dD]
}|�t
|j|�q�|�t	t|d
�|�t	t|d
�|jt	|dd�|jt	|dd�|jt|d
d�|jt|dd�|jt|dgd�|jt|dgd�|jt	|dd�|jt	|dd�dS)N�r$r�rrrr�rr��r�r�r$r%r#rG�r�r3r�rorYr�r&rzr)r$r�r�r%r�r3r�r&r��r3�r�r��r��Q�r&�rr�)r�r)
rr'rFr<r�r�rr�r�r�r��KeyError�__delattr__)r�r'rFrr!rrr�test_invalid_context�sL�z+ContextInputValidation.test_invalid_contextN)r�r�r�r�rrrrr���r�c@r�)�CContextInputValidationNr�rrrrr�r�r�c@r�)�PyContextInputValidationNr�rrrrr�r�r�c@r�)�ContextSubclassingcs�|j��j}�j��j}�j}�j}�j}�j}�j}�j	}�j
}	G��fdd�d��}
��}|
�}dD]}
|�t||
�t||
��q4|j
t|
fiddi��|
dd�}|�|jd�|�
|	|j|d�d	�|j
t|
fid
di��|
tdd�}|�|jt�|�|�|d
��d�|j
t|
fiddi��|
ddd�}|�|jd�|�|d�|d��}|�||d��|||||fD]
}|�|j|�q�|j
t|
fiddi��|
ddd�}|�|jd�|�
||j|d�|d��|jtk�r|||fD]
}|�|j|�q�|j
t|
fiddi��|
d	d�}|�|jd	�|�d�}|�|�|�d�|j
t|
fiddi��|
ddd �}|�|jd�|�|d��}|�t|�d!�|j
t|
fid"di��|
||gd#�}||fD]}|�|j|��qh|� �t!�D]}|�"|j|��q||j
t|
fid$di��|
||gd%�}||fD]}|�|j#|��q�|�$�t!�D]}|�"|j#|��q�dS)&Ncs"eZdZ			d��fdd�	ZdS)z>ContextSubclassing.test_context_subclassing.<locals>.MyContextNc		s���|�|dur||_|dur||_|dur||_|dur!||_|dur(||_|dur/||_�durHt�t�rE�fdd�t	��D���|_
�durct�t�r^�fdd�t	��D���|_dSdS)Nc�i|]}||�v�qSrr�rr�r�rr�
<dictcomp>D�z[ContextSubclassing.test_context_subclassing.<locals>.MyContext.__init__.<locals>.<dictcomp>cr�rrr�r�rrr�Hr�)r�r$r%r�r�r�r3rVrWr�r�r&)	r�r$r%r�r�r�r3r�r&�r'r�r�r&rr�2s,



�zGContextSubclassing.test_context_subclassing.<locals>.MyContext.__init__)NNNNNNNNr�rr�rr�	MyContext1s
�r��r$r%r�r�r�r3r�r&r$rr�rvZ9e2rr%�XYZ)r%r$r	r#r�r)r�r$z1e-99z2.234e-2000r�r�)r�r$Z1e99z
2.234e2000r�r�Z1E222z1e+222r3r��c)r3r�z!1.000000000000000000000000000E+99r�r�r&r�)%rr�r'ryr{r|r}r~rr�rzr�rr�r�r$r�r�rrr%rWr�rirr�r�rhr�r�r`r3r�r�r�r3r&r�)r�r�ryr{r|r}r~rr�rzr�rrr!r�r�rr�r�test_context_subclassing$s~


�z+ContextSubclassing.test_context_subclassingN)r�r�r�r�rrrrr�"r�r�c@r�)�CContextSubclassingNr�rrrrr��r�r�c@r�)�PyContextSubclassingNr�rrrrr��r�r�c@s$eZdZdd�Zdd�Zdd�ZdS)�CheckAttributescCs�|�tjtj�|�tjtj�|�tjtj�|�tjtj�|�tjdup+tjdu�|�tjdup8tjdu�|�tj	tj	�|�t
t�t
t��dS)NTF)r�rhr�r�r�rlrmrrG�__version__�dirr�rrr�test_module_attributes�sz&CheckAttributes.test_module_attributescCsJdd�tt���D�}dd�tt���D�}|�t|�t|�t��dS)NcS�"g|]
}d|vs
|�d�s|�qS��__r��r�rrrrr���"z;CheckAttributes.test_context_attributes.<locals>.<listcomp>cSr�r�r�rrrrr��r�)r�rhr'r�r�rf�r�r�rrrr�test_context_attributes�sz'CheckAttributes.test_context_attributescCsNdd�tt�d��D�}dd�tt�d��D�}|�t|�t|�t��dS)NcSr�r�r�rrrrr��r�z;CheckAttributes.test_decimal_attributes.<locals>.<listcomp>r#cSr�r�r�rrrrr��r�)r�rhr�r�rfr�rrr�test_decimal_attributes�sz'CheckAttributes.test_decimal_attributesN)r�r�r�r�r�r�rrrrr��sr�c@steZdZdd�Zdd�Zdd�Zdd�Zd	d
�Zdd�Zd
d�Z	dd�Z
dd�Zdd�Zdd�Z
dd�Zdd�ZdS)�CoveragecCsH|jj}|�|d���d�|�|d���d�|�|d���d�dS)NZ	1234e9999i'r>rr?)rr�r�rr�rrr�
test_adjusted�szCoverage.test_adjustedcCsL|jj}|jj}|d���}|�|d�|�}|�|d��}|�|d�dS)Nr#)rr�rTr
r�)r�r�rTr�rrrr�test_canonical�szCoverage.test_canonicalcCsp|jj��}d|_d|_d|_t|_d|_d|_	t
|jD]}d|j|<d|j|<q|�
�}d}|�||�dS)Nr�rDrr�Fz{Context(prec=425000000, rounding=ROUND_HALF_DOWN, Emin=-425000000, Emax=425000000, capitals=0, clamp=1, flags=[], traps=[]))rrFr<r$r�r�rtr%r�r3r�r�r&�__repr__r�)r�rr:rr�rrr�test_context_repr�s
zCoverage.test_context_reprcCsJ|jj}|jj}|���L}d|_d|_d|_|�t|d��d�|�|d�dd�|�|d�dd	�|�|d�d
d�|�|d��|d�d�d�|�	|d
��d
d��
�d�|�t|d�d	d
�d	�|�|d���d�|�	|d��
�d�|�	|d���d�|�|d���d�|�|d���d�|�|d���d	�|�|d���d�|�|d�d�|�|d�dd�|�|d���d�|�|d���|d��|�|d���|d��|�|d���d�|�|d�
d�|�|d�d
d�|�|d�d
d�|�|d���d�|�|d����|�|d����|�|d����|�|d����|�|d����|�|d����|�|d����Wd�n	1�s\wY|��6}d|_d d!}||�}|��}|�||�|��}|�||�|� |d��}|�||�Wd�dS1�s�wYdS)"Nr�rz-10r1�7r-r�rr�rz1.2rrTz1.01r$FZ20Z580rr!r#z2E+1z-1E+1z+Normalr�z1.12345r/r�r�r�i�i�)!rr�rr$r�r�r�rr�r7rJ�powr�rKrOr�r�r�rDrSrTrYr8r_rrErGrNrMrPr>r?rA)r�r�rrr�rr�rrrr��sb
�?
$�zCoverage.test_implicit_contextcCs�|jj}|jj}|jj}|jj}|���}t|d�d�\}}|�||d��|�||d��t|d�d�\}}|�|��o?|���d|j	|<t|d�d�\}}|�|��oX|���d|j	|<|�
�t|d�|d��\}}|�|��ow|���|�|j|�|�
�t|d�d	�\}}|�|��o�|���|�|j|�|�
�t|d
�d
�\}}|�|��o�|���|�|j|�d|j	|<|�
�t|d�d
�\}}|�|��o�|���|�|j|o�|j|�Wd�dS1s�wYdS)NZ10912837129r�Z10901935Z194rrFr?r�r�)
rr�rrzr{r�r�rrJr&r�r�rH)r�r�rrzr{rrrJrrrr7+sD


�"�zCoverage.test_divmodcCs�|jj}|jj}|jj}|jj}|��L}d|_|��|�|d�d|d��|�|j	|�d|_d|_
d|_|��d|j|<|�|d�|d	�|d
��|�|j	|�Wd�dS1sbwYdS)Nr$r�rYr�r�rFr�r�r?)
rr�rr}r~r$r�r�rr�r�r�r&)r�r�rr}r~rrrrr[Ts"
"�zCoverage.test_powercCs�|jj}|jj}|jj}|��'}d|_d|_d|_d|j|<|d��|d��}|�	|�
��Wd�dS1s9wYdS)Nr�rFr�Z1e1)rr�rrzr$r�r�r&r�rrJ�r�r�rrzrr�rrrr�hs
"�zCoverage.test_quantizecCs>|jj}|jj}|�}|�|d���d�|�|��d�dS)Nr/r1)rr�rTr�rr�rrr�
test_radixus
zCoverage.test_radixcCs0|jj}dD]}|�t|d�|�d�t�qdS)N)r|rr�r�rrr�r�r�r/r)rr�r7rrf)r�r�r!rrrr�}s�zCoverage.test_ropcCs�|jj}|jj}|��`}d|_|�t|d����d�|�t|d����d�|�t|d��d��d�|�t|d	��d
��d�|�t|d	��d��d
�|�t|d�jd�|�t|d�jdd�Wd�dS1snwYdS)NrMrr�z9.99e-5r�r�rz1.23457r�r1z1.2345000000rxz0E+10r�rr-)	rr�rr$r�r��	__round__r�r�)r�r�rrrrr�
test_round�s"�zCoverage.test_roundcCs |j��}|�t|jdg�dS)Nr�)rr'r�r�r�)r�rrrr�test_create_decimal�s
zCoverage.test_create_decimalcCsv|jj}|jj}|��&}d|_|dd�dd}|�t|�d�|�|��d�Wd�dS1s4wYdS)Nri�i�r1iSr�r�)rr�rr$r�r�r��r�r�rrr�rrrr��s"�zCoverage.test_intcCsl|jj}|�}d|_dd}|�|�}|�||�|�|�}|�||�|�|d�}|�||�dS)Nr�i�i�r�)rr'r$r>r�r?rA)r�r'rr�rrrrr �s


zCoverage.test_copyN)r�r�r�r�r�r�r�r7r[r�r�r�r�r�r�r rrrrr��sQ)

r�c@r�)�	CCoverageNr�rrrrr��r�r�c@r�)�
PyCoverageNr�rrrrr��r�r�c@rA)�PyFunctionalityz!Extra functionality in decimal.pycCs>tj}tj}gd�}|D]\}}}|�t||�|�|�qdS)N)
)z.0er�z1e+0)z#.0er�z1.e+0)r�r�r/)z#.0fr��1.)r��1.1r�)z#gr�r�)r�r/r/)z#.0gr/r�)r�r�z100%)z#.0%r�z100.%)r�r�rr�r�)r�r�rr\r�rr�rrr�test_py_alternate_formatting�s
�z,PyFunctionality.test_py_alternate_formattingN)r�r�r�r�r�rrrrr��sr�c@s8eZdZdZdd�Zdd�Zdd�Zdd	�Zd
d�ZdS)
�
PyWhiteboxz White box testing for decimal.pycCstj}tj}|��n}d|_|d�|d�}|�||d��|d�|d�}|�||d��|d�|d�}|d�|d	�}|�||d
��|d�|d	�}|dd
�|d	�}d|_|d�|d�}d|_|dd�|d�}Wd�dS1szwYdS)Nr-ir�z
0.00390625z-0.6z0.0012885819Z256e7l�o�
�z-0.0625rZ152587890625e7ric
r�Z152587890625��r�iB)r�r�rr$r�r�rrr�test_py_exact_power�s$"�zPyWhitebox.test_py_exact_powercs:tj}tj}tj}|��}tdd�ttD��|_||�|d��|d��|d��|d��d4�����fdd�	}|�����j	�j	����j
�j
����j�j�|d�|d	d
�|dd
�|dd
�|d
d
�|dd
�|dd
�|dd
�|dd
�|d�|dd
�|d�|d�|d�|dd
�|dd
�|d�|d�|d�|dd
�|dd
�|dd
�|d�|d d
�|d!d
�|d"d
�|d#d
�|d$d
�|d%�|d&d
�|d'd
�|d(�|d)�|d*d
�|d+d
�|d,d
�|d-�|d.d
�|d/d
�|d0d
�|d1�|d2�|d3�dS)5Ncss�|]}|dfVqdS)rNrrrrrr�s�z=PyWhitebox.test_py_immutability_operations.<locals>.<genexpr>z-25e55z33e+33Fcs�|r<td|d����j�j����j�j����j�j����j�j����j�j����j�j�dStd|d����j�j����j�j����j�j�dS)Nzd1.z(d2)z())r�r��_sign�_int�_exp)Z	operationZuseOther��b1�b2r	r
r�rr�checkSameDec�sz@PyWhitebox.test_py_immutability_operations.<locals>.checkSameDec�__abs__r{Trqrwrxrursrvrt�	__float__r�ru�__int__�	__trunc__r�r��__neg__�__bool__�__pos__r�r|rrr�r�r�r�r�r�__str__r~r�rr�r2r�r�rYr�rZr[r\r]r�)F)r�r�rFr,r<r)r�r&r�r�r�r�)r�r�rFr,rr�rr�r�test_py_immutability_operations�st


























z*PyWhitebox.test_py_immutability_operationscCs>tj}|d�}||�}|�t|�d�|�t|�t|��dS)Nr�r�)r�r�r�r�rUr�r:rrr�test_py_decimal_id=s
zPyWhitebox.test_py_decimal_idcCsVtj}tj}|��}|d��dt�}|�|���Wd�dS1s$wYdS)Nrr$)r�r�rZ_rescalervrrJr�rrr�test_py_rescaleEs"�zPyWhitebox.test_py_rescalecCs tj}|�t|d�jdt�dS)Nz3.1234r)r�r�r�r�Z_roundrvr�rrr�test_py__roundNszPyWhitebox.test_py__roundN)	r�r�r�r�r�rrrrrrrrr��sO	r�c@s4eZdZdZedd��Zedd��Zedd��ZdS)	�CFunctionalityzExtra functionality in _decimalcCstj}tj}tj}tj}dd�}||�}|�|jd�|�|jd�|�|jd�|||�||�}|�|jd�|�|jd�|�|jd�|||�||�}|�|jd	�|�|jd
�|�|jd�|||�|�	t
|d�|�	t|d
�|�	t|d�dS)NcSs.|�|jd�t||dg�t||dg�dS)Nr�r&r�)r�r3r")r�r rrr�assert_rest_sz7CFunctionality.test_c_ieee_context.<locals>.assert_restr�`i����r|ryr{�"ii�rPri)rh�IEEEContext�	DECIMAL32�	DECIMAL64�
DECIMAL128r�r$r�r�r�r�r�)r�r
rrrr
rrrr�test_c_ieee_contextWs.


z"CFunctionality.test_c_ieee_contextcCs:tj}|tjtjd�}|�|jtj�|�|jtj�dS)Nr�)rhr'r0�
DecRoundedr��_flags�_trapsr!rrr�test_c_context{szCFunctionality.test_c_contextcCstjtjtjtjtjtjtjtjtj	tj
tjtjtj
tjtjf}|�tjd�|�tjd�|�tjd�|�tjd�t|�D]\}}|�|d|>�q@|�tjtjtjBtjBtjBtjBtj	Btj
B�|�tjtjtjB�|�tjtjtjBtjB�dS)Nrr��ir�)rhr0�DecConversionSyntax�DecDivisionByZero�DecDivisionImpossible�DecDivisionUndefined�DecFpuError�
DecInexact�DecInvalidContext�DecInvalidOperation�DecMallocError�DecFloatOperation�DecOverflowr�DecSubnormal�DecUnderflowr�rrrZIEEE_CONTEXT_MAX_BITSr��DecIEEEInvalidOperationZ	DecErrorsZDecTraps)r��condr�r�rrr�test_constants�sH�
�������	���zCFunctionality.test_constantsN)r�r�r�r��requires_extra_functionalityrrr&rrrrr	Ts
#
r	c@s�eZdZdZdd�Zdd�Zdd�Zdd	�Zd
d�Zdd
�Z	e
dd��Zdd�Ze
dd��Z
dd�Zdd�Zdd�Zdd�Zdd�Ze
dd��Ze
d d!��Zd"d#�Zd$d%�Zd&d'�Zd(d)�Zd*d+�Ze�ej�d,�d-�e�eppe d.�d/d0���Z!d1S)2�	CWhiteboxzWhitebox testing for _decimalcCs�tj}tj}dd}dd}|��1}d|_td�D] }t�||�}t�dd�}||}	||�||�}
|�|	|
�qWd�dS1sEwYdS)Nr1�#�$i@Brr�i�)rhr�rr$rr�rr�)r�r�rr�r�rr�r2r]r�rrrr�test_bignum�s�"�zCWhitebox.test_bignumcCs|�ttjdd�dS)Nr#r)r�r�rhr�r�rrr�test_invalid_construction�sz#CWhitebox.test_invalid_constructioncCsVtj}tj}tj}tj}||���|�||d�Wd�dS1s$wYdS)NZ1e9999999999999999999)rhr�rzr'rr�)r�r�rzr'rrrr�test_c_input_restriction�s�"�z"CWhitebox.test_c_input_restrictioncCs�tj}tj}|��}d|_d|_d|_t|_d|_	d|_
ttD]}d|j|<d|j
|<q d|j|<d|j
|<|��}d}|�||�dS)Nr�rDrr�TaQContext(prec=425000000, rounding=ROUND_HALF_DOWN, Emin=-425000000, Emax=425000000, capitals=0, clamp=1, flags=[Clamped, InvalidOperation, DivisionByZero, Inexact, FloatOperation, Overflow, Rounded, Subnormal, Underflow], traps=[Clamped, InvalidOperation, DivisionByZero, Inexact, FloatOperation, Overflow, Rounded, Subnormal, Underflow]))rhrFrr<r$r�r�rtr%r�r3r�r�r&r�r�)r�rFrrr:rr�rrr�test_c_context_repr�s"


zCWhitebox.test_c_context_reprc	Cs�tj}tj}tj}tj}tj}tj}tj}tjdk}|�}	|�	t
|	jjdd�|�	t
|	j
jdd�|�	t|	jj|�|�	t|	j
j|�|�	tt|	ddg�|�	tt|	ddg�|�	t
t|	dddi�|�	t
t|	dddi�|	j��}
|
|=d	|
d
<|�	t
t|	d|
�|�	t
t|	d|
�|r�dnd}|r�d
nd}dD]}
|�	tt|	|
|�q�|�	tt|	d|�|j	t||d�|j	t||d�|j	t||d�|j	t||dd�|j	t||dd�|j	t||dd�|j	t||dd�|j	t||dd�dD]4}
|�	tt|	|
|d�|�	tt|	|
|d�tjdk�r1|�	tt|	|
|�|�	tt|	|
|d�q�tjdk�r]|�	tt|	d�|d�|�	tt|	d�|d�|�	tt|	d�|d�tjdk�r�|�	tt|	d�d�|�	tt|	d�d�|�	tt|	d�d�|�	tt|	d�d�|�	tt|	d�d�|�	tt|	d�d�dD]5}
|�	tt|	|
d�|�	tt|	|
d�|�	tt|	|
gd ��|�r�|�	tt|	|
d!�|�	tt|	|
d"��q�|�	ttd#t��|�	ttd$t��|�}|�	t|d%�||�dS)&Nr�i!rr�r�r&rr�i�pr�rOrNl�N�Zoiʚ;r�r�rvrz)r�r�r�r�)r$r�r�r�r3�win32r�r�r�i���?ri9�r�r���zwith localcontext("xyz"): passz-with localcontext(context=getcontext()): passr)rhr'rzr}rrrTr,r�r�r�r��__setitem__r&r��__delitem__r�r�r<r�r��platformr�execrf)r�r'rzr}rrrTr,�HAVE_CONFIG_64rr�int_maxZgt_max_emaxr!Z
saved_contextrrr�test_c_context_errors�s�

��������
��zCWhitebox.test_c_context_errorscCs�|�tjtj�|�tjtj�|�tjtj�|�tjtj�|�tjtj�|�tjtj�|�tj	tj	�|�tj
tj
�dSr)r7rhrvr�rrrqrsrurtr(rwr�rrr�test_rounding_strings_internedMsz(CWhitebox.test_rounding_strings_internedc	Cs�tj}tj}tj}tj}tj}tj}tjdk}|�}|rdnd}	|�t	t
|d|	d�|�t	t
|d|	d�tjdkrQ|�t
t
|d|	�|�t
t
|d|	d�dD]3}
|�t	t
||
|	d�|�t	t
||
|	d�tjdkr�|�tt
||
|	�|�tt
||
|	d�qS|�t
t
|dd	�|�t
t
|dd�|�tt
|dgd
��|r�|�t
t
|dd�|�t
t
|dd�dD]}
|�tt
||
d
�|�tt
||
d�q�dS)Nr�rOrN�_allcrr�r�r/)rrrr�r0r1rr�)rhr'rzr}rrTr,r�r�r�r�r�r4r�r�)r�r'rzr}rrTr,r6rr7r!rrr�test_c_context_errors_extraXs>


��z%CWhitebox.test_c_context_errors_extracCstj}tj}tj}tj}tj}tj}|��}d|_t	|_
d|_d|_d|_
d|_|�|jd�|�|j
t	�|�|jd�|�|jd�|�|j
d�|�|jd�|�|��d�|�|��d�tjdkr�|�d	�|�d	�|�d
�|�|jd	�|�|jd	�|�|jd
�dSdS)Nri�iH�r�ri'�i�r�rhri)rhrFryr�r|r~rr<r$rur%r�r�r�r3r�ZEtinyZEtopr�r�r�r�)r�rFryr�r|r~rrrrr�test_c_valid_context�s:



�zCWhitebox.test_c_valid_contextcCs4tj}|��}|�|jd�d|_|�|jd�dS)Nr�r)rhrFr<r�r:)r�rFrrrr�test_c_valid_context_extra�s
z$CWhitebox.test_c_valid_context_extracCstj}tj}tj}tj}tj}tjdkrdnd}|��\}d|j|<|�||d�j	|d�|�||d�j	|�|�||d�j	t
|d��|�tj|d�j	t
|d��|�t|d�j	|d�|�t|d�j	|d�Wd�dS1szwYdS)	Nr�rOrNTr�r�r/r�)rhr�rzrr�rmr�r&r�r�r�r�)r�r�rzrr�rmr7rrrr�test_c_round�s6
��
����"�zCWhitebox.test_c_roundcCs�tj}tjdk}|�t|d�jdgd�|�t|d�jdd�|�t|d�jg�|�t|d�jd�|r7dnd}|�t|d�jd	|�dS)
Nr�r�z=10.10r#z<>=10.10rOrNr�z=%d.1)rhr�r�r�r�r�r�)r�r�r6�maxsizerrr�
test_c_format�s
�zCWhitebox.test_c_formatcCsftj}tj}tj}|d�}|�|��d�|�t|jd�|�t|jdd�|�t|jd�|�|��d�|�t|jd�|�t|jdd�|�t|jd�|�|�	�d�|�t|j	d�|�t|j	dd�|�t|j	d�|��6}|d��t
�}|�||d��|d��	t
�}|�||d��d|j|<|�||d�j	t
�Wd�dS1s�wYdS)Nr1r�r�z99999999999999999999999999.9Z100000000000000000000000000Tz999.9)rhr�r|rr�r�r�r�r^r_rvr&)r�r�r|rr�rrrr�test_c_integral�s0
"�zCWhitebox.test_c_integralc	CsTtj}tj}tj}tj}tj}|�|d���d�|�t	t
|d�dd�|�t	|d�jdd�|�t	|d�jd	dd�|�t	|d
�j
|d�g�|�t	|d
�j
|d�|��|�t	|d
�j
|d�d�|�t	|d
�j
|d�td
�|���}|��|�t	|j|d�dd�|�t	|jd�|�t	|jd�|�t	|jdddd�|�t	|jdd	dd�|�t|�|d���d�|�|��d�d|j|<|�||d�jd�|�||jdd�|�|j|�|��d|j|<|�||d�jd�|�||jdd�|�|j|�d|j|<d|_|�|t
|d
�dd�Wd�dS1�s#wYdS)Nz9.99e10z99.9E+9r�r�r�r#r�rr$r�z	1e-100000r1r�rDr-Z200Tri�)rhr�rzr{rTrr�r]r�r�r�r8r[r�rvr�rAr
rEr�r�rr&rqrr�r�r$)r�r�rzr{rTrrrrr�test_c_funcs�s^����


$�zCWhitebox.test_c_funcscCs�tj}tj}|d�}dD]}t||�}|jt|dd�|jt|ddd�qdD]}t||�}|jt|dd�|jt|ddd�q'|jt|jdgd�|jt|jigd�|�t|jgg�|jt|jdgd�|jt|jigd�|�t|jgg�|jt|jdgd�|jt|jigd�|�t|jgg�|jt|j	dddd�|jt|j	ddddd�|jt|j
dgdd�|jt|j
dgdd	�|�t|j
dgg�|�}|jt|jdddd
�|jt|jdddd
�|jt|jdddd
�dS)NZ10001111111)
r�rKrOr�r�r�rDrSrTrYr8r\r]r�r�)r2r9r5rWr�rQr�rRrZr�r�r�r�r�r�r�)�mod)rhr�r'rr�r�r�r^r_r�r�rZ)r�r�r'r�r!�funcrrrr�test_va_args_exceptions2s:

z!CWhitebox.test_va_args_exceptionscCsL|�tjjtjtjBtjBtjBtjB�|�tj	jtjtjBtjB�dSr)
r�rhr�rr$rr!r#r0rFr�rrr�test_c_context_templates^s����z"CWhitebox.test_c_context_templatesc&stj}tj}tj}tj}tj}tj}tj}tj}tj	}	tj
}
tj}tj}tj
}
tj}�fdd�}|��}��||jv�|��|j��D]}d|j|<qE|j��D]}��|�qR|��|j��D]	\}}��|�qc��|j�|����|j�d�d���|j�dd�d���t|jjddd���t|j�t|j��t�|j�}t�|j�}|j� �}|�!�||_"��|j|�|��|
|_#��|j|�|�!�|j��}d||<||_|||j�|��|j��}d||<||_|||j�|tj|	tj$|
tj%|tj&|tj'|tj(|tj)|tj*|tji	}tj+tj,tj-tj.tj
tj/tj0g}tt1t�}t2|�D]�}t2|�D]�}t3D]�}t4�5t1t|�}t4�5t1t|�}t4�6dd�}t4�6d	d
�}t4�6d
d�}t4�6d
d�} t4�6d
d�}!t4�6d
d�}"||||||!| t7|�t7|�d�}��|j8|���|j9|���|j:|���|j;|���|j<|!���|j=| �d
}#|D]	}$|#||$O}#�q���|j"|#�d
}#|D]	}$|#||$O}#�qLj�|j#|#��q>�q:�q4|D]}%|%|_"��|j"|@�|||j��q�|D]}%|%|_#��|j#|@�|||j��q�dS)
Ncs4|D]}||kr��||�q��||�qdSr)rr3)r�Zsignal_dictr:r�rr�assertIsExclusivelySets
�z<CWhitebox.test_c_signal_dict.<locals>.assertIsExclusivelySetTr�rr�r�r�i���rr�r�)>rhr'rFrzrr{r}rr�r~r|ryr0rr$r<rr&r�r�valuesr[r3r�r�r7r�r�r�r�r��	getsizeofr�r�rrrrr"r#r!rr rrrrrrr�rrr��samplerrWr$r%r�r�r�r3)&r�r'rFrzrr{r}rr�r~r|ryr0rr$rGrr�r�rrZ
IntSignalsZIntCondZlimrJr�r�r�r&r$rpror3rZcrr�r�r%rr�r�test_c_signal_dictjs�


��

����zCWhitebox.test_c_signal_dictcs�tj�zddlm}Wnty|�d�Ynwdd�}d�fdd�	}d	|gd
��d	d�}d|gd
��d	d�}d|gd
��dd�}|dkrP|�t|d|d�|�t|d|d�|�t|d|d�dS)Nrr�r�cSsd�dd�|D��S)NrcSr�rr�r�rrrr��r�zJCWhitebox.test_invalid_override.<locals>.make_grouping.<locals>.<listcomp>)r�r�rrrr��sz6CWhitebox.test_invalid_override.<locals>.make_groupingr	cs�|��||�Sr)r�r�ryrrr���z0CWhitebox.test_invalid_override.<locals>.get_fmtr�)�rMrr�Zxxxxxr�r�Zyyyyy�r�r�r�)rhr�r�r�r�r�r�r�)r�r�r�r�Zinvalid_groupingZinvalid_dotZinvalid_seprryr�test_invalid_override�s4�
�
�
�
�zCWhitebox.test_invalid_overridecCs�tj}tj}tj}|��D}d|j|<dtj}|�|||�dtjd}|�|||�dtj}|�|||�dtjd}|�|||�Wd�dS1sSwYdS)NTz0e%dr�z1e%d)rhr�rrzr&r�r?r�r�rrr�test_exact_conversions


"�zCWhitebox.test_exact_conversioncCs�tj}tj}tj}tj}tj}|���}d|j|<d|j|<d|j|<ddtjf}|�	t
|�|��d�|�|||�ddtjf}|�||j|�|�|||�ddtjdf}|�	t
|�|��d�|�|||�ddtjdf}|�||j|�|�|||�ddtjdf}|�t
|j|�|�t
||�ddtjdf}|�t
|j|�|�t
||�d}|�	t
||��d	�d
}|�	t
||��d	�d}|�	t
||��d�Wd�dS1s�wYdS)
NTr�rz
-0E+999999)rr�r�z-0E-1000007r�r�r�)r�rr�)r�r�r�z-sNaN1)rhr�rrzr}r�r&r�r?r�r�r�r�r�)r�r�rrzr}r�rr�rrr�test_from_tuple-sD


"�zCWhitebox.test_from_tuplecCs�tj}tjdk}|�|d���d�|r.|dd���}|dd���}|�||d�dS|dd���}|dd���}|�||d	�dS)
Nr�rr1rLi�r-����r!)rhr�r�rQ�
__sizeof__r�)r�r�r6r�rrrr�test_sizeof]s
zCWhitebox.test_sizeofcsztj}Gdd�dt�}Gdd�dt�}Gdd�dt��G�fdd�dt�}|||fD]}|�|�|d	��|�d	��q*dS)
Nc@seZdZdd�Zdd�ZdS)z<CWhitebox.test_internal_use_of_overridden_methods.<locals>.XcSr��Nr�rr�rrrr�pr�zMCWhitebox.test_internal_use_of_overridden_methods.<locals>.X.as_integer_ratiocS�|Srrr�rrrr�rr�zDCWhitebox.test_internal_use_of_overridden_methods.<locals>.X.__abs__N�r�r�r�r�r�rrrr�XosrYc@r�)z<CWhitebox.test_internal_use_of_overridden_methods.<locals>.YcS�
dgdS�Nr�rDrr�rrrr�vr�zDCWhitebox.test_internal_use_of_overridden_methods.<locals>.Y.__abs__N)r�r�r�r�rrrr�Yur�r\c@r�)z<CWhitebox.test_internal_use_of_overridden_methods.<locals>.IcSrZr[rr�rrr�
bit_lengthzr�zGCWhitebox.test_internal_use_of_overridden_methods.<locals>.I.bit_lengthN)r�r�r�r]rrrr�Iyr�r^cs eZdZ�fdd�Zdd�ZdS)z<CWhitebox.test_internal_use_of_overridden_methods.<locals>.Zcs�d��d�fSrVrr��r^rrr�~rLzMCWhitebox.test_internal_use_of_overridden_methods.<locals>.Z.as_integer_ratiocSrWrrr�rrrr��r�zDCWhitebox.test_internal_use_of_overridden_methods.<locals>.Z.__abs__NrXrr_rr�Z}sr`gfffffFY@)rhr�rHr�r�r�)r�r�rYr\r`rrr_r�'test_internal_use_of_overridden_methodsks��z1CWhitebox.test_internal_use_of_overridden_methodsZaixzEAIX: default ulimit: test is flaky because of extreme over-allocationzLsanitizer defaults to crashing instead of returning NULL for malloc failure.cCsZgd�}tj}tj}tj}|tjtjtjd�}||���|�|d���d�|�|d��	�d�|�|d��
�d�|�|d��
�d�|�|dd��
�d�|�|d	���d
�|�|d���d�|�|d���|d
��|�t
|d�d�d�|�|d�dd�|�|d�dd�|�|d�d|d��Wd�dS1s�wYdS)N)	rDrSrTr5rWrarUr�r�)r$r�r�rr�rYr�r1��l�9V�r!Z40E9z2.0E+5r$)r$r�i�rz0.0025)rhr�r'rr�rlr�r�r�r�r�r�r\r�)r�ZMaxContextSkipr�r'rZ
maxcontextrrr�test_maxcontext_exact_arith�s&

"�z%CWhitebox.test_maxcontext_exact_arithN)"r�r�r�r�r+r,r-r.r8r9r'r;r<r=r>r@rArBrErFrKrOrPrQrUrar��skipIfr�r4r��MEMORY_SANITIZER�ADDRESS_SANITIZERrdrrrrr(�sBe
*&
;,

%0�r(ztest requires C versionc@r�)�
SignatureTestzFunction signaturesc
Cs�tt�D]f}|�d�rqtt|�}tt|�}|dks#|dks#t�|�rjt�|�}t�|�}t|j	�
��}dd�|j	�
�D�}|j||d|d�dd�|j	��D�}d	d�|j	�
�D�}	|d
krj|j||	d|d�qdS)Nr�r�r'cSsg|]	}|�d�s|�qS)r�r�r�rrrr��s
�z5SignatureTest.test_inspect_module.<locals>.<listcomp>�parameter name mismatch in %s��msgcS�g|]}|j�qSr��kindr�rrrr���cSs$g|]}|d�d�s|dj�qS)rr�r�)r�rnr�rrrr��s�r,�parameter kind mismatch in %s)r�r�r�rrh�inspect�
isfunction�	signaturerW�
parametersrr�rHr[)
r�r!�p_func�c_func�p_sig�c_sig�c_names�p_names�c_kind�p_kindrrr�test_inspect_module�s.


�

����z!SignatureTest.test_inspect_modulecstjj�tjj�tt�d�t�d�t�d�t�d�t�d�t�d�t�d�t�d�t�d�t�d�ddtjt��d�tt�d�t�d�t�d�t�d�t�d�t�d�t�d�ddtjt��d�i����fdd��dd	�������fd
d�}|d�|d
�dS)Nr�r/rG)rpr
r�rr�r2r]rr�rY�numr�r%r )rpr
r2r]rr�rYr~r�r%r csng}i}|j��D])\}}|dkrq	|j�kr!|��||�q	|j�kr/�||||<q	td��||fS)Nr�zunexpected parameter kind)rtr[rnr�r)�moduler:r��kwargs�nameZparam)�POS�POS_KWD�pdictrr�mkargs�s


z0SignatureTest.test_inspect_types.<locals>.mkargscSs(|dkrdS|dkrdS|dkrdS|S)zwThe C Context docstrings use 'x' in order to prevent confusion
               with the article 'a' in the descriptions.r�r2rr]r�rr)rrrr�tr�sz,SignatureTest.test_inspect_types.<locals>.trc	s�tt|�}tt|�}t|�D]�}|�d�rqt||�}t||�}t�|�r�t�|�}t�|�}t|j	�
��}�fdd�|j	�
�D�}	�j|	|d|d�dd�|j	��D�}
dd�|j	��D�}��
|
d����
|d��|d	kr��j|d
d�|
d
d�d|d�n�jt|�t|
�d|d��t|�\}}
zt|d�|�|i|
��Wnty�td
|||
f��w�t|�\}}
zt|d�|�|i|
��Wqty�td
|||
f��wqdS)Nr�csg|]}�|��qSrrr�)r�rrr�r�zBSignatureTest.test_inspect_types.<locals>.doit.<locals>.<listcomp>rirjcSrlrrmr�rrrr�rocSrlrrmr�rrrr�rorr�r�rpr#zinvalid signature for %s: %s %s)rr�rhr�r�rqrrrsrWrtrr�rHr7r�r�r)�tyZp_typeZc_typer!rurvrwrxrzryr|r{r��kwds)r�r�r�r�r�rrr�sP







�������z.SignatureTest.test_inspect_types.<locals>.doitr�r')	rqZ_ParameterKindZPOSITIONAL_ONLYZPOSITIONAL_OR_KEYWORDrhr�rurTr�)r�r�r)r�r�r�r�r�r�r�test_inspect_types�sF
�
��
/z SignatureTest.test_inspect_typesN)r�r�r�r�r}r�rrrrrh�srhr�r�c
Cs�tt�tt�|dur|ntd�a|a|durt}nttg}t	�
t�D]6}d|vs/|�d�r0q$|�
d�\}}|dur@||vr@q$|fdd�}ttd||�ttd||�~~~~q$zVt|�|dur�dd	lm}	tjd}
tr}ttjd<tt||	d
�ttjd<tt|�|
tjd<Wtr�t�tt�t�tt�ts�t�dt�ttjdur�td��dStr�t�tt�t�tt�ts�t�dt�ttjdur�td��w)
z� Execute the tests.

    Runs all arithmetic tests if arith is True or if the "decimal" resource
    is enabled in regrtest.py
    Nrz.decTestr�cSs|�t|�Sr)r��	directory)r�r�rrrr�osztest_main.<locals>.<lambda>Ztest_r)�IGNORE_EXCEPTION_DETAIL)Zoptionflagsz*C tests skipped: no module named _decimal.zGInternal error: unbalanced number of changes to sys.modules['decimal'].)r.rhr�rr�r��	all_testsr�r��os�listdirr�r�r�r�r�doctestr�r�r�rr,�ORIGINAL_CONTEXT�warnings�warn�UserWarning�orig_sys_decimalr)�arith�verbose�
todo_tests�debugZtest_classes�filename�head�tailZtesterr�r�rrr�	test_mainTs\





�����
r�z:test_decimal.py [--debug] [{--skip | test1 [test2 [...]]}]z--debugz-d�
store_truez2shows the test number and context before each test)�action�helpz--skipz-sz%skip over 90% of the arithmetic tests)r�r�)r�r�r�r�)NNNN)�r�r�r�r�rr�r�r<r�r�r�Ztest.supportrrrrrrrr	r
rZtest.support.import_helperrr
r�rqrHZ	sysconfigZget_config_varZ_cflagsZ_config_argsrfrgr4rhr�rr�Z
cfractionsr�Z
pfractionsrr�rTr�rr+ryr~r|rr�r}r{rzrr�r"rvrrrqrsrurtr(rwrr�r.ZTESTDATADIRr��argvr��__file__�path�dirname�curdirZtestdir�sepr��isdirr�r��hasattrZEXTRA_FUNCTIONALITYZ
skipUnlessr'reZskip_if_extra_functionalityZTestCaser1r�r�r�rarbrcr�r�r�rrrr+r,r;r@rBrMrNrOr�r�r�rrrrjrkrlr�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r	r(rhr��insertr�ZoptparseZOptionParserrZ
add_option�
parse_args�optr��skipr�rrrr�<module>s	 ��



������	�
��eYM)',-6Xo~
P>mU
����������������	�	�
�
�����
�
���������

7
�
© 2025 GrazzMean