Server : LiteSpeed
System : Linux server51.dnsbootclub.com 4.18.0-553.62.1.lve.el8.x86_64 #1 SMP Mon Jul 21 17:50:35 UTC 2025 x86_64
User : nandedex ( 1060)
PHP Version : 8.1.33
Disable Function : NONE
Directory :  /opt/cppython/lib/python3.8/test/__pycache__/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]


Current File : //opt/cppython/lib/python3.8/test/__pycache__/test_decimal.cpython-38.opt-2.pyc
U

>��g�<�"@s ddlZddlZddlZddlZddlZddlZddlZddlZddlZddl	Z	ddl
mZmZm
Z
mZmZddl
mZmZmZmZddlZddlZddlZeddgd�Zeddgd�ZejdZeddgd�Zeejd<eddgd�Zeejd<eeeeiZeejd<ee�r"ee��j �!��ndeee��j �!��iZ"ee�rjej#ej$ej%ej&ej'ej(ej)ej*ej+g	ndeej#ej$ej%ej&ej'ej(ej)ej*ej+g	iZ,d	d
�Z-ej.Z.ej/Z/ej0Z0ej1Z1ej2Z2ej3Z3ej4Z4ej5Z5e.e/e0e1e2e3e4e5gZ6ee�r�e����ndee����iZ7dd�Z8d
Z9e:dk�r,ej;dZ<ne=Z<ej>�?e<��pBej@ZAeAejBe9ejBZCej>�DeC�aEdZFeGed��rzdndZHe�IeHd�ZJe�KeHd�ZLGdd�dejM�ZNGdd�deN�ZOGdd�deN�ZPGdd�dejM�ZQGdd�deQ�ZRGdd�deQ�ZSGd d!�d!ejM�ZTGd"d#�d#eT�ZUGd$d%�d%eT�ZVGd&d'�d'ejM�ZWGd(d)�d)eW�ZXGd*d+�d+eW�ZYGd,d-�d-ejM�ZZGd.d/�d/eZ�Z[Gd0d1�d1eZ�Z\d2d3�Z]d4d5�Z^Gd6d7�d7ejM�Z_Gd8d9�d9e_�Z`Gd:d;�d;e_�ZaGd<d=�d=ejM�ZbGd>d?�d?eb�ZcGd@dA�dAeb�ZdGdBdC�dCejM�ZeGdDdE�dEee�ZfGdFdG�dGee�ZgGdHdI�dIejM�ZhGdJdK�dKeh�ZiGdLdM�dMeh�ZjGdNdO�dOejM�ZkGdPdQ�dQek�ZlGdRdS�dSek�ZmGdTdU�dUejM�ZnGdVdW�dWen�ZoGdXdY�dYen�ZpGdZd[�d[ejM�ZqGd\d]�d]eq�ZrGd^d_�d_eq�ZsGd`da�daejM�ZtGdbdc�dcet�ZuGddde�deet�ZvGdfdg�dgejM�ZwGdhdi�diew�ZxGdjdk�dkew�ZyeLGdldm�dmejM��ZzGdndo�doejM�Z{Gdpdq�dqe{�Z|Gdrds�dse{�Z}Gdtdu�duejM�Z~Gdvdw�dwejM�ZGdxdy�dyejM�Z�Gdzd{�d{ejM�Z�ee�Ied|�Gd}d~�d~ejM���Z�eReSeUeVeXeYe[e\e`eaecedefegeiejelemeoepereseuevexeye|e}e�e~e�eeOePg"Z�e�sre�ddd��Z�ne���dez�e���de��d�d�d��Z�e:dk�rddl�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��n&e��re�dde�e�j�d��ne�ddd��dS)��N)�run_unittest�run_doctest�is_resource_enabled�requires_IEEE_754�requires_docstrings)�import_fresh_module�
TestFailed�run_with_locale�cpython_only�decimalZ_decimal)Zfresh)Zblocked�	fractionscs,t||��|�t��fdd��D���dS)Nc3s(|] }|�kr�|n�|VqdS�N���.0�s��d�expectedr�0/opt/cppython/lib/python3.8/test/test_decimal.py�	<genexpr>Ksz!assert_signals.<locals>.<genexpr>)�getattr�
assertTrue�all)�cls�context�attrrrrr�assert_signalsIs
rcCs2|sdS|jdtt�t|d�d�}|�|�dS)N�	r)�prec�rounding�traps)�Context�ROUND_HALF_EVEN�dict�fromkeys�Signals�
setcontext)�mZDefaultTestContextrrr�initbs�r)Zdecimaltestdata�__main__F�
DecClampedTz.test requires build with -DEXTRA_FUNCTIONALITYztest requires regular buildc@sleZdZdd�Zdd�Zdd�Zdd�Zd	d
�Zdd�Zd
d�Z	dd�Z
dd�Zdd�Zdd�Z
dd�ZdS)�IBMTestCasesc&Cs�|j��|_|j��|_dg|_tdddddddd	d
ddd
ddddddddddddg�|_|jtkr�|j�d�|j�d�|j�d�|j�d�|j�d�|j�d�|j�d �|j�d!�|j	|j
|j|j|j
d"�|_d#d$d%d&d'd(d)d*d+d,d-d.d/d0d1d2d3d4d5d6d7d8d9d:d;d<d=d>d?d@dAdBdCdDdEdFdGdH�%|_ttttttttdI�|_|jj|jj|jj|jj|jj|jj|jj|jj|jj|jj|jj|jj dJ�|_!dK|_"dS)LN�#Zscbx164Zscbx165Zexpx901Zexpx902Zexpx903Zexpx905Zlnx901Zlnx902Zlnx903Zlnx905Zlogx901Zlogx902Zlogx903Zlogx905Zpowx1183Zpowx1184Zpowx4001Zpowx4002Zpowx4003Zpowx4005Zpowx4008Zpowx4010Zpowx4012Zpowx4014Zpwsx803Zpwsx805Zpowx4302Zpowx4303Zpowx4342Zpowx4343Zpwmx325Zpwmx326)Z	precisionr ZmaxexponentZminexponent�clamp�logical_and�_apply�number_class�compare_signal�
compare_total�compare_total_mag�copy_decimal�copy_abs�copy_negate�	copy_sign�
divide_int�logical_invert�is_canonical�	is_finite�is_infinite�is_nan�	is_normal�is_qnan�	is_signed�is_snan�is_subnormal�is_zero�max_mag�min_mag�
next_minus�	next_plus�next_toward�
logical_or�	normalize�remainder_near�same_quantum�sqrt�
to_eng_string�to_integral_value�to_integral_exact�
to_sci_string�logical_xor)%�andZapply�classZ
comparesigZcomparetotalZ
comparetotmag�copyZcopyabsZ
copynegate�copysignZ	divideint�invertZiscanonical�isfiniteZ
isinfinite�isnanZisnormalZisqnanZissignedZissnanZissubnormalZiszeroZmaxmagZminmagZ	nextminusZnextplusZ
nexttoward�or�reduceZ
remaindernearZsamequantumZ
squarerootZtoengZ
tointegralZtointegralxZtosci�xor)ZceilingZdown�floorZ	half_downZ	half_evenZhalf_upZupZ05up)ZclampedZconversion_syntaxZdivision_by_zeroZdivision_impossibleZdivision_undefinedZinexactZinvalid_contextZinvalid_operationZoverflowZroundedZ	subnormalZ	underflow)r;r<r=r>r?r@rArBrCrDrM)#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.setUpcCsX|jtkrF|jjdkrF|j�d�|j�d�|j�d�|j�|�S|j�||�SdS)N�@�Ti���?i�9�)	rrc�MAX_EMAXr_�_unsafe_setprec�_unsafe_setemax�_unsafe_setemin�create_decimal�Decimal)r�vrrrr�read_unlimitedszIBMTestCases.read_unlimitedcCs�tr
tj�t|��t}|D]h}|�dd��dd�}z|�|�}Wq|jjk
r~}z|�d|j	j
d|�W5d}~XYqXqW5QRXdS)Nz
��
zException "z" raised on line )�
skip_expected�unittestZSkipTest�open�replace�	eval_liner�DecimalException�fail�	__class__�__name__)r�file�f�line�t�	exceptionrrr�	eval_files
zIBMTestCases.eval_filecCs�|�d�dkrX|dd�dkrX|�d�sX|�d�dd|�d�d�d�d��}n|�d�d��}|jD]}|�|�dkrpdSqp|s�dSd|kr�|�|�S|�|�SdS)	Nz -> r��--z  --�->��:)�find�
startswith�split�stripr`�eval_directive�
eval_equation)rr�ignorerrrr�,s(�


zIBMTestCases.eval_linecCsldd�|�d�D�\}}|dkr,|j|}n"zt|�}Wntk
rLYnX|j�|dd��}||�dS)Ncss|]}|����VqdSr
)r��lower�r�xrrrr?sz.IBMTestCases.eval_directive.<locals>.<genexpr>r�r cWsdSr
r)�argsrrr�<lambda>H�z-IBMTestCases.eval_directive.<locals>.<lambda>)r�rs�int�
ValueErrorrj�get)rr�funct�valuerrrr�>szIBMTestCases.eval_directivecs�tst��dkrdS�j��zt|�d�}|d����}|d}trTtd|dd�|d��}|dd�}|d����}|d}|dd�}Wn"t	t
tfk
r��jj
�YnXd	d
�}	|�jkr�dS�j�||�}
|
dkr�dSt�j|
�}g}d}d}
�fd
d�|D��t�jD]}d�jj|<�q�D]}d�jj|<�q2t|�D�]&\}}|�d�ddk�rtd|
}
|
�r�|d|}�qNn||}d}|	|�}|
dk�r\t�rN�D]�}d�jj|<z|�j�|��WnR|k
�r�YnPt�jk
�r*}z��d|||f�W5d}~XYnX��d||f�d�jj|<�q��j�|�}n��|�j�}|�|��qN|	|�}t�r�|
dk�r�D]�}d�jj|<z||�WnR|k
�r�YnPt�jk
�r}z��d|||f�W5d}~XYnX��d||f�d�jj|<�q��fdd�t�jD�}|D]�}d�jj|<z||�WnV|k
�rtYnTt�jk
�r�}z��dt|�||f�W5d}~XYnX��d||f��qB|D]}d�jj|<�q�t�r�td�j�z,t||��}|
�jk�r ttt |���}WnRt�jk
�r^}z��d||f�W5d}~XYntd|��YnX��!�}|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�	FixQuotes_sz-IBMTestCases.eval_equation.<locals>.FixQuotesZrescaler�csg|]}�j|���qSr)r|r�r�r~rr�
<listcomp>osz.IBMTestCases.eval_equation.<locals>.<listcomp>r�)rRrOz Raised %s in %s when %s disabledzDid not raise %s in %scsg|]}|�kr|�qSrr�r�e)�theirexceptionsrrr��szRaised %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�
IndexErrorrrurbrkr�rr&r!�	enumerate�count�EXTENDEDERRORTESTr�r�r��append�OrderedSignals�type�strr}r��eval�
getexceptions�sort�repr�assertEqual)rrZSides�L�idr�Zvalstemp�ans�
exceptionsr�ZfnameZvalsZconglomerate�quoter��ir�r��errorr�Zordered_errors�resultZmyexceptionsr)rr�rr�Ks�



���"
��zIBMTestCases.eval_equationcs�fdd�t�jD�S)Ncsg|]}�jj|r|�qSr)r�flagsr�r~rrr��sz.IBMTestCases.getexceptions.<locals>.<listcomp>)r&rr~rr~rr��szIBMTestCases.getexceptionscCs0|jtkr$|jjdkr$|j�|�n||j_dS�Nr�)rrc�MAX_PRECrr�r)rrrrrre�szIBMTestCases.change_precisioncCs||j_dSr
)rr )rr rrrrf�sz#IBMTestCases.change_rounding_methodcCs0|jtkr$|jjdkr$|j�|�n||j_dSr�)rrcr�rr��Emin�r�exprrrrh�sz IBMTestCases.change_min_exponentcCs0|jtkr$|jjdkr$|j�|�n||j_dSr�)rrcr�rr��Emaxr�rrrrg�sz IBMTestCases.change_max_exponentcCs||j_dSr
)rr.)rr.rrrri�szIBMTestCases.change_clampN)r��
__module__�__qualname__r�r�r�r�r�r�r�rerfrhrgrirrrrr,s
r,c@seZdZeZdS)�
CIBMTestCasesN�r�r�r�rcrrrrrr��sr�c@seZdZeZdS)�PyIBMTestCasesN�r�r�r��Prrrrrr��sr�c@s|eZdZdd�Zdd�Zdd�Zdd�Zed	d
��Zdd�Z	d
d�Z
dd�Zdd�Ze
dd��Zdd�Zdd�Zdd�ZdS)�ExplicitConstructionTestcCs|jj}|�|�|d��dS)N�0�rr�r��rr�rrr�test_explicit_empty�sz,ExplicitConstructionTest.test_explicit_emptycCs|jj}|�t|d�dSr
)rr��assertRaisesr�r�rrr�test_explicit_from_None�sz0ExplicitConstructionTest.test_explicit_from_NonecCs�|jj}|d�}|�t|�d�|d�}|�t|�d�|d�}|�t|�d�|d�}|�t|�d�tdd	�D]J}d
D]@}tdd�D]0}|d
||}||�}|�t|�t|��q�qzqrdS)N�-�45�{e��	500000123�����-45rr�� ����r�����r�)rr�r�r��range)rr�r�n�signr�r�rrr�test_explicit_from_int�sz/ExplicitConstructionTest.test_explicit_from_intc	Cs�|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�q�q�|���}d|j|<|�||d�|�t|ddd�|�||d�|�||d�|�||d�|�||d�|�||d�|�||d�W5QRXdS)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)r�r�� u z	9.311E+28T�xyz�1234r��yu1 2 3u 1 2 ru  z123z1_2_3)	rr�ru�localcontextr�r�r!r�r�)rr�rurZlead�trail�crrr�test_explicit_from_strings8�
z2ExplicitConstructionTest.test_explicit_from_stringcCsRddl}|jj}|j��}|�d�}|�t||��d�|�t|�|��d�dS)Nr�9.999999)�	_testcapirr�r"�unicode_legacy_stringr�r�r�)rrr�rrrrr�test_from_legacy_stringsGs

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�)�r�rr��r�rr��r���r��r��	rrrrr�rr�rr����-4.34913534E-17)rr�F�Infinity)r��rrrrr�)�rr�)�rr�r�rr�)r�rzwrong!)r�rr)r�r�1)r�rr�)r�)rrrNr�r�)r�)r���rrr�r�)r�)r�
rrr�r�)r�)rrr�ar�r�)rr�r�r�r�r��rr�rrrr�test_explicit_from_tuplesQs.z2ExplicitConstructionTest.test_explicit_from_tuplescCs�|jj}|ddgdg�}|�t|�d�|ddddddddddg	dg�}|�t|�d	�|dd
dg�}|�t|�d	�|ddddddddddg	df�}|�t|�d	�dS)Nrr�r�rrrr�rrr�rr�r�r�r#rrr�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�r�r�r�rr�r%�rr�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]2}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�floatr@r=r�r��expovariate)rr��rr�r�rrr�test_explicit_from_float�s0
�
�
�
�
�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]0}|�	|�}|�t||��|�t|�|��qbd|_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)"Nrr���in�z457E+2Z456789z4.57E+5z3.14
r�rrz	-4.35E-17r�r�z5.00E+8�T)	l����l����l����i�r��l��������z0E-017z0E-17r��-Infr1�NaN123r)r�rrrZ5678z 1234Z12_34ZNaN12345F)rr�ruryrV�
getcontextrr�r�r�r�r��assertIsInstancer!r�
isinstancer�r�r�)rr�rury�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]6}t
�d
�t
�
�dd}|�|t|�|����q"dS)Nr,z0.1000000000000000055511151231r.r/r0r�rr1r2r3�dr4r5r6r7)rr�r"r�r�r�r�rr8r@r=rr�r�r9)rr�rGr:r�r�rrr�'test_explicit_context_create_from_floats0

����z@ExplicitConstructionTest.test_explicit_context_create_from_floatcCs>|jj}dddd�}|��D]\}}|�t||��|�qdS)Nrz	0.0000372z-NaN2400)u1u٠.٠٣٧٢e-٣u-nan౨౪౦౦)rr��itemsr�r�)rr��test_values�inputrrrr�test_unicode_digits3s�z,ExplicitConstructionTest.test_unicode_digitsN)r�r�r�r�r�r�r	r
r
r$r&r)r+rr;rHrJrNrrrrr��s8
	+
Yr�c@seZdZeZdS)�CExplicitConstructionTestNr�rrrrrO>srOc@seZdZeZdS)�PyExplicitConstructionTestNr�rrrrrP@srPc@s<eZdZdd�Zdd�Zdd�Zdd�Zd	d
�Zdd�Zd
S)�ImplicitConstructionTestcCs|jj}|�ttdt��dS)NzDecimal(5) + None�rr�r�r�r��localsr�rrr�test_implicit_from_NoneFsz0ImplicitConstructionTest.test_implicit_from_NonecCs<|jj}|�t|d�d�d�|�|d�d|d��dS)Nr�r�Z50l2}rr%r�rrr�test_implicit_from_intJsz/ImplicitConstructionTest.test_implicit_from_intcCs|jj}|�ttdt��dS)NzDecimal(5) + "3"rRr�rrr�test_implicit_from_stringRsz2ImplicitConstructionTest.test_implicit_from_stringcCs|jj}|�ttdt��dS)NzDecimal(5) + 2.2rRr�rrr�test_implicit_from_floatVsz1ImplicitConstructionTest.test_implicit_from_floatcCs(|jj}|�|d�|d�|d��dS)Nr�r��2r�r�rrr�test_implicit_from_DecimalZsz3ImplicitConstructionTest.test_implicit_from_Decimalcs4|jj}Gdd�d�}|�t|�|d��d�|�t|d�|��d�|�td�d�|�td�d	�|�td
�d�|�td�d
�|�td�d�|�td�d�dddddddg}|D]r\}��t|��fdd��t|��fdd��|�td|d�d�d�|�td|d�d�d�q�dS) Nc@sLeZdZdd�Zdd�Zdd�Zdd�Zd	d
�Zdd�Zd
d�Z	dd�Z
dS)z,ImplicitConstructionTest.test_rop.<locals>.EcSsdt|�S)Nzdivmod �r��r�otherrrr�
__divmod__csz7ImplicitConstructionTest.test_rop.<locals>.E.__divmod__cSst|�dS)Nz rdivmodrZr[rrr�__rdivmod__esz8ImplicitConstructionTest.test_rop.<locals>.E.__rdivmod__cSsdt|�S)Nzlt rZr[rrr�__lt__gsz3ImplicitConstructionTest.test_rop.<locals>.E.__lt__cSsdt|�S)Nzgt rZr[rrr�__gt__isz3ImplicitConstructionTest.test_rop.<locals>.E.__gt__cSsdt|�S)Nzle rZr[rrr�__le__ksz3ImplicitConstructionTest.test_rop.<locals>.E.__le__cSsdt|�S)Nzge rZr[rrr�__ge__msz3ImplicitConstructionTest.test_rop.<locals>.E.__ge__cSsdt|�S)Nzeq rZr[rrr�__eq__osz3ImplicitConstructionTest.test_rop.<locals>.E.__eq__cSsdt|�S)Nzne rZr[rrr�__ne__qsz3ImplicitConstructionTest.test_rop.<locals>.E.__ne__N)r�r�r�r]r^r_r`rarbrcrdrrrr�Ebsrer!z	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�rZr[)�loprrr��r�z3ImplicitConstructionTest.test_rop.<locals>.<lambda>cst|��dSryrZr[)�roprrr��r�zE()zDecimal(10)r��10)rr�r��divmodr��setattr)rr�reZoplistZsymr)rzr{r�test_rop^s6�

�
�z!ImplicitConstructionTest.test_ropN)	r�r�r�rTrUrVrWrYrrrrrrQCsrQc@seZdZeZdS)�CImplicitConstructionTestNr�rrrrr��sr�c@seZdZeZdS)�PyImplicitConstructionTestNr�rrrrr��sr�c@s6eZdZdd�Zdd�Zedd�dd��Zd	d
�ZdS)�
FormatTestc�CsT|jj}ddddddddd	d
ddd
ddddddddddddddddddd d!d"d#d$d%d&d'd(d)d*d+d,d-d.d/d0d1d2d3d4d5d6d7d8d9d:d;d<d=d>d?d@dAdBdCdDdEdFdGdHdIdJdKdLdMdNdOdPdQdRdSdTdUdVdWdXdYdZd[d\d]d^d_d`dadbdcdddedfdgdhdidjdkdldmdndodpdqdrdsdtdudvdwdxdydzd{d|d}d~dd�d�d�d�d�g�}|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�r
z9.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�)rrr��0%)rrZ0E0r�)rrz0E-1r�)rrr�r�)rrz0E-3z0.0%)rrz0E-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.16frBr1)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@>10rBz
@-Infinity)z#>5rBr1)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=10r0z
-Infinity)z^16r0z-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�rr)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%rCz
   NaN123%r�s-020)rr�r��formatr�r��
__format__)rr�rL�fmtrr�rrr�test_formatting�s��zFormatTest.test_formattingc	s@�jj�zddlm}Wntk
r6��d�YnX�fdd�}dA��fdd�	}d	|d
d
dg�dd�}d||g�d
d�}d|d
d
dg�dd�}d|ddd|g�dd�}d�d�|d
d
dg�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)Nr�cSsg|]}t|��qSr��chrr�rrrr�?szCFormatTest.test_n_format.<locals>.make_grouping.<locals>.<listcomp>)rrc�join�Zlstr~rr�
make_grouping>sz/FormatTest.test_n_format.<locals>.make_groupingr�cs0�jtkr�|��||�S�|�j||d�SdS)N)�_localeconv)rrcr��r��overrider��r�rrr�get_fmtAs
z)FormatTest.test_n_format.<locals>.get_fmt�.rr���
decimal_point�grouping�
thousands_sepr�r��&r�rr�ris¿zutf-8s´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+8rAZ03nrZ04nZ05nZ01234Z06nZ001234�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�)	rr�r�r��en_US�fr_FR�ru_RUZcrazyZdotsep_widerr�r�
test_n_format6sx������zFormatTest.test_n_format�LC_ALL�ps_AFcCsn|jj}t��d}t��d}|dkr:|�d�|d��|dkrT|�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�)rr�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@seZdZdd�ZdS)z;FormatTest.test_decimal_from_float_argument_type.<locals>.AcSst|�|_dSr
)r��a_type)rr"rrr�__init__�szDFormatTest.test_decimal_from_float_argument_type.<locals>.A.__init__N�r�r�r�r�rrrr�A�sr�g@E@�*)rr��
from_floatr�r�)rr�r"rrr�%test_decimal_from_float_argument_type�s


z0FormatTest.test_decimal_from_float_argument_typeN)r�r�r�r�r�r	r�r�rrrrr��s Y
r�c@seZdZeZdS)�CFormatTestNr�rrrrr��sr�c@seZdZeZdS)�PyFormatTestNr�rrrrr��sr�c@sdeZdZdd�Zdd�Zdd�Zdd�Zd	d
�Zdd�Zd
d�Z	dd�Z
dd�Zdd�Zdd�Z
dS)�ArithmeticOperatorsTestcCs�|jj}|d�}|d�}|�|||d��|�|||d��|d}|�||d��|�t|�t|��d|}|�||d��|�t|�t|��||7}|�||d��|d7}|�||d��dS)N�-11.1�22.2z11.1r�z-6.1�16.1�rr�r�r��rr��d1�d2rrrr�
test_addition�sz%ArithmeticOperatorsTest.test_additioncCs�|jj}|d�}|d�}|�|||d��|�|||d��|d}|�||d��|�t|�t|��d|}|�||d��|�t|�t|��||8}|�||d��|d8}|�||d��dS)	Nr�r�z-33.3z33.3r�z-16.1r�z-38.3r�r�rrr�test_subtraction�sz(ArithmeticOperatorsTest.test_subtractioncCs�|jj}|d�}|d�}|�|||d��|�|||d��|d}|�||d��|�t|�t|��d|}|�||d��|�t|�t|��||9}|�||d��|d9}|�||d��dS)N�-5r�r�r�z-25z-75r�r�rrr�test_multiplication�sz+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.4rz-1.25z-0.8z-0.625r�r�rrr�
test_divisionsz%ArithmeticOperatorsTest.test_divisioncCs�|jj}|d�}|d�}|�|||d��|�|||d��|d}|�||d��|�t|�t|��d|}|�||d��|�t|�t|��||}|�||d��|d}|�||d��dS)N�5r�r�rr�r�r�r�rrr�test_floor_division"sz+ArithmeticOperatorsTest.test_floor_divisioncCs�|jj}|d�}|d�}|�|||d��|�|||d��|d}|�||d��|�t|�t|��d|}|�||d��|�t|�t|��||C}|�||d��|dC}|�||d	��dS)
Nr�r�Z25r�rZ625r�Z16807Z390625r�r�rrr�
test_powering>sz%ArithmeticOperatorsTest.test_poweringcCs�|jj}|d�}|d�}|�|||d��|�|||d��|d}|�||d��|�t|�t|��d|}|�||d��|�t|�t|��||;}|�||d��|d;}|�||d��dS�Nr�r�rrr�r�r�rrr�test_moduleZsz#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�)rr�r�r��p�qrrr�test_floor_div_modulevs$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�sz,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]P\}}
|
|D]>}|||
�}|tj
kr�dnd}|�||d�||j
||
|��q�q�|���}d|j|<|D]R\}}
|D]B}|||
�}|tj
k�rBdnd}|�||d�||j
||
|���q$�q|	D]:\}}
|D]*}|�|tj	||
�|�|tj
||
��q|�qp||	D]&\}}
|
D]}|�||||
��q��q�W5QRXdS)	Nr��sNaNr�r�TFz8expected {0!r} for operator.{1}({2!r}, {3!r}); got {4!r}r�)rr�rur�operator�lt�le�gt�ge�eq�ner'r�r�r!r�)rr�rurr�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�r8r�r�r�r#rrr�test_copy_sign�sz&ArithmeticOperatorsTest.test_copy_signN)r�r�r�r�r�r�r�r�r�r�r�rrrrrrrr��s7r�c@seZdZeZdS)�CArithmeticOperatorsTestNr�rrrrr�src@seZdZeZdS)�PyArithmeticOperatorsTestNr�rrrrr�src
Cs�|jj}|jj}|jj}|jj}|jj}|jj}|jj}|jj}|d�}	|d�}
|	|
}|j	�
�|j��|	|
}|���}
|�
|
j|�|�||
j|	d�|�
|
j|�|��N}|�
|j|�|�
|j|�|�||j|	|d��|�
|j|�~W5QRX|�|
j|�~
W5QRX|�||d��|�||d��|�}|�
|j|�||||fD]}|�|j|��qfdS)Nr�rrr�0.333333333333333333333333)rr�rurvrxr{rwrDr�finish1ra�synchro�waitrr�r��divide�compare�assertFalser�)rr�rurvrxr{rwrDrr��d3�test1�test2�c2�c3�c1�sigrrr�thfunc1�s@

rc
Cs�|jj}|jj}|jj}|jj}|jj}|jj}|jj}|jj}|d�}	|d�}
|	|
}|�}d|_	|	|
}
|���}|�
|j|�|�||j
|d�d�|�
|j|�||��X}|�
|j|�|�|j|�d|j|<|�||j|d�d�|�
|j|�~W5QRX|�|j|�|�|j|�~W5QRX|j��|j��|�||d��|�|
|d	��|�|j|�|�
|j|�||||fD]}|�|j|��q�dS)
Nr�r�Z1e425000000��Tz1e-425000000rz0.333333333333333333)rr�rurvrxr{rwrDrrrr�r��multiplyrr!rrra�finish2r�)rr�rurvrxr{rwrDrr�rrZthiscontextrrrrrrr�thfunc2sH



r$c@seZdZdd�ZdS)�
ThreadingTestcCs�|jj}|jtkr$|jjs$|�d�|j}|j}|j}d|_d|_d|_t�	�|_
t�	�|_t�	�|_tj
t|fd�}tj
t|fd�}|��|��|j��|j��t|jD]}|�|j|�q�|��|��||_||_||_dS)Nzcompiled without threading�r����)�targetr�)r�DefaultContextrc�HAVE_THREADSr�rr�r��	threading�Eventrrr#�Threadrr$�startrr&rr�r�)rr)Z	save_precZ	save_emaxZ	save_eminZth1Zth2rrrr�test_threading6s2





zThreadingTest.test_threadingN)r�r�r�r/rrrrr%0sr%c@seZdZeZdS)�CThreadingTestNr�rrrrr0]sr0c@seZdZeZdS)�PyThreadingTestNr�rrrrr1`sr1c@s�eZdZdd�Zdd�Zdd�Zdd�Zd	d
�Zdd�Zd
d�Z	dd�Z
dd�Zdd�Zdd�Z
dd�Zdd�Zdd�Zdd�Zdd �Zd!d"�Zd#d$�Zd%d&�Zd'S)(�
UsabilityTestcCs|jj}|d�}|d�}|d�}|�||�|�||�|�||�|�||�|�||�|�||�|�||�|�||�|�|d�|�d|�|�|d�|�|d�|�|d�|�|t��|�|t�t	t
|td���}|dd�}t�
|�|��|�||�dS)Nz23.42r��r�rg�����Y@@rI)rr��
assertGreater�assertGreaterEqual�
assertLess�assertLessEqualr��assertNotEqual�object�list�mapr�r��shuffler�)rr��da�db�dcr"�brrr�test_comparison_operatorsfs0
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�r6r7r4r5r8r��rr�r=r>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)NrBrCy�?y�?y@y@�?)	rr�r8r�r'r_�NotImplementedrar`rGrrr�test_decimal_complex_comparison�sz-UsabilityTest.test_decimal_complex_comparisonc
	Cs�|jj}t|jj}|jj}|jj}|jj}tr6tjnd}trDtj	nd}trRtj
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��W5QRXdS)N�ɚ;�6e�ilʈ�r�r�rr�l	��Z��mH;5�Br�Z1ez-1el��!�0QYrFr!i,ri�6l�c(	Z9er/l�g�]�{l�����g�]r0r.i����)rr�rZFractionr"rrurcr��MIN_EMIN�	MIN_ETINYrr6r�r�r8r7r5r4r�r`r'rIr_)
r�Drr"rru�emax�eminZetinyrrrr� test_decimal_fraction_comparison�s@z.UsabilityTest.test_decimal_fraction_comparisoncCsP|jj}|d�}t�|�}|�t|�t|��t�|�}|�t|�t|��dS)Nz43.24)rr�rVr�r��deepcopy)rr�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]}��||�|t|���q؈�|�d��|d����tt�d����	|�d�����	|�d���dddd d!d"d#d$g}|D]*}t
|�}�|�}��||�||���q\|��v}	�d%�}
d&|	_||
�}d'|	_||
�}d(|	_||
�}
��||���||
�d)|	_d*d+}
��|�|
��||
��W5QRXdS),Ncs t|�}|��}��||�|Sr
)�hash�__hash__r�)rr"r@r~rr�hashit�sz.UsabilityTest.test_hash_method.<locals>.hashitr3rr1Znan123�-NaNcs:g|]2}tdd�D]"}dD]}�|d||��qqqS)���r!r�r�)r�)rr(r�r��r�rrr��s�z2UsabilityTest.test_hash_method.<locals>.<listcomp>)r������r��!�=�>�?�@�A�B�-1r3r�z-0.000r�z-0E12�10.0z	-23.00000Z1230E100z
-4.5678E50l��z	1.634E100z
90.697E100z
188.83E100z
1652.9E100Z	56531E100rr�rBr/r�z-.0e1z34.0�2.5z
112390.625z	-0.515625z123456789.1�r!r_�'iLi�)rr�r�extendr�r�r�r�rWrr8r)rrrYrLr�Ztest_stringsrr�rrr�Zh1Zh2Zh3rr�r�test_hash_method�st
���zUsabilityTest.test_hash_methodcCs�|jj}|d�}|d�}d}d}|�t||�|�|�t||�|�|�t||�|�|�t||�|�|�t||�|�|�t||�|�|�t||�|�|�t||�|�dS)N�15.32z28.5r^r=)rr�r'�min�max)rr�r�r��l1�l2rrr�test_min_and_max_methods8sz&UsabilityTest.test_min_and_max_methodscCs(|jj}|�|d��|�|d��dS)Nrz0.372)rr�rrr�rrr�test_as_nonzeroLszUsabilityTest.test_as_nonzerocCs4|jj}|d�}|�t|�d�|�t|�d�dS)NrqzDecimal('15.32'))rr�r�r�r�r#rrr�test_tostring_methodsTsz#UsabilityTest.test_tostring_methodsc
Cs�|jj}|d�}|d�}|�t|�d�|�t|�d�|�t|�d�|�t|�d�dddd	d
ddd
dg	}|D]\}}|�t�||��|�qr|�ttj|d��|�ttj|d��|�ttj|d��|�t	tj|d��|�t	tj|d��dddddddd
dg	}|D] \}}|�t�
||��|��q|�ttj
|d��|�ttj
|d��|�ttj
|d��|�t	tj
|d��|�t	tj
|d��dddddddd
dddddddd g}|D]\}}|�t||��|��q�|�tt|d��|�tt|d��|�tt|d��|�t	t|d��|�t	t|d��d!d"d#d$d%d&d'd(d)d*d+d,d-d.g}|D]&\}}}	|�tt||�|��|	��q\dS)/NZ66rqrir^g�p=
ף.@)z123.00rN)�3.2r)�3.54r)�3.899r)�-2.3r )z-11.0i����)r�r)z-0E3r)�89891211712379812736.1l�{�#'s�{MrZrrCr�rB)ryr)rzr)r{r)r|r)r}l�{�#'s�{M)z-3.5���)r�r)r�r)�-0.5r)�0.5r)r�r�)rlr�)z3.5r)�123.456r~z0E+4)r�r z0E+3)r�rz1E+2)r�r�z1.2E+2)r�rr�)r�r�z123.5)r�r��123.46)r�rr�)r�rz123.4560)z123.455r�r�)z123.445r�z123.44)r�rr�)rBi��r�)ZsNaN314rZNaN314)
rr�r�r�r8�mathr^r�r��
OverflowError�ceil�roundr�)
rr�r�r�Z
test_pairsrr�Ztest_triplesr�r:rrr�test_tonum_methods\s�����z UsabilityTest.test_tonum_methodscCsX|jj}dD]F}t||��}|�t�|��t�d|�}|�||�d�rLdnd�qdS)N)r.Znan1234�-nanz-nan2468r7rig�)	rr�r8rr�rZrWr�r�)rr�rr�r�rrr�test_nan_to_float�szUsabilityTest.test_nan_to_floatcCs,|jj}dD]}||�}|�tt|�qdS)N)�snanz-snanZsnan1357z	-snan1234)rr�r�r�r8)rr�rrrrr�test_snan_to_float�sz UsabilityTest.test_snan_to_floatcCs||jj}|d�}|�|tt|���|d�}|�|tt|���|d�}|�|tt|���|d�}|�|tt|���dS)Nrrrr)rr�r�r�r�r#rrr�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)Nrrr�rrrr)rrr)r�rrrrr�rrr)r�rrr�rrr)r��rrr�%)r�rr�)r�rr�)rr�r�)rr�r�)r�r��N�r�rr�)r�rr�)rrr)r�)rr�r�r�r)r�rr)rr�r��as_tupler#rrr�
test_as_tuple�s6zUsabilityTest.test_as_tuplec		Cs|jj}|�t|j|d��|�t|j|d��|�t|j|d��|�t|j|d��tdd�D]�}td�D]�}dD]�}|d	|||f�}|��}|\}}|�|t�|�|t	�|�|t	�|�
|d
�|�t�
||�d�|�||�||�|�qvqnqbdS)Nr/r0r�Zsnan123r~r���)rfriz%s%dE%drr�)rr�r�r��as_integer_ratior�r�rE�tupler�r4r�r��gcd)	rr�r�Zcoeffr�rZpqr�r�rrr�test_as_integer_ratios:����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�	MyDecimal8sr�r�r��1.0r)	rr�r'r�rsrVr�rUr)rr�r�r�r�rr�r(rrr�test_subclassing4s<


zUsabilityTest.test_subclassingcCs@|jj}|jj}|�}|�t|d����t|�|d����dS�Nr)rr�rDr�r�rN�rr�rDrrrr�test_implicit_contextcs�z#UsabilityTest.test_implicit_contextc
Csf|jj}|jj}|jj}|jj}|jj}|jj}|jj}|jj}|jj	}	|jj
}
|jj}||���
��}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|�W5QRX||���X}d|_d|_
d|_|dd0��0}|�|jd�|�|j
d�|�|jd�W5QRXW5QRXdS)1Nr�r!i���Z111Z1e9999z1e-9999�rz1.609487E+48FTz4.709530r�z2.045323r�rZ1111000z
9.999999E+999rrr��
+Subnormalz0E-1005r�ZNan891287828Z
NaN1287828i  rjr��eZ101rNr|r�Z11100z1.11E+9rnrZ225r��r rrz1.50001z1e-3)r�r rz1.501z1.500z1e-10)r):rr�r"rrurvrxr{rzrwryrtrr�r�r�r�r�r�rr�r�r'r?rC�ln�log10�logbr:rGrHrKr1rN�capitalsrOrr2r/rJrSrsrErrrFrL�rotate�scaleb�shift�fmar#r �to_integralrmrqrPrQ�quantize)rr�r"rrurvrxr{rzrwryrtrr�r�zr�rrrr�test_none_argsls�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)Nrriu'��i7rNrArIir�r�z9.123���r<r�i�r��C)rr�r�rr2r3r4r/rJrSrsrErrrFrIr�rLr�rMr�r�r�r�rrr�test_conversions_from_int[	s����������������������z'UsabilityTest.test_conversions_from_intN)r�r�r�rArHrJrTrVrprvrwrxr�r�r�r�r�r�r�r�r�r�rrrrr2cs($*	Tg
-!/	pr2c@seZdZeZdS)�CUsabilityTestNr�rrrrr��	sr�cs,eZdZeZ�fdd�Z�fdd�Z�ZS)�PyUsabilityTestcs"t���t��|_t�d�dS�NiX��superr��sys�get_int_max_str_digits�_previous_int_limit�set_int_max_str_digitsr~�r�rrr��	s

zPyUsabilityTest.setUpcst�|j�t���dSr
�r�r�r�r��tearDownr~r�rrr��	szPyUsabilityTest.tearDown�r�r�r�r�rr�r��
__classcell__rrr�rr��	s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�NumberrZRealrEZassertNotIsInstancer�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�r��modules�dumps�loadsr�rcr�rEr�ZDecimalTuple)r�protor��savedecimalrr�r�r�rZsxr:Zsyrrr�test_pickle�	sL















zPythonAPItests.test_picklecCs�|jj}tdd�D]R}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/r0)rr�r�r�r�r8r�rmr�r�r��rr�r�rrr:rrr�test_int�	s
zPythonAPItests.test_intcCsl|jj}tdd�D]T}d|d}|�t||��tt|���||�}|�t�}|�|t�	|��|�qdS)Nr�r�r�r�)
rr�r�r�r�r8r�rmr��truncr�rrr�
test_trunc�	s
zPythonAPItests.test_trunccCs||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]6}t�d�t��dd}|�|t	|�|����q@dS)Nc@seZdZdd�ZdS)z1PythonAPItests.test_from_float.<locals>.MyDecimalcSs
d|_dS)Nr)r�)r�_rrrr��	sz:PythonAPItests.test_from_float.<locals>.MyDecimal.__init__Nr�rrrrr��	sr�r,r-rls\�&�5$3�|	r.r/r0r�rr1�abcr4r5r6r7)rr�rr�r�r�r�r�r�r8r@r=r�r�r�r�r9)rr�r�r:Zbigintr�r�rrr�test_from_float�	s6

�
�
�
�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�)rr z3.1415r�)rr!��z
Decimal('-0')r7zDecimal('1')r!z
Decimal('10'))rr�r"rwrmr��create_decimal_from_floatr��pirqr�r�)rr�r"rwrrrr�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��rMz7.335z.01z7.34�r z7.33Z10e99999Z1e100000r�z0.871831e800Z1e797)rr�r z	8.71E+799)rr�r"rur�r�rmr�)rr�r"rurrr�rrr�
test_quantize0
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.8182731e181273rrr��realrI�imag�	conjugate�__complex__)rr�r�r�r�r��complexr8r�r�r~)rr�r�rrr�test_complexH
szPythonAPItests.test_complexc	Cs|jj}|jj}|jj}|jj}|jj}|�}d|_d|_d|_|����}|�	�|�
|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�W5QRXdS)8Nr�r�rr�)rr�rrr�r�rz0.7r0rz-0.9z9.73z1E+1Z9999�'z-2000i0���r�rNz0.0625�0.2r)rr\r�r.�0.01z0.0101r�z-0.3z0.02z-0.03r2rjrFZ1e10�9.99r�r�9.9z0.9)�thirdrr\z7E+1i����r�z0.21Z11r|Z01Z23g�������?r�)r)@rr�r"rrurxrr�r�r�r�r�rr�rr�r�r�rGrHrKr�rQrPrNrr2rsrErrrFrIr�rLr�r�r;r<r=r>r@rBrArDr?rC�adjustedr��radixr�r:r1rOr/rJrSr�r�r�r�r��	canonicalr6r7)rrQr"rrurxZxcrrrr�test_named_parametersX
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�ru�FloatOperationrvrxr{rzrwryrtrr��ArithmeticErrorr��ZeroDivisionErrorZConversionSyntaxZDivisionImpossibleZDivisionUndefinedZInvalidContext)rrr�rur�rvrxr{rzrwryrtrrr�test_exception_hierarchy�
sBz'PythonAPItests.test_exception_hierarchyN)
r�r�r�r�r�r�r�r�r�r�r�r�r�rrrrr��	s3 pr�c@seZdZeZdS)�CPythonAPItestsNr�rrrrr��
sr�c@seZdZeZdS)�PyPythonAPItestsNr�rrrrr��
sr�c@seZdZdd�Zedd��Zdd�Zdd�Zd	d
�Zdd�Z	d
d�Z
dd�Zdd�Zdd�Z
dd�Zdd�Zdd�Zdd�Zdd�Zdd �Zd!d"�Zd#d$�Zd%d&�Zd'd(�Zd)d*�Zd+d,�Zd-d.�Zd/d0�Zd1d2�Zd3d4�Zd5d6�Zd7d8�Zd9d:�Z d;d<�Z!d=d>�Z"d?d@�Z#dAdB�Z$dCdD�Z%dEdF�Z&dGdH�Z'dIdJ�Z(dKdL�Z)dMdN�Z*dOdP�Z+dQdR�Z,dSdT�Z-dUdV�Z.dWdX�Z/dYdZ�Z0d[d\�Z1d]d^�Z2d_d`�Z3dadb�Z4dcdd�Z5dedf�Z6dgdh�Z7didj�Z8dkdl�Z9dmdn�Z:dodp�Z;dqdr�Z<dsdt�Z=dudv�Z>dwdx�Z?dydz�Z@d{d|�ZAd}d~�ZBdS)��ContextAPItestsc
Cs�|jj}|jj}|jj}|jj}|�}|ddddddddd�}||fD]z}|�|jd�|�|jt�|�|j	d�|�|j
d�|�|jd�|�|jd�t
||dg�t
||d|||g�qFdS)	N)rr r�r�r�r.r�r!r=�?B��r�rr�r!)rr"rurvrxr�rr r#r�r�r�r.r)rr"rurvrxrrrrrrr��
s,
��zContextAPItests.test_none_argscCsrddl}|j��}tD]}|�|�|_|�|j|�q|�d�}|�tt	|d|�|�d�}|�tt	|d|�dS)Nrr�r z	ROUND_UP)
rrr"�
RoundingModesrr r�r�r�r~)rrrZrndrrrrr
s


z(ContextAPItests.test_from_legacy_stringscCs�ttjd�D�]l}|jj}tjd}|jtjd<|�}t�t�||��}|�	|j
|j
�|�	|j|j�|�	|j|j�|�	|j
|j
�|�	|j|j�|�	|j|j�|�	|j|j�|�	|j|j�tr�ttfttfgnttfg}|D�]�\}}tt�D�]n\}	}
tt|�D�]V\}}
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*�qq�q�|tjd<qdS)
Nr�rrIr�rr�)rr�r�r r�r.r�r!r�r!)r�r�r�rr"r�r�r�r�r�rr�r�r r�r.r�r!rcr�r�r�r�r��	randrangerEr)rr�r"r�rr��combinationsZdumper�loaderZrir��fiZtirrSrR�capsr.rrrrrr�s`



�

&zContextAPItests.test_picklecCsB|jj}|�|d�dd|d�dig�|�|d�dddig�dS)Nr!r"r7)r�r�)rr�ZassertInZassertNotInr�rrr�test_equality_with_other_typesWsz.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"rVr8r�r�r!ra�keysr�)rr�r"rrZk1Zk2rrr�	test_copy]szContextAPItests.test_copycCs"|jj}|�}|�tt|d�dS)NZ_clamp)rr"r�r�r�rr"rrrr�test__clamplszContextAPItests.test__clampcCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dS�Nr�rj)rr�r"rr�r�r��rr�r"rrrrr�test_abswszContextAPItests.test_abscCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dS�Nr�r)rr�r"rdr�r�r�rrrr�test_add�szContextAPItests.test_addcCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"rr�r�r�rrrr�test_compare�szContextAPItests.test_comparecCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"r2r�r�r�rrrr�test_compare_signal�sz#ContextAPItests.test_compare_signalcCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"r3r�r�r�rrrr�test_compare_total�sz"ContextAPItests.test_compare_totalcCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"r4r�r�r�rrrr�test_compare_total_mag�sz&ContextAPItests.test_compare_total_magcCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"r6r�r�r�rrrr�
test_copy_abs�szContextAPItests.test_copy_abscCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"r5r�r�r�rrrr�test_copy_decimal�sz!ContextAPItests.test_copy_decimalcCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"r7r�r�r�rrrr�test_copy_negate�sz ContextAPItests.test_copy_negatecCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dS)Nr�rrr
)rr�r"r8r�r�r�rrrrr�szContextAPItests.test_copy_signcCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dS�Nr�r�rr�)rr�r"rr�r�r�rrrr�test_divide�szContextAPItests.test_dividecCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"r9r�r�r�rrrr�test_divide_int�szContextAPItests.test_divide_intcCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"r}r�r�r�rrrr�test_divmod�szContextAPItests.test_divmodcCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dS�Nr!r|)rr�r"r�r�r�r�rrrr�test_exps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�rrr�r��4rrz
not a decimalr�r�gZd;�O��?)rr�r"r�r�r�r�rrrr�test_fmas<
�
���zContextAPItests.test_fmacCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"r<r�r�r�rrrr�test_is_finite*szContextAPItests.test_is_finitecCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"r=r�r�r�rrrr�test_is_infinite3sz ContextAPItests.test_is_infinitecCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"r>r�r�r�rrrr�test_is_nan<szContextAPItests.test_is_nancCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"r?r�r�r�rrrr�test_is_normalEszContextAPItests.test_is_normalcCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"r@r�r�r�rrrr�test_is_qnanNszContextAPItests.test_is_qnancCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"rAr�r�r�rrrr�test_is_signedWszContextAPItests.test_is_signedcCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"rBr�r�r�rrrr�test_is_snan`szContextAPItests.test_is_snancCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"rCr�r�r�rrrr�test_is_subnormalisz!ContextAPItests.test_is_subnormalcCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"rDr�r�r�rrrr�test_is_zerorszContextAPItests.test_is_zerocCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"r�r�r�r�rrrr�test_ln{szContextAPItests.test_lncCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"r�r�r�r�rrrr�
test_log10�szContextAPItests.test_log10cCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"r�r�r�r�rrrr�	test_logb�szContextAPItests.test_logbcCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"r/r�r�r�rrrr�test_logical_and�sz ContextAPItests.test_logical_andcCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dS)Nr�r)rr�r"r:r�r�r�rrrr�test_logical_invert�sz#ContextAPItests.test_logical_invertcCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"rJr�r�r�rrrr�test_logical_or�szContextAPItests.test_logical_orcCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"rSr�r�r�rrrr�test_logical_xor�sz ContextAPItests.test_logical_xorcCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"rsr�r�r�rrrr�test_max�szContextAPItests.test_maxcCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"rEr�r�r�rrrr�test_max_mag�szContextAPItests.test_max_magcCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"rrr�r�r�rrrr�test_min�szContextAPItests.test_mincCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"rFr�r�r�rrrr�test_min_mag�szContextAPItests.test_min_magcCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"Zminusr�r�r�rrrr�
test_minus�szContextAPItests.test_minuscCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"r"r�r�r�rrrr�
test_multiply�szContextAPItests.test_multiplycCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"rGr�r�r�rrrr�test_next_minus
szContextAPItests.test_next_minuscCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"rHr�r�r�rrrr�test_next_plus
szContextAPItests.test_next_pluscCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"rIr�r�r�rrrr�test_next_toward
sz ContextAPItests.test_next_towardcCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"rKr�r�r�rrrr�test_normalize&
szContextAPItests.test_normalizecCsn|jj}|jj}|�}|�|�d�|�|d���|�|�d�|�|d���|�|�d�|�|d���dS)NrNrr�)rr�r"r�r1)rr�r"rrrr�test_number_class/
sz!ContextAPItests.test_number_classcCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"�plusr�r�r�rrrr�	test_plus8
szContextAPItests.test_pluscCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�|�|d�|d��|�|�t|jdd�|�t|jdd�|�|jdddd�d�dS)	Nr�rrrr�rr�)�modulor@r")rr�r"�powerr�r�r�rrrr�
test_powerA
szContextAPItests.test_powercCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"r�r�r�r�rrrrr�O
szContextAPItests.test_quantizecCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"�	remainderr�r�r�rrrr�test_remainder[
szContextAPItests.test_remaindercCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"rLr�r�r�rrrr�test_remainder_nearg
sz#ContextAPItests.test_remainder_nearcCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"r�r�r�r�rrrr�test_rotates
szContextAPItests.test_rotatecCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"rNr�r�r�rrrr�	test_sqrt
szContextAPItests.test_sqrtcCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"rMr�r�r�rrrr�test_same_quantum�
sz!ContextAPItests.test_same_quantumcCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"r�r�r�r�rrrr�test_scaleb�
szContextAPItests.test_scalebcCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"r�r�r�r�rrrr�
test_shift�
szContextAPItests.test_shiftcCs�|jj}|jj}|�}|�|d�|d��}|�|�dd�|�|�|�|d�d�|�|�|�d|d��|�|�t|jdd�|�t|jdd�dSr)rr�r"�subtractr�r�r�rrrr�
test_subtract�
szContextAPItests.test_subtractcCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"rOr�r�r�rrrr�test_to_eng_string�
sz"ContextAPItests.test_to_eng_stringcCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"rRr�r�r�rrrr�test_to_sci_string�
sz"ContextAPItests.test_to_sci_stringcCsJ|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�dSr)rr�r"rQr�r�r�rrrr�test_to_integral_exact�
sz&ContextAPItests.test_to_integral_exactcCs\|jj}|jj}|�}|�|d��}|�|�d�|�|�t|jd�|�t|jdd�dS)Nr!r|r�)rr�r"rPr�r�r�rrrr�test_to_integral_value�
sz&ContextAPItests.test_to_integral_valueN)Cr�r�r�r�r
r
r�r�rrrrr	r
rrr
rrrrrrrrrrrrrrrrr r!r"r#r$r%r&r'r(r)r*r+r,r-r.r/r0r1r2r4r7r�r9r:r;r<r=r>r?rArBrCrDrErrrrr��
s�
=																												r�c@seZdZeZdS)�CContextAPItestsNr�rrrrrF�
srFc@seZdZeZdS)�PyContextAPItestsNr�rrrrrG�
srGc@s<eZdZdd�Zdd�Zdd�Zdd�Zd	d
�Zdd�Zd
S)�ContextWithStatementc	Csb|jj}|jj}|�}|��}|�}W5QRX|�}|�||d�|�||d�|�||d�dS)N�!did not restore context correctly�did not copy the context� __enter__ returned wrong context)rrDrr'�assertIsNot)rrDr�orig_ctx�	enter_ctx�set_ctx�	final_ctxrrr�test_localcontext�
sz&ContextWithStatement.test_localcontextc		Cs�|jj}|jj}|jj}|jj}|�}|dd�}||��}|�}W5QRX|�}|�||d�|�|j|jd�|�||d�|�||d�dS)Nr��rrIzdid not set correct contextrJrK)rr"rDrr'r�rrL)	rr"rDrrM�new_ctxrNrOrPrrr�test_localcontextarg�
s

z)ContextWithStatement.test_localcontextargc
Cs�|jj}|jj}|jj}|jj}|jj}|jj}|�}|��|dd�}|���}	|�|	j	|j	�|�|	j
|j
�d|	j
|<d|	_|�|jd�|�
||	jd�|�|	j	|�||��^}
|�|
j	|j	�|�|
j
|j
�|�
||
j|d�d�|�|
j	|�|�|
j	|�~
W5QRX|�|	j	|�~	W5QRX|�|jd�|�|j	|�|�|j	|�|�|j	|�|�|j	|�dS)N��r�T���z0e-999z3.4e200r�)rr�r"rDrrtrxr�r�r�r!r�r8r�r�rr6r)rr�r"rDrrtrxrMrSrrrrr�test_nested_with_statementss>


z0ContextWithStatement.test_nested_with_statementscCs\|jj}|��D}~|��0}~|��}~|��}~W5QRXW5QRXW5QRXW5QRXdSr
�rr�rrrrr�c4rrr�test_with_statements_gc1'sz-ContextWithStatement.test_with_statements_gc1cCsb|jj}|��J}||��6}~||�� }~||��
}~~W5QRXW5QRXW5QRXW5QRXdSr
rYrZrrr�test_with_statements_gc23s


z-ContextWithStatement.test_with_statements_gc2c
Cs"|jj}|jj}|jj}|jj}|���}~|dd�}||�||���}~|�|jd�~|dd�}||�~|�|�jd�|dd�}	||	�|�|�jd�||	��^}
~	|�|
jd�~
|dd�}||�~|�|�jd�|��}|�|jd�~W5QRXW5QRXW5QRXW5QRXdS)Nr�rRr�rr)rr"rrDr'r�r)
rr"rrDr'rZn1rZn2Zn3rZn4r[rrr�test_with_statements_gc3?s<





z-ContextWithStatement.test_with_statements_gc3N)	r�r�r�rQrTrXr\r]r^rrrrrH�
s
#rHc@seZdZeZdS)�CContextWithStatementNr�rrrrr_`sr_c@seZdZeZdS)�PyContextWithStatementNr�rrrrr`bsr`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]�\}}
|	��||
�}dd�|	j��D�}|D]�}|	��|D]}||	|��q||
�}t|�}|D]}||k�rB|�|��qB|jtd
�dd�|	j��D�}|jtd
���||dd||f���||dd||f��qq�dS)Ncs2�jtkr$d|j|<|j|r.|�n
|�|�dS�NT)rrcr�r!Z_raise_error)r�flagr~rr�raise_errorrs



z7ContextFlags.test_flags_irrelevant.<locals>.raise_errorrr'r�)rr�r�r r!r�z100E-425000010r�r�z
9.87654321cSsg|]\}}|r|�qSrr�r�kr�rrrr��sz6ContextFlags.test_flags_irrelevant.<locals>.<listcomp>r�cSsg|]\}}|r|�qSrrrerrrr��sz=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"rwryr{rtrzr#r0rNrdr"r@r�r�rKr:r�r�r�r�)rr�r"rwryr{rtrzrdrZ
operationsZflagsets�fnr�r�r��extra_flagsrcZnew_ansZexpected_flagsZ	new_flagsrr~r�test_flags_irrelevantgs`��	�

��
��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"rwryr8r�r!r��update)rr"rwryrrrrr�test_flag_comparisons�s4
z"ContextFlags.test_flag_comparisonsc	Cs�|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	|�W5QRXdS)Ng@T)rr�r�rrr!r�r�rr�r�r�r�r�)rr�r�rrr�rrr�test_float_operation�sD





z!ContextFlags.test_float_operationcs"�jj��jj}�jj��jj}d��fdd�	��d���d��d�
d��d���d��	d	�d
�
�d���d��td
��td��d���������	�
��
��fdd�	}d���fdd�	}|�}||��P}��|j��||dd�||dd�d|j�<||�d�||�d�W5QRXdS)NcsN|��t||�}|�kr*��|||�n��||�d���|j��dSrb)r�rr�r'rr�)r"r@rr�signalr�)r�rrr�assert_attrs
z7ContextFlags.test_float_comparison.<locals>.assert_attrrBrCrErDr�r2rr�rr1r/r0csdD]}��
�|||�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)r_ra)r`rbrcrdrFr,r�r.)r8)rrmr)r�rn�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�doit#s z0ContextFlags.test_float_comparison.<locals>.doitcs�|��td�d�g�}��t|�d���|j��|��|r\��|td�d�g�ntd�d�g�}��|j��|��d�d�dfk}��|j��|��d�d�dddik}��|j��dS)	Nr�z100.0r�r7rkg$@r"r@)r�rar��lenrr�r��sorted)rrmrr@)r�r�rrr�test_containersAsz;ContextFlags.test_float_comparison.<locals>.test_containers)rmT)N)N)N)rr�r"r�rr8rr!)rr"rr{r~rGrr)r�r�rnrorprqrrrsrtrurvrrwrxryrzr�test_float_comparisons6	(

z"ContextFlags.test_float_comparisoncCs�|jj}|jj}|jj}|jj}|�}|�|j|�|�|j|�|��d|j|<d|j|<|�	|j|�|�	|j|�dSrb)
rr�r"rwr�rr�r!�clear_trapsr)rr�r"rwr�rrrr�test_float_operation_default`s

z)ContextFlags.test_float_operation_defaultN)	r�r�r�rirkrrlrr�rrrrraesB&
5[rac@seZdZeZdS)�
CContextFlagsNr�rrrrr�psr�c@seZdZeZdS)�PyContextFlagsNr�rrrrr�rsr�c@seZdZdd�Zdd�ZdS)�SpecialContextsc
Cs|jj}|jj}|jj}|jj}|jj}|jj}|jj}|jj}|jj	}	t
||d|||||	g�|���}
|j}|j}d}
ztzFd|_|_||fD],}||�|�}|�
||�|�|jd�q�Wn(tk
r�}z
|j}
W5d}~XYnXW5||_||_||
�|
�r|
�XdS)Nr!i�)r�BasicContext�ExtendedContextrDr'rurvrxr{rtrrVrrLr��	Exceptionr�)rr�r�rDr'rurvrxr{rt�savecontextZbasic_context_precZextended_context_prec�ex�templaterr�rrr�test_context_templatesxs<�
z&SpecialContexts.test_context_templatesc
Cs&|jj}|jj}|jj}|jj}|jj}|jj}|jj}|jj}|�	|j
d�|�	|j
d�t||d|||g�|���}	|j
}
d}z�zR|�}|j
}
d|_
|�}|�	|j
|
�||�|�}|�
||�|�	|j
d�Wn*tk
�r}z
|j}W5d}~XYnXW5|
|_
||	�|�r |�XdS)Nrr!i�)rr)r�r�rDr'rurvrxr�rrrVrLr�r�)rr)r�r�rDr'rurvrxr�Zdefault_context_precr�rZsaveprecr�rrr�test_default_context�s@�
z$SpecialContexts.test_default_contextN)r�r�r�r�r�rrrrr�us$r�c@seZdZeZdS)�CSpecialContextsNr�rrrrr��sr�c@seZdZeZdS)�PySpecialContextsNr�rrrrr��sr�c@seZdZdd�ZdS)�ContextInputValidationc
CsD|jj}|jj}|��}dD]F}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||dd
dg�q�|�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�rr�r�r�rr�r�r�)r�r�rr rr7�r�r.r�rrRrIr�r!rur)rr�r�r r�r.r�r!r��r.�r�r��r��Q�r!�rr�)r�r)
rr"r)rVr~r�rr�r�r�r��KeyError�__delattr__)rr"r)rrrrr�test_invalid_context�sL�z+ContextInputValidation.test_invalid_contextN)r�r�r�r�rrrrr��sr�c@seZdZeZdS)�CContextInputValidationNr�rrrrr�sr�c@seZdZeZdS)�PyContextInputValidationNr�rrrrr�
sr�c@seZdZdd�ZdS)�ContextSubclassingcsf|j��j}�j��j}�j}�j}�j}�j}�j}�j	}�j
}	G��fdd�d��}
��}|
�}dD]}
|�t||
�t||
��qh|j
t|
fddi�|
dd�}|�|jd�|�
|	|j|d�d	�|j
t|
fd
di�|
tdd�}|�|jt�|�|�|d
��d�|j
t|
fddi�|
ddd�}|�|jd�|�|d�|d��}|�||d��|||||fD]}|�|j|��ql|j
t|
fddi�|
ddd�}|�|jd�|�
||j|d�|d��|jtk�r�|||fD]}|�|j|��q�|j
t|
fddi�|
d	d�}|�|jd	�|�d�}|�|�|�d�|j
t|
fddi�|
ddd �}|�|jd�|�|d��}|�t|�d!�|j
t|
fd"di�|
||gd#�}||fD]}|�|j|��q�|� �t!�D]}|�"|j|��q�|j
t|
fd$di�|
||gd%�}||fD]}|�|j#|��q"|�$�t!�D]}|�"|j#|��qJdS)&NcseZdZd��fdd�	ZdS)z>ContextSubclassing.test_context_subclassing.<locals>.MyContextNc		s���|�|dk	r||_|dk	r&||_|dk	r4||_|dk	rB||_|dk	rP||_|dk	r^||_�dk	r�t�t�r��fdd�t	��D���|_
�dk	r�t�t�r��fdd�t	��D���|_dS)Ncsi|]}||�k�qSrr�rr�r�rr�
<dictcomp>/sz[ContextSubclassing.test_context_subclassing.<locals>.MyContext.__init__.<locals>.<dictcomp>csi|]}||�k�qSrrr�r�rrr�3s)r�rr r�r�r�r.rFr:r�r�r!)	rrr r�r�r�r.r�r!�r"r�r�r!rr�s*


zGContextSubclassing.test_context_subclassing.<locals>.MyContext.__init__)NNNNNNNNr�rr�rr�	MyContexts�r��rr r�r�r�r.r�r!rr�r�rRZ9e2rr �XYZ)r rr�rr�r�)r�rz1e-99z2.234e-2000r�r�)r�rZ1e99z
2.234e2000r�r�Z1E222z1e+222r.r��c)r.r�z!1.000000000000000000000000000E+99r�r�r!r�)%rr�r"rtrvrwrxryrzr{rur�rr�r�rr�r�rmr r3r�rdrr�r�rcr�r�rRr.r�r�r�rr!r�)rr�rtrvrwrxryrzr{rur�rrrr�rmrr�r�test_context_subclassings|


z+ContextSubclassing.test_context_subclassingN)r�r�r�r�rrrrr�
sr�c@seZdZeZdS)�CContextSubclassingNr�rrrrr�zsr�c@seZdZeZdS)�PyContextSubclassingNr�rrrrr�|sr�c@s$eZdZdd�Zdd�Zdd�ZdS)�CheckAttributescCs�|�tjtj�|�tjtj�|�tjtj�|�tjtj�|�tjdkpVtjdk�|�tjdkpptjdk�|�tj	tj	�|�t
t�t
t��dS)NTF)r�rcr�r�r�rOrPrr*�__version__�dirr~rrr�test_module_attributes�sz&CheckAttributes.test_module_attributescCsJdd�tt���D�}dd�tt���D�}|�t|�t|�t��dS)NcSs"g|]}d|ks|�d�s|�qS��__r��r�rrrrr��s
z;CheckAttributes.test_context_attributes.<locals>.<listcomp>cSs"g|]}d|ks|�d�s|�qSr�r�rrrrr��s
)r�rcr"r�r�ra�rr�rrrr�test_context_attributes�sz'CheckAttributes.test_context_attributescCsNdd�tt�d��D�}dd�tt�d��D�}|�t|�t|�t��dS)NcSs"g|]}d|ks|�d�s|�qSr�r�rrrrr��s
z;CheckAttributes.test_decimal_attributes.<locals>.<listcomp>rcSs"g|]}d|ks|�d�s|�qSr�r�rrrrr��s
)r�rcr�r�rar�rrr�test_decimal_attributes�sz'CheckAttributes.test_decimal_attributesN)r�r�r�r�r�r�rrrrr�sr�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�r�r�rrr�
test_adjusted�szCoverage.test_adjustedcCsL|jj}|jj}|d���}|�|d�|�}|�|d��}|�|d�dS)Nr)rr�rDr�r�)rr�rDr�rrrr�test_canonical�szCoverage.test_canonicalcCsp|jj��}d|_d|_d|_t|_d|_d|_	t
|jD]}d|j|<d|j|<q:|�
�}d}|�||�dS)Nr�r'rr�Fz{Context(prec=425000000, rounding=ROUND_HALF_DOWN, Emin=-425000000, Emax=425000000, capitals=0, clamp=1, flags=[], traps=[]))rr)rVrr�r�ror r�r.r�r�r!�__repr__r�)rrrrr�rrr�test_context_repr�s
zCoverage.test_context_reprc	Cs|jj}|jj}|����}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����W5QRX|��`}d|_d d!}||�}|��}|�||�|��}|�||�|� |d��}|�||�W5QRXdS)"Nr�r�z-10r!�7rr|r�r�r�z1.2r�r�Tz1.01rFZ20Z580r�rrz2E+1z-1E+1z+Normalrjz1.12345rr�r�rni�i�)!rr�rrr�r�r�rr�r'r>�powr�r?rCr�r�r�r:rGrHrKr1rQrr;r<rBrArDr6r7r8)rr�rrr�rr�rrrr��s^

zCoverage.test_implicit_contextc	Cs�|jj}|jj}|jj}|jj}|����}t|d�d�\}}|�||d��|�||d��t|d�d�\}}|�|��o�|���d|j	|<t|d�d�\}}|�|��o�|���d|j	|<|�
�t|d�|d��\}}|�|��o�|���|�|j|�|�
�t|d�d	�\}}|�|���o2|���|�|j|�|�
�t|d
�d
�\}}|�|���ot|���|�|j|�d|j	|<|�
�t|d�d
�\}}|�|���o�|���|�|j|�o�|j|�W5QRXdS)NZ10912837129r�Z10901935Z194r�r�Fr/r�r�)
rr�rrurvr}r�rr>r!r�r�r=)rr�rrurvrr�r:rrrrsB



�zCoverage.test_divmodc	Cs�|jj}|jj}|jj}|jj}|���}d|_|��|�|d�d|d��|�|j	|�d|_d|_
d|_|��d|j|<|�|d�|d	�|d
��|�|j	|�W5QRXdS)Nrr�rIr�r�r�Frnr�r/)
rr�rrxryrr�r�rr�r�r�r!)rr�rrxryrrrrr7?s 
zCoverage.test_powerc	Csj|jj}|jj}|jj}|��B}d|_d|_d|_d|j|<|d��|d��}|�	|�
��W5QRXdS)Nr�r�Fr�Z1e1)rr�rrurr�r�r!r�rr>�rr�rrurr�rrrr�Ss
zCoverage.test_quantizecCs>|jj}|jj}|�}|�|d���d�|�|��d�dS)Nrr!)rr�rDr�r�r�rrr�
test_radix`s
zCoverage.test_radixcCs0|jj}dD]}|�t|d�|�d�t�qdS)N)rhrkrnrqr^rtrvrxrr)rr�r'rrI)rr�rrrrrhszCoverage.test_ropc	Cs�|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�W5QRXdS)Nr=r�r|z9.99e-5r�r�r�z1.23457r�r!z1.2345000000r[z0E+10r�r�r)	rr�rrr�r��	__round__r�r�)rr�rrrrr�
test_roundoszCoverage.test_roundcCs |j��}|�t|jdg�dS)Nrr)rr"r�r�r�)rrrrr�test_create_decimal�s
zCoverage.test_create_decimalc	Cs`|jj}|jj}|��@}d|_|dd�dd}|�t|�d�|�|��d�W5QRXdS)Nr�i�i�r!iSr�r�)rr�rrr�r�r��rr�rrr�rrrr��szCoverage.test_intcCsl|jj}|�}d|_dd}|�|�}|�||�|�|�}|�||�|�|d�}|�||�dS)Nrni�i�r�)rr"rr6r�r7r8)rr"rr�rrrrr�s


zCoverage.test_copyN)r�r�r�r�r�r�r�rr7r�r�rr�r�r�rrrrrr��sQ)

r�c@seZdZeZdS)�	CCoverageNr�rrrrr��sr�cs,eZdZeZ�fdd�Z�fdd�Z�ZS)�
PyCoveragecs"t���t��|_t�d�dSr�r�r~r�rrr��s

zPyCoverage.setUpcst�|j�t���dSr
r�r~r�rrr��szPyCoverage.tearDownr�rrr�rr��sr�c@seZdZdd�ZdS)�PyFunctionalityc
CsNtj}tj}ddddddddd	d
g
}|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�rr)z#.0grr�)r�r�z100%)z#.0%r�z100.%)r�r�rr�r�)rr�rrLr�rr�rrr�test_py_alternate_formatting�s�
z,PyFunctionality.test_py_alternate_formattingN)r�r�r�r�rrrrr��sr�c@s4eZdZdd�Zdd�Zdd�Zdd�Zd	d
�ZdS)�
PyWhiteboxc	Cs�tj}tj}|���}d|_|d�|d�}|�||d��|d�|d�}|�||d��|d�|d�}|d�|d	�}|�||d
��|d�|d	�}|dd
�|d	�}d|_|d�|d�}d|_|dd�|d�}W5QRXdS)Nrirz
0.00390625z-0.6z0.0012885819Z256e7l�o�
�z-0.0625r�Z152587890625e7r�ic
r�Z152587890625��r�iB)r�r�rrr�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�sz=PyWhitebox.test_py_immutability_operations.<locals>.<genexpr>z-25e55z33e+33Fcs�|rvtd|d����j�j����j�j����j�j����j�j����j�j����j�j�n@td|d����j�j����j�j����j�j�dS)Nzd1.z(d2)z())r�r��_sign�_int�_exp)Z	operationZuseOther��b1�b2r�r�rrr�checkSameDec�sz@PyWhitebox.test_py_immutability_operations.<locals>.checkSameDec�__abs__rgTr]rcrdrar_rbr`�	__float__rurX�__int__�	__trunc__rsrm�__neg__�__bool__�__pos__rwrhr^r�rvrtrnrxrk�__str__rjrpr�r�rrsrrrKr�rLrMrNrOr�)F)r�r�r)r'rVr$r�r!r�r�r�r�)rr�r)r'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�r8r�r*rrr�test_py_decimal_id1s
zPyWhitebox.test_py_decimal_idc	Cs@tj}tj}|��$}|d��dt�}|�|���W5QRXdS)Nr�r)r�r�rZ_rescalerqrr>r�rrr�test_py_rescale9s
zPyWhitebox.test_py_rescalecCs tj}|�t|d�jdt�dS)Nz3.1234r)r�r�r�r�Z_roundrqr�rrr�test_py__roundBszPyWhitebox.test_py__roundN)r�r�r�r�r�r�r�r�rrrrr��s
O	r�c@s0eZdZedd��Zedd��Zedd��ZdS)�CFunctionalitycCstj}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�r.r)rrrrr�assert_restSsz7CFunctionality.test_c_ieee_context.<locals>.assert_restr��`i����r_rUrW�"ii�r@r�i)rc�IEEEContext�	DECIMAL32�	DECIMAL64�
DECIMAL128r�rr�r�r�r�r�)rr�r�r�r�r�rrrr�test_c_ieee_contextKs.


z"CFunctionality.test_c_ieee_contextcCs:tj}|tjtjd�}|�|jtj�|�|jtj�dS)Nr�)rcr"r+�
DecRoundedr��_flags�_trapsrrrr�test_c_contextoszCFunctionality.test_c_contextcCstjtjtjtjtjtjtjtjtj	tj
tjtjtj
tjtjf}|�tjd�|�tjd�|�tjd�|�tjd�t|�D]\}}|�|d|>�q�|�tjtjtjBtjBtjBtjBtj	Btj
B�|�tjtjtjB�|�tjtjtjBtjB�dS)Nr�rg�ir�)rcr+�DecConversionSyntax�DecDivisionByZero�DecDivisionImpossible�DecDivisionUndefined�DecFpuError�
DecInexact�DecInvalidContext�DecInvalidOperation�DecMallocErrorZDecFloatOperation�DecOverflowr��DecSubnormal�DecUnderflowr�r�r�r�ZIEEE_CONTEXT_MAX_BITSr��DecIEEEInvalidOperationZ	DecErrorsZDecTraps)r�condr�r�rrr�test_constantswsZ�
�������	���zCFunctionality.test_constantsN)r�r�r��requires_extra_functionalityr�r�r�rrrrr�Hs
#
r�c@s�eZdZdd�Zdd�Zdd�Zdd�Zd	d
�Zdd�Ze	d
d��Z
dd�Ze	dd��Zdd�Z
dd�Zdd�Zdd�Zdd�Ze	dd��Ze	dd ��Zd!d"�Zd#d$�Zd%d&�Zd'd(�Zd)d*�Zd+S),�	CWhiteboxc	Cs�tj}tj}dd}dd}|��V}d|_td�D]@}t�||�}t�dd�}||}	||�||�}
|�|	|
�q2W5QRXdS)Nr!�#�$i@Br�r�i�)rcr�rrr�r�r�r�)rr�rr�r�rr�r"r@r�rrrr�test_bignum�szCWhitebox.test_bignumcCs|�ttjdd�dS)Nrr)r�r�rcr�r~rrr�test_invalid_construction�sz#CWhitebox.test_invalid_constructionc	Cs@tj}tj}tj}tj}||���|�||d�W5QRXdS)NZ1e9999999999999999999)rcr�rur"rr�)rr�rur"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�r'rr�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]))rcr)r�rVrr�r�ror r�r.r�r�r!r�r�)rr)r�rrrr�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|	|
|��q6|�	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]j}
|�	tt|	|
|d�|�	tt|	|
|d�tjdk�r|�	tt|	|
|�|�	tt|	|
|d��qtjdk�r�|�	tt|	d�|d�|�	tt|	d�|d�|�	tt|	d�|d�tjdk�rF|�	tt|	d�d�|�	tt|	d�d�|�	tt|	d�d�|�	tt|	d�d�|�	tt|	d�d�|�	tt|	d�d�dD]l}
|�	tt|	|
d�|�	tt|	|
d�|�	tt|	|
ddd g�|�rJ|�	tt|	|
d!�|�	tt|	|
d"��qJ|�	ttd#t��|�	ttd$t��|�}|�	t|d%�||�dS)&Nr�i!rr�r�r!rr�i�pr�r?r>l�N�Zoiʚ;r�r�rRrV)r�r�r�r�)rr�r�r�r.�win32r�r�r�i���?r�i9�r�r��zwith localcontext("xyz"): passz-with localcontext(context=getcontext()): passr)rcr"rurxr�rrDr'r�r�r�r��__setitem__r!r��__delitem__r�r~rVr�r��platformr�execrS)rr"rurxr�rrDr'�HAVE_CONFIG_64rr�int_maxZgt_max_emaxrZ
saved_contextrrr�test_c_context_errors�s�

������
��zCWhitebox.test_c_context_errorscCs�|�tjtj�|�tjtj�|�tjtj�|�tjtj�|�tjtj�|�tjtj�|�tj	tj	�|�tj
tj
�dSr
)r'rcrqr�rmrlrnrpror#rrr~rrr�test_rounding_strings_internedAsz(CWhitebox.test_rounding_strings_internedc	Cs�tj}tj}tj}tj}tj}tj}tjdk}|�}|r<dnd}	|�t	t
|d|	d�|�t	t
|d|	d�tjdkr�|�t
t
|d|	�|�t
t
|d|	d�dD]f}
|�t	t
||
|	d�|�t	t
||
|	d�tjdkr�|�tt
||
|	�|�tt
||
|	d�q�|�t
t
|dd	�|�t
t
|dd�|�tt
|dddd
g�|�rt|�t
t
|dd�|�t
t
|dd�dD]*}
|�tt
||
d
�|�tt
||
d��qxdS)Nr�r?r>�_allcrr�r�r)r�r�r�rrrr�r�)rcr"rurxrrDr'r�r�r�r~r�rr�r�)rr"rurxrrDr'r	rr
rrrr�test_c_context_errors_extraLs:


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�tjdk�r|�d	�|�d	�|�d
�|�|jd	�|�|jd	�|�|jd
�dS)Nr�i�iH�r�ri'�i�r�rKrL)rcr)rtr{rwryrzrVrrpr r�r�r�r.r�ZEtinyZEtopr�r�r�r�)rr)rtr{rwryrzrrrr�test_c_valid_contextws8


zCWhitebox.test_c_valid_contextcCs4tj}|��}|�|jd�d|_|�|jd�dS)Nr�r)rcr)rVr�r
)rr)rrrr�test_c_valid_context_extra�s
z$CWhitebox.test_c_valid_context_extrac	Cs�tj}tj}tj}tj}tj}tjdkr,dnd}|���}d|j|<|�||d�j	|d�|�||d�j	|�|�||d�j	t
|d��|�tj|d�j	t
|d��|�t|d�j	|d�|�t|d�j	|d�W5QRXdS)	Nr�r?r>Tr�r�rr�)rcr�rurr�rPr�r!r�r�r�r�)rr�rurr�rPr
rrrr�test_c_round�s4
��
����zCWhitebox.test_c_roundcCs�tj}tjdk}|�t|d�jdgd�|�t|d�jdd�|�t|d�jg�|�t|d�jd�|rndnd}|�t|d�jd	|�dS)
Nr�r�z=10.10rz<>=10.10r?r>r�z=%d.1)rcr�r�r�r�r�r�)rr�r	�maxsizerrr�
test_c_format�s
�zCWhitebox.test_c_formatc	CsPtj}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�|��`}|d��t
�}|�||d��|d��	t
�}|�||d��d|j|<|�||d�j	t
�W5QRXdS)Nr!r|r�z99999999999999999999999999.9Z100000000000000000000000000Tz999.9)rcr�rwrr�r�r�r�rPrQrqr!)rr�rwrr�rrrr�test_c_integral�s.
zCWhitebox.test_c_integralc	Cs>tj}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
�|���J}|��|�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�W5QRXdS)Nz9.99e10z99.9E+9r�r�r�rr�rrr�z	1e-100000r!r�r4rZ200Tri�)rcr�rurvrDrr�rOr�r�r�r1rMr�rqr�r8r�r;r}r�r�r!r]rr�r�r)rr�rurvrDrrrrr�test_c_funcs�sn����



zCWhitebox.test_c_funcscCs�tj}tj}|d�}dD]0}t||�}|jt|dd�|jt|ddd�qdD]0}t||�}|jt|dd�|jt|ddd�qN|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�r?rCr�r�r�r:rGrHrKr1rNrOr�r�)rr2r/rJrsrErrrFrLr�r�r�r�r�r�r�)�mod)rcr�r"rr�r�r�rPrQr�r�r6)rr�r"r�r�funcrrrr�test_va_args_exceptions&s:

z!CWhitebox.test_va_args_exceptionscCsL|�tjjtjtjBtjBtjBtjB�|�tj	jtjtjBtjB�dSr
)
r�rcr�r�r�r�r�r�r+r)r~rrr�test_c_context_templatesRs����z"CWhitebox.test_c_context_templatesc%stj}tj}tj}tj}tj}tj}tj}tj}tj	}	tj
}
tj}tj}tj
}
�fdd�}|��}��||jk�|��|j��D]}d|j|<q�|j��D]}��|�q�|��|j��D]\}}��|�q���|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
i}tj)tj*tj+tj,tjtj-tj.g}tt/t�}t0|�D�]V}t0|�D�]D}t1D�]6}t2�3t/t|�}t2�3t/t|�}t2�4dd�}t2�4d	d
�}t2�4d
d�}t2�4d
d�}t2�4d
d�} t2�4d
d�}!|||||| |t5|�t5|�d�}��|j6|���|j7|���|j8|���|j9|���|j:| ���|j;|�d
}"|D]}#|"||#O}"�q^��|j!|"�d
}"|D]}#|"||#O}"�q���|j"|"��qt�qj�q\|D](}$|$|_!��|j!|
@�|||j��q�|D](}$|$|_"��|j"|
@�|||j��q�dS)
Ncs4|D]*}||kr ��||�q��||�qdSr
)rr)rmZsignal_dictrr~rr�assertIsExclusivelySetrsz<CWhitebox.test_c_signal_dict.<locals>.assertIsExclusivelySetTr�rr�r�rni���rr�r�)<rcr"r)rurvrxrzr{ryrwrtr+r�r�rVrr!r�r�valuesrKrr�r�r'r�r�r�r|r��	getsizeofr�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r��sampler�r:rr r�r�r�r.)%rr"r)rurvrxrzr{ryrwrtr+r�r�rrrfr�rrZ
IntSignalsZIntCondZlimr:r�r�r�r!rrSrRr.r�Zcrr�r�r�rr~r�test_c_signal_dict^s�


��

�zCWhitebox.test_c_signal_dictcs�tj�zddlm}Wntk
r4|�d�YnXdd�}d�fdd�	}d	|d
d
dg�d	d�}d|d
d
dg�d	d�}d|d
d
dg�dd�}|dkr�|�t|d|d�|�t|d|d�|�t|d|d�dS)Nrr�r�cSsd�dd�|D��S)Nr�cSsg|]}t|��qSrr�r�rrrr��szJCWhitebox.test_invalid_override.<locals>.make_grouping.<locals>.<listcomp>)r�r�rrrr��sz6CWhitebox.test_invalid_override.<locals>.make_groupingr�cs�|��||�Sr
)r�r�r\rrr��sz0CWhitebox.test_invalid_override.<locals>.get_fmtr��r�Zxxxxxrr�Zyyyyy�r�r�)Nr�)rcr�r�r�r�r�r�r�)rr�r�r�Zinvalid_groupingZinvalid_dotZinvalid_seprr\r�test_invalid_override�s4���
�zCWhitebox.test_invalid_overridec	Cs�tj}tj}tj}|��|}d|j|<dtj}|�|||�dtjd}|�|||�dtj}|�|||�dtjd}|�|||�W5QRXdS)NTz0e%dr�z1e%d)rcr�rrur!r�rr�r�rrr�test_exact_conversions


zCWhitebox.test_exact_conversionc	Cs�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�W5QRXdS)
NTr�rz
-0E+999999)rr�r�z-0E-1000007r�r�r�)r�rr�)r�r�r�z-sNaN1)rcr�rrurxr{r!r�rr�r�r�r�r�)rr�rrurxr{rr�rrr�test_from_tuplesB



zCWhitebox.test_from_tuplecCs�tj}tjdk}|�|d���d�|rZ|dd���}|dd���}|�||d�n0|dd���}|dd���}|�||d	�dS)
Nr�rr!r<i�r����r)rcr�r�r4�
__sizeof__r�)rr�r	r�rrrr�test_sizeofOs
zCWhitebox.test_sizeofcsztj}Gdd�dt�}Gdd�dt�}Gdd�dt��G�fdd�dt�}|||fD] }|�|�|d	��|�d	��qTdS)
Nc@seZdZdd�Zdd�ZdS)z<CWhitebox.test_internal_use_of_overridden_methods.<locals>.XcSsdS�Nr�rr~rrrr�bszMCWhitebox.test_internal_use_of_overridden_methods.<locals>.X.as_integer_ratiocSs|Sr
rr~rrrr�dszDCWhitebox.test_internal_use_of_overridden_methods.<locals>.X.__abs__N�r�r�r�r�r�rrrr�Xasr*c@seZdZdd�ZdS)z<CWhitebox.test_internal_use_of_overridden_methods.<locals>.YcSs
dgdS�Nr�r4rr~rrrr�hszDCWhitebox.test_internal_use_of_overridden_methods.<locals>.Y.__abs__N)r�r�r�r�rrrr�Ygsr,c@seZdZdd�ZdS)z<CWhitebox.test_internal_use_of_overridden_methods.<locals>.IcSs
dgdSr+rr~rrr�
bit_lengthlszGCWhitebox.test_internal_use_of_overridden_methods.<locals>.I.bit_lengthN)r�r�r�r-rrrr�Iksr.cs eZdZ�fdd�Zdd�ZdS)z<CWhitebox.test_internal_use_of_overridden_methods.<locals>.Zcs�d��d�fSr(rr~�r.rrr�pszMCWhitebox.test_internal_use_of_overridden_methods.<locals>.Z.as_integer_ratiocSs|Sr
rr~rrrr�rszDCWhitebox.test_internal_use_of_overridden_methods.<locals>.Z.__abs__Nr)rr/rr�Zosr0gfffffFY@)rcr�r8r�r�r�)rr�r*r,r0rrr/r�'test_internal_use_of_overridden_methods]s�z1CWhitebox.test_internal_use_of_overridden_methodsN)r�r�r�r�r�rrrrr�rrrrrrrrrrr!r"r#r'r1rrrrr��s4e
*&
;,

%0r�ztest requires C versionc@seZdZdd�Zdd�ZdS)�
SignatureTestc
Cs�tt�D]�}|�d�rqtt|�}tt|�}|dksF|dksFt�|�rt�|�}t�|�}t|j	�
��}dd�|j	�
�D�}|j||d|d�dd�|j	��D�}d	d�|j	�
�D�}	|d
kr|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��msgcSsg|]
}|j�qSr��kindr�rrrr��scSs$g|]}|d�d�s|dj�qS)rr�r�)r�r7r�rrrr��s�r'�parameter kind mismatch in %s)r�r�r�rrc�inspect�
isfunction�	signaturer:�
parametersrr�rrK)
rr�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�rr7)r\r�r�rr�r"r@rr�r5�numr�r r)r\r�r"r@rr�r5rFr�r rcspg}i}|j��D]T\}}|dkr$q|j�krB|��||�q|j�kr^�||||<qtd��q||fS)Nrzunexpected parameter kind)r<rKr7r�r)�modulerr��kwargs�nameZparam)�POS�POS_KWD�pdictrr�mkargs�s


z0SignatureTest.test_inspect_types.<locals>.mkargscSs(|dkrdS|dkrdS|dkr$dS|S)Nr�r"rr@r�rr)rrrr�tr�sz,SignatureTest.test_inspect_types.<locals>.trcs�tt|�}tt|�}t|�D�]�}|�d�r.qt||�}t||�}t�|�rt�|�}t�|�}t|j	�
��}�fdd�|j	�
�D�}	�j|	|d|d�dd�|j	��D�}
dd�|j	��D�}��
|
d����
|d��|d	k�r�j|d
d�|
d
d�d|d�n�jt|�t|
�d|d��t|�\}}
zt|d�|�||
�Wn6tk
�r�}ztd
|||
f��W5d}~XYnX�t|�\}}
zt|d�|�||
�Wqtk
�r�}ztd
|||
f��W5d}~XYqXqdS)Nr�csg|]}�|��qSrrr�)rNrrr��szBSignatureTest.test_inspect_types.<locals>.doit.<locals>.<listcomp>r3r4cSsg|]
}|j�qSrr6r�rrrr��scSsg|]
}|j�qSrr6r�rrrr��srr�r�r8rzinvalid signature for %s: %s %s)rr�rcr�r�r9r:r;r:r<rr�rr'r|r�r)ZtyZp_typeZc_typerr=r>r?r@rBrArDrCr��kwds�err)rJrKrMrrNrrr{�sH







�
��$z.SignatureTest.test_inspect_types.<locals>.doitr�r")	r9Z_ParameterKindZPOSITIONAL_ONLYZPOSITIONAL_OR_KEYWORDrcr�rprDr�)rr{r)rJrKrMrLrrNr�test_inspect_types�sH
���
/z SignatureTest.test_inspect_typesN)r�r�r�rErQrrrrr2ysr2r�r�c
Csptt�tt�|dk	r|ntd�a|a|dkr6t}nttg}t	�
t�D]l}d|ksH|�d�r`qH|�
d�\}}|dk	r�||kr�qH|fdd�}ttd||�ttd||�~~~~qHzft|�|dk�rd	d
lm}	tjd}
tr�ttjd<tt||	d�ttjd<tt|�|
tjd<W5t�r2t�tt�t�tt�t�sRt�dt�ttjdk	�rjtd��XdS)Nrz.decTestr�cSs|�t|�Sr
)r��	directory)rr�rrrr�9r�ztest_main.<locals>.<lambda>Ztest_z*C tests skipped: no module named _decimal.zGInternal error: unbalanced number of changes to sys.modules['decimal'].r)�IGNORE_EXCEPTION_DETAIL)Zoptionflags)r)rcr�rr�r��	all_testsr�r��os�listdirrRr�r�r~r'�ORIGINAL_CONTEXT�warnings�warn�UserWarning�orig_sys_decimalr�r�rr�doctestrSr)�arith�verbose�
todo_tests�debugZtest_classes�filename�head�tailZtesterrSr�rrr�	test_mainsJ





�rdz: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�rUr�rrXr�rVr�r�r�Ztest.supportrrrrrrrr	r
r�r9r+rcr�r�r[Z
cfractionsZ
pfractionsrr�rDr�rr&rtryrwrzr{rxrvrur�r�rrqrmrlrnrpror#rrr�rWr)ZTESTDATADIRr��argvr��__file__�path�dirname�curdirZtestdir�seprR�isdirr�r��hasattrZEXTRA_FUNCTIONALITYZ
skipUnlessr�ZskipIfZskip_if_extra_functionalityZTestCaser,r�r�r�rOrPrQr�r�r�r�r�r�rrrr$r%r0r1r2r�r�r�r�r�r�rFrGrHr_r`rar�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r2rT�insertrdZoptparseZOptionParserr�Z
add_option�
parse_args�optr��skipr`rrrr�<module>s�



������	
�
��eWM)',-/Xm~
P>mUa
	�
7



F1le Man4ger