a ze]v@sdZddlmZddlmZddlZddlZddlZddlZddl Z ddl Z ddl Z ddl m Z m Z ddlmZmZejZGdddeZGd d d eZGd d d ejZd dZGddde jZedkre dS)zTests for Lib/fractions.py.)Decimal)requires_IEEE_754N)copydeepcopy)dumpsloadsc@s\eZdZdZddZddZddZdd Zd d Zd d Z ddZ ddZ ddZ e Z dS) DummyFloatz8Dummy float class for testing comparisons with FractionscCst|tstd||_dS)Nz-DummyFloat can only be initialized from float) isinstancefloat TypeErrorvalueselfr rG/opt/bitninja-python-dojo/embedded/lib/python3.9/test/test_fractions.py__init__s zDummyFloat.__init__cCs>t|tjr|t|j|St|tr6||j|jStSdSN)r numbersRationalF from_floatr rNotImplemented)rotheroprrr_richcmps   zDummyFloat._richcmpcCs||tjSr)roperatoreqrrrrr__eq__!zDummyFloat.__eq__cCs||tjSr)rrlerrrr__le__"rzDummyFloat.__le__cCs||tjSr)rrltrrrr__lt__#rzDummyFloat.__lt__cCs||tjSr)rrgerrrr__ge__$rzDummyFloat.__ge__cCs||tjSr)rrgtrrrr__gt__%rzDummyFloat.__gt__cCsdSrrrrrr __float__(szDummyFloat.__float__cCsdSrrrrrr__sub__,szDummyFloat.__sub__N)__name__ __module__ __qualname____doc__rrrr!r#r%r'r)r*__rsub__rrrrrsrc@sHeZdZdZddZddZddZdd Zd d Zd d Z ddZ dS) DummyRationalzATest comparison of Fraction with a naive rational implementation.cCs$t||}|||_|||_dSr)mathgcdnumden)rr3r4grrrr4s  zDummyRational.__init__cCs,t|tjr$|j|jko"|j|jkStSdSr)r fractionsFractionr3 _numeratorr4 _denominatorrrrrrr9s    zDummyRational.__eq__cCs|j|j|j|jkSrr3r9r4r8rrrrr#@szDummyRational.__lt__cCs|j|j|j|jkSrr:rrrrr'CszDummyRational.__gt__cCs|j|j|j|jkSrr:rrrrr!FszDummyRational.__le__cCs|j|j|j|jkSrr:rrrrr%IszDummyRational.__ge__cCsdSrrr(rrrr)NszDummyRational.__float__N) r+r,r-r.rrr#r'r!r%r)rrrrr01sr0c@seZdZdZdS) DummyFractionz6Dummy Fraction subclass for copy and deepcopy testing.N)r+r,r-r.rrrrr;Qsr;cCs |j|jfSr) numerator denominator)rrrr _componentsUsr?c@s eZdZddZddZddZddZed d Zd d Z d dZ ddZ ddZ ddZ ddZddZddZddZddZdd Zd!d"Zd#d$Zd%d&Zd'd(Zd)d*Zd+d,Zd-d.Zd/d0Zd1d2Zd3d4Zd5d6Zd7d8Zd9d:Z d;d<Z!d=d>Z"d?d@Z#dAdBZ$dCdDZ%dES)F FractionTestcCs$|t|t||||dS)z4Asserts that both the types and values are the same.N) assertEqualtyperZexpectedactualrrrassertTypedEquals[szFractionTest.assertTypedEqualscCs0||||ttt|ttt|dS)zBAsserts that both the types and values in the tuples are the same.N)ZassertTupleEqualZassertListEquallistmaprBrCrrrassertTypedTupleEquals`s z#FractionTest.assertTypedTupleEqualsc Os\z||i|Wn4|yF}z||t|WYd}~nd}~00|d|jdS)z@Asserts that callable(*args, **kwargs) raises exc_type(message).Nz %s not raised)rAstrZfailr+)rexc_typemessagecallableargskwargserrrassertRaisesMessagees &z FractionTest.assertRaisesMessagec Cs|dtt|dttd|dtttdd|dttdd|dttdd|d ttd d |d ttd d |dttdd|dttd|dtttddd|dttdtdd|dtttddtdd|tdtdd|ttd|ttd d|ttdd!|ttdd"|ttddddS)#Nr)rRrSrSrU)rRrVrR)rRrR)rR )rSr[)m+?RrRr\)rUM )rYrX )i i cqzFraction(12, 0) ry?@3/2yy?)rAr?rrPZeroDivisionError assertRaisesr r(rrrtestInitos("zFractionTest.testInitcCsv|dttd|dttd|dttd|tttd|tttd|tttd dS) N)rYrX@rQ)L33fl皙?naninf-inf)rAr?rrh ValueErrorr OverflowErrorr(rrrtestInitFromFloats zFractionTest.testInitFromFloatcCs|dtttd|dtttd|dtttd|tttd|tttd|tttd |tttd dS) N)r^rZz1.1)rSz3.5e-2rQz.000e20rnsnanrorp)rAr?rrrhrqrrr(rrrtestInitFromDecimalsz FractionTest.testInitFromDecimalcCs|dttd|dttd|dttd|dttd|dttd |d ttd |d ttd |dttd|dttd|dttd|dttd|dttd|dttd|dttd|tdtd|tdtd|tdtd |td!td"|td#td$|td%td&|td'td(|td)td*|td+td,|td-td.dS)/N)rYrR5)rUrXrfz +3/2)rXz-3/2 ) rXz 013/02 )rYz 3.2 )irYz -3.2 )rxrRz -3. )rUrYz .6 )rRi5 z32.e-5)i@BrRz1E+06)irRz-1.23e4rQz .0e+0 z-0.000e0zFraction(3, 0)z3/0z"Invalid literal for Fraction: '3/'z3/z"Invalid literal for Fraction: '/2'z/2z$Invalid literal for Fraction: '3 /2'z3 /2z$Invalid literal for Fraction: '3/+2'z3/+2z%Invalid literal for Fraction: '+ 3/2'z+ 3/2z#Invalid literal for Fraction: '3a2'Z3a2z%Invalid literal for Fraction: '3/7.2'z3/7.2z%Invalid literal for Fraction: '3.2/7'z3.2/7z!Invalid literal for Fraction: '.'.)rAr?rrPrgrqr(rrrtestFromStringslzFractionTest.testFromStringcCstdd}|dd|dt||tt|dd|tt|dd |dt|d |_d|_|d t|| td d|dS) NrSrUrXr[rTr<rer=)r~rX) rrrAr?rhAttributeErrorsetattrr8r9assertNotEqualrr>rrr testImmutables  zFractionTest.testImmutablecCs*|ttjd|dttdd}||dftt||dttd|dttd|d ttd |d ttd |td ttd |dttd|dttdd}||}|tdtj||tdtj| |t dtj|dS)N@@)rZrRrZl{C rRrQrk$@)rXg)ll+?RrRJ-Dr\)rll g @g(cannot convert Infinity to integer ratio#cannot convert NaN to integer ratio) rhr rrrAr?r rPrrrq)rZbigintrornrrr testFromFloats:  zFractionTest.testFromFloatcCs|ttjd|tddtd|tdttd|tddttd|tddttd |td ttd |dtdd ttd |tdtjtd|tdtjtd|tdtjtd|tdtjtddS)NrrZrRrz-0rYz0.5iz5e-3iZ5e3l73Me'z 0.999999999999999999999999999999rrorprrnru) rhr rZ from_decimalrArrPrrrqr(rrrtestFromDecimals2     zFractionTest.testFromDecimalcCs\|tddd|tddd|tddd|tddddS) Nr~r})rXrU)rWrUirrQ)rAras_integer_ratior(rrrtest_as_integer_ratiosz"FractionTest.test_as_integer_ratiocCstd}||dtdd||d tdd||dtdd||dtdd|td d d td |td d d tdd |tddtddD]}|tdtd j|qdS)Nz3.1415926535897932i'rcrdipiMjrtdrRefr)rrVz$max_denominator should be at least 1)rrAZlimit_denominatorrPrq)rZrpiirrrtestLimitDenominators z!FractionTest.testLimitDenominatorcCsr|dttdd|dttdd|dttdd|dttdd|dttdd|dttdd|dttdd|dttd d|dttd d|dttd d|d t tdd|d t tdd|dt tdd| t t td| dt ttdtd|dttdddS)NrVirZrRr^rWr`rrFTrUrXrmA22222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222227gUUUUUU?A33333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333331?)rEr1truncrfloorceilintroundrAboolr rhrrassertAlmostEqualcomplexr(rrrtestConversions-s$zFractionTest.testConversionscCsrtjGddd}tj||d}t|}||j||t|d|d}t|}|t|ddS)Nc@s8eZdZdZddZddZeddZdd ZeZ d S) z=FractionTest.testBoolGuarateesBoolReturn..CustomValuerRcSs ||_dSr)r r rrrrLszFFractionTest.testBoolGuarateesBoolReturn..CustomValue.__init__cSs t|jSr)rr r(rrr__bool__OszFFractionTest.testBoolGuarateesBoolReturn..CustomValue.__bool__cSs|Srrr(rrrr<RszGFractionTest.testBoolGuarateesBoolReturn..CustomValue.numeratorcSs tddS)Nz&Avoid comparisons in Fraction.__bool__)AssertionErrorrrrrrWszDFractionTest.testBoolGuarateesBoolReturn..CustomValue.__eq__N) r+r,r-r=rrpropertyr<rr#rrrr CustomValueHs rrRTrF) functoolstotal_orderingrrregisterrZassertIsr<r)rrr<r>rrrtestBoolGuarateesBoolReturnEs z(FractionTest.testBoolGuarateesBoolReturncCs|tdttdd|tdttdd|tdttdd|tddttd d d |tddttd d d dS) Ni8ijrWirVrZrrrRi)rErrr(rrr testRoundis zFractionTest.testRoundcCs|tddtddtdd|tddtddtdd|tddtddtdd|tddtddtdd|dtddtdd|d td dtd|tdd td d td d|tdd td d td d|tdtdd fttd d td d|tdtdd fttd d td d|tddtdd td |tddtdd td|dtdtdd|tddtdd ttdtdd}||jd||jdtddd}||tdd||jd||j dtddd}||tdd||jd||j dtddd}||tdd||jd||j ddS)NrRrXrZrYrxr~rar\r}rSrUrrW@rVr) rArrEdivmodpowrrealimagr<r=)rzprrrtestArithmeticps:"""""",,  zFractionTest.testArithmeticc Cs^|tddtddddtdddd|tddtd d  d td d d |d tddfttddddtdddd|d d dtd d  d td d d |dtd d d td d d |dtd d d fttd d d td d d |d d dtddfttd d  d td d d dS)Nl b;efOpUmnP|}l~Jw5PHyT#/jei4TrZ#rRlP~cegrSlrXrrUrYl_rtr[)rErrHrr(rrrtestLargeArithmeticsH"$  z FractionTest.testLargeArithmeticcCs|tddtddd|dtddd|dtddd|tdddtdd|ddtdd|ddtdd|tddtddd|d tddd|d tddd|td ddtdd|d dtdd|d dtdd|tddtddd|dtddd|dtddd|tdddtdd|ddtdd|ddtdd|tddtddd|dtddd|dtddd|tdddtdd|ddtdd|ddtdd|dtddd|dtddd|ddtdd|ddtdd|ddtdd|tddtddd|dtddd|tdddtdd|ddtdd|dtddtd|tdtddtd|tdtddtd|dtddtd|dtddfttddd|tddttddd|dtdftdtdd|tddtdtdd|tdtdttddtd|tdtdttddtd|tdtdttddtd|tdtdttddtd|tddtddd|tddtddd|dtddd|dtddd|ddtddtdtdd}|d|j|d|j |tdddtdd|d dtdd|d!d tdd|ddtdd| t t jtddddS)"Nr^rZrRg?g?y?y?r_gyrag?y?rmrry$@rr\ld&O!g"@g?rorprVgrrWrXr~rg?) rErr rHrrrrrArrhrgr)rrrrrtestMixedArithmeticsx" &&&&  z FractionTest.testMixedArithmeticcCs<|ttjtddtd|ttjtdtdddS)NrUr^z 3.1415926)rhr raddrrr(rrrtestMixingWithDecimals   z"FractionTest.testMixingWithDecimalcCs|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddkdS)NrRrXrU) assertTruer assertFalser(rrrtestComparisonsszFractionTest.testComparisonscCs|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddkdS)NrRrXrUr~rS)rrr0rr(rrrtestComparisonsDummyRational s8z)FractionTest.testComparisonsDummyRationalcCstd}tdd}|||k|||kp2||k|||k|||koV||k|||k|||kpz||k|||k|||ko||kdS)NgUUUUUU?rRrU)rrrr)rxyrrrtestComparisonsDummyFloat)s z&FractionTest.testComparisonsDummyFloatcCs4|dtddk|dtddk|tdddk|tdddk|tdddk|tdddk|dtddk|dtddk|td tddk|td td d k|td tddk|tddtd k|tddtd k|tddtd kdS)NrXrYr~rUrR333333?皙??rorprrZrnrxrSrerrrr r(rrr testMixedLess5szFractionTest.testMixedLesscCs4|dtddk|dtddk|tdddk|tdddk|dtddk|dtddk|tdddk|tdddk|td tddk|td td d k|td tddk|tddtd k|tddtd k|tddtd kdS)NrrRrXrrr~rUrYrorprrZrnrxrSrrerrrr(rrrtestMixedLessEqualGszFractionTest.testMixedLessEqualcCs|tdtdk|dtttddk|dttddk|dttddk|dttddk|dttddkdS)Nr\rrR)rrr r1rrr(rrrtestBigFloatComparisonsXs  z$FractionTest.testBigFloatComparisonscCs|tdtdk|ttjtdtd|ttjtdtdtdd}tdd}tdd}|||k|||k|||k|||ktj tjtjtj fD]D}|t||||t||||t||||t|||qdS)Nr\rUrg?rg?) rrrrhr rr&r rr"r$)rrrwrrrrtestBigComplexComparisonsbs   z&FractionTest.testBigComplexComparisonscCs|dtddk|dtddk|tdddk|tdddk|dtddk|dtddk|tdddk|tdddk|tddtd k|td tdd k|tddtd k|td tddkdS) NrrRrXrrr~rUrYrnrSrorprr(rrrtestMixedEqualtszFractionTest.testMixedEqualcCsp|dttdd|dttd|dttdd|d ttdd|d ttdddS) NzFraction(7, 3)rSrUz Fraction(6283185307, 2000000000)z 3.1415926535z#Fraction(-1, 100000000000000000000)rRl Fx:^Vz7/37)rAreprrrIr(rrrtestStringifications  z FractionTest.testStringificationcCstjj}tjj}|tdttdd|tddttdd|ttdttd||ttd||ttdtd dS) NrjrYrXrZ2r\rRrV) sys hash_infomodulusrorAhashrrr __hash__)rZhmodZhinfrrrtestHashs zFractionTest.testHashc Cstd}d|dddddf\}}}}}}}t||tddkr||}|||d}}|||d}}|||}||7}q(|tj|dS)NrUrrRʚ;r )rabsrr1pi) rZthreelaststsnZnaddarrrtestApproximatePis   zFractionTest.testApproximatePicCstd}ddtddddf\}}}}}}t||tddkr|}|d7}|||d9}|||9}|d9}||||7}q(|td|dS)NrRrrrXrV)rrrr1cos)rrrrrZfactr3signrrrtestApproximateCos1s  z FractionTest.testApproximateCos1cCstdd}tdd}||tt||t|tt||t|tt||t|tt||t|tt|| |t|| |t|dS)NryrS) rr;rArridrrrrE)rr>Zdrrrrtest_copy_deepcopy_pickles  z&FractionTest.test_copy_deepcopy_picklecCs tdd}|tt|dddS)NryrSarZ)rrhrrrrrr test_slotss zFractionTest.test_slotscCshGdddt}t|d|d}||jd||jd|t|j||t|j|dS)Nc@s<eZdZddZddZddZeddZed d Zd S) z-FractionTest.test_int_subclass..myintcSst|t|t|SrrBrrrrr__mul__sz5FractionTest.test_int_subclass..myint.__mul__cSst|t|t|Srrrrrr __floordiv__sz:FractionTest.test_int_subclass..myint.__floordiv__cSst|t|t|}|Srr)rrrrrr__mod__sz5FractionTest.test_int_subclass..myint.__mod__cSst|t|Srrr(rrrr<sz7FractionTest.test_int_subclass..myint.numeratorcSs t|dS)NrR)rBr(rrrr=sz9FractionTest.test_int_subclass..myint.denominatorN) r+r,r-rrrrr<r=rrrrmyints rrUr}rRrX)rr6r7rAr<r=rB)rrfrrrtest_int_subclasss zFractionTest.test_int_subclassN)&r+r,r-rErHrPrirrsrvr|rrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr@YsF   5$ "E        r@__main__)r.decimalrZ test.supportrr1rrr6rrZunittestrrpicklerrr7robjectrr0r;r?ZTestCaser@r+mainrrrrs0