a ze]v@sddlmZddlmZddlZddlZddlZddlZddlZddl Z ddl Z ddl m Z m Z ddl mZmZejZGdddeZGdd d eZGd d d ejZd d ZGddde jZedkre dS))Decimal)requires_IEEE_754N)copydeepcopy)dumpsloadsc@sXeZdZddZddZddZddZd d Zd d Zd dZ ddZ ddZ e Z dS) DummyFloatcCst|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__rrrr!r#r%r'r)r*__rsub__rrrrrsrc@sDeZdZddZddZddZddZd d Zd d Zd dZ dS) DummyRationalcCs$t||}|||_|||_dSr)mathgcdnumden)rr2r3grrrr4s  zDummyRational.__init__cCs,t|tjr$|j|jko"|j|jkStSdSr)r fractionsFractionr2 _numeratorr3 _denominatorrrrrrr9s    zDummyRational.__eq__cCs|j|j|j|jkSrr2r8r3r7rrrrr#@szDummyRational.__lt__cCs|j|j|j|jkSrr9rrrrr'CszDummyRational.__gt__cCs|j|j|j|jkSrr9rrrrr!FszDummyRational.__le__cCs|j|j|j|jkSrr9rrrrr%IszDummyRational.__ge__cCsdSrrr(rrrr)NszDummyRational.__float__N) r+r,r-rrr#r'r!r%r)rrrrr/1sr/c@s eZdZdS) DummyFractionN)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||||dSr) assertEqualtyperZexpectedactualrrrassertTypedEquals[szFractionTest.assertTypedEqualscCs0||||ttt|ttt|dSr)ZassertTupleEqualZassertListEquallistmaprArBrrrassertTypedTupleEquals`s z#FractionTest.assertTypedTupleEqualsc Os\z||i|Wn4|yF}z||t|WYd}~nd}~00|d|jdS)Nz %s not raised)r@strZfailr+)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)rQrRrRrT)rQrUrQ)rQrQ)rQ )rRrZ)m+?RrQr[)rTM )rXrW )i i cqzFraction(12, 0) ry?@3/2yy?)r@r>rrOZeroDivisionError assertRaisesr r(rrrtestInitos("zFractionTest.testInitcCsv|dttd|dttd|dttd|tttd|tttd|tttd dS) N)rXrW@rP)L33fl皙?naninf-inf)r@r>rrg ValueErrorr OverflowErrorr(rrrtestInitFromFloats zFractionTest.testInitFromFloatcCs|dtttd|dtttd|dtttd|tttd|tttd|tttd |tttd dS) N)r]rYz1.1)rRz3.5e-2rPz.000e20rmsnanrnro)r@r>rrrgrprqr(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)rXrQ5)rTrWrez +3/2)rWz-3/2 ) rWz 013/02 )rXz 3.2 )irXz -3.2 )rwrQz -3. )rTrXz .6 )rQi5 z32.e-5)i@BrQz1E+06)irQz-1.23e4rPz .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: '.'.)r@r>rrOrfrpr(rrrtestFromStringslzFractionTest.testFromStringcCstdd}|dd|dt||tt|dd|tt|dd |dt|d |_d|_|d t|| td d|dS) NrRrTrWrZrSr;rdr<)r}rW) rrr@r>rgAttributeErrorsetattrr7r8assertNotEqualrr=rrr testImmutables  zFractionTest.testImmutablecCs*|ttjd|dttdd}||dftt||dttd|dttd|d ttd |d ttd |td ttd |dttd|dttdd}||}|tdtj||tdtj| |t dtj|dS)N@@)rYrQrYl{C rQrPrj$@)rWg)ll+?RrQJ-Dr[)rkl g @g(cannot convert Infinity to integer ratio#cannot convert NaN to integer ratio) rgr rrr@r>r rOrqrp)rZbigintrnrmrrr testFromFloats:  zFractionTest.testFromFloatcCs|ttjd|tddtd|tdttd|tddttd|tddttd |td ttd |dtdd ttd |tdtjtd|tdtjtd|tdtjtd|tdtjtddS)NrrYrQrz-0rXz0.5iz5e-3iZ5e3l73Me'z 0.999999999999999999999999999999rrnrorrmrt) rgr rZ from_decimalr@rrOrqrpr(rrrtestFromDecimals2     zFractionTest.testFromDecimalcCs\|tddd|tddd|tddd|tddddS) Nr}r|)rWrT)rVrTirrP)r@ras_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'rbrcipiMjrsdrQefr)rrUz$max_denominator should be at least 1)rr@Zlimit_denominatorrOrp)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)NrUirYrQr]rVr_rrFTrTrWrlA22222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222227gUUUUUU?A33333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333333331?)rDr0truncrfloorceilintroundr@boolr rgrqassertAlmostEqualcomplexr(rrrtestConversions-s$zFractionTest.testConversionscCsrtjGddd}tj||d}t|}||j||t|d|d}t|}|t|ddS)Nc@s8eZdZdZddZddZeddZdd ZeZ d S) z=FractionTest.testBoolGuarateesBoolReturn..CustomValuerQcSs ||_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 rrQTrF) functoolstotal_orderingrrregisterrZassertIsr;r)rrr;r=rrrtestBoolGuarateesBoolReturnEs z(FractionTest.testBoolGuarateesBoolReturncCs|tdttdd|tdttdd|tdttdd|tddttd d d |tddttd d d dS) Ni8ijrVirUrYrrrQi)rDrrr(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)NrQrWrYrXrwr}r`r[r|rRrTrrV@rUr) r@rrDdivmodpowrrealimagr;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#/jei4TrY#rQlP~cegrRlrWrrTrXl_rsrZ)rDrrGrr(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]rYrQg?g?y?y?r^gyr`g?y?rlrry$@rr[ld&O!g"@g?rnrorUgrrVrWr}rg?) rDrr rGrrrrr@rrgrfr)rrrrrtestMixedArithmeticsx" &&&&  z FractionTest.testMixedArithmeticcCs<|ttjtddtd|ttjtdtdddS)NrTr]z 3.1415926)rgr raddrrr(rrrtestMixingWithDecimals   z"FractionTest.testMixingWithDecimalcCs|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddk|tddtddkdS)NrQrWrT) 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)NrQrWrTr}rR)rrr/rr(rrrtestComparisonsDummyRational s8z)FractionTest.testComparisonsDummyRationalcCstd}tdd}|||k|||kp2||k|||k|||koV||k|||k|||kpz||k|||k|||ko||kdS)NgUUUUUU?rQrT)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)NrWrXr}rTrQ333333?皙??rnrorrYrmrwrRrdrrrr 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)NrrQrWrrr}rTrXrnrorrYrmrwrRrrdrrrr(rrrtestMixedLessEqualGszFractionTest.testMixedLessEqualcCs|tdtdk|dtttddk|dttddk|dttddk|dttddk|dttddkdS)Nr[rrQ)rrr r0rrr(rrrtestBigFloatComparisonsXs  z$FractionTest.testBigFloatComparisonscCs|tdtdk|ttjtdtd|ttjtdtdtdd}tdd}tdd}|||k|||k|||k|||ktj tjtjtj fD]D}|t||||t||||t||||t|||qdS)Nr[rTrg?rg?) rrrrgr 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) NrrQrWrrr}rTrXrmrRrnrorr(rrrtestMixedEqualtszFractionTest.testMixedEqualcCsp|dttdd|dttd|dttdd|d ttdd|d ttdddS) NzFraction(7, 3)rRrTz Fraction(6283185307, 2000000000)z 3.1415926535z#Fraction(-1, 100000000000000000000)rQl Fx:^Vz7/37)r@reprrrHr(rrrtestStringifications  z FractionTest.testStringificationcCstjj}tjj}|tdttdd|tddttdd|ttdttd||ttd||ttdtd dS) NrirXrWrY2r[rQrU) sys hash_infomodulusrnr@hashrrr __hash__)rZhmodZhinfrrrtestHashs zFractionTest.testHashc Cstd}d|dddddf\}}}}}}}t||tddkr||}|||d}}|||d}}|||}||7}q(|tj|dS)NrTrrQʚ;r )rabsrr0pi) rZthreelaststsnZnaddarrrtestApproximatePis   zFractionTest.testApproximatePicCstd}ddtddddf\}}}}}}t||tddkr|}|d7}|||d9}|||9}|d9}||||7}q(|td|dS)NrQrrrWrU)rrrr0cos)rrrrrZfactr2signrrrtestApproximateCos1s  z FractionTest.testApproximateCos1cCstdd}tdd}||tt||t|tt||t|tt||t|tt||t|tt|| |t|| |t|dS)NrxrR) rr:r@rridrrrrD)rr=Zdrrrrtest_copy_deepcopy_pickles  z&FractionTest.test_copy_deepcopy_picklecCs tdd}|tt|dddS)NrxrRarY)rrgr~rrrrr 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|SrrArrrrr__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)NrQ)rAr(rrrr<sz9FractionTest.test_int_subclass..myint.denominatorN) r+r,r-rrrrr;r<rrrrmyints rrTr|rQrW)rr5r6r@r;r<rA)rrfrrrtest_int_subclasss zFractionTest.test_int_subclassN)&r+r,r-rDrGrOrhrrrrur{rrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr?YsF   5$ "E        r?__main__)decimalrZ test.supportrr0rrr5rrZunittestrrpicklerrr6robjectrr/r:r>ZTestCaser?r+mainrrrrs.