U
    9%e                     @   s
  d Z ddlZddlZddlZddlZddlZddlZddlm	Z	m
Z
mZ ddlmZ ddlmZmZ ddlmZ ddlmZmZmZ ddlmZmZ ed	Zed
Zdd ZdZdZee Z dd Z!dd Z"dd Z#dd Z$dd Z%dd Z&dd Z'dd Z(dd  Z)d!d" Z*d#d$ Z+d%d& Z,d'd( Z-d)d* Z.d+d, Z/d-d. Z0d/d0 Z1d1d2 Z2d3d4 Z3G d5d6 d6eZ4ej5Z6ej7Z8G d7d8 d8eZ9G d9d: d:eZ:G d;d< d<e:Z;G d=d> d>eZ<G d?d@ d@e<Z=G dAdB dBeZ>G dCdD dDeZ?G dEdF dFeZ@eAdGkreB  dS )Hz0
Test np.datetime64 and np.timedelta64 support.
    N)jit	vectorizenjit)numpy_version)typesconfig)TypingError)TestCasetagskip_parfors_unsupported)npdatetime_helpersnumpy_supportztimedelta64[M]ztimedelta64[Y]c                 C   s   t | j}|jS N)r   Z
from_dtypedtypeunit)valty r   Z/var/www/html/Darija-Ai-API/env/lib/python3.8/site-packages/numba/tests/test_npdatetime.py
value_unit   s    r   )YM)WDhmsmsusnspsfsasc                 C   s   | | S r   r   xyr   r   r   add_usecase%   s    r&   c                 C   s   | | S r   r   r#   r   r   r   sub_usecase(   s    r'   c                 C   s   | | S r   r   r#   r   r   r   mul_usecase+   s    r(   c                 C   s   | | S r   r   r#   r   r   r   div_usecase.   s    r)   c                 C   s   | | S r   r   r#   r   r   r   floordiv_usecase1   s    r*   c                 C   s   | |kS r   r   r#   r   r   r   
eq_usecase4   s    r+   c                 C   s   | |kS r   r   r#   r   r   r   
ne_usecase7   s    r,   c                 C   s   | |k S r   r   r#   r   r   r   
lt_usecase:   s    r-   c                 C   s   | |kS r   r   r#   r   r   r   
le_usecase=   s    r.   c                 C   s   | |kS r   r   r#   r   r   r   
gt_usecase@   s    r/   c                 C   s   | |kS r   r   r#   r   r   r   
ge_usecaseC   s    r0   c                 C   s   | 
 S r   r   r$   r   r   r   pos_usecaseF   s    r2   c                 C   s   |  S r   r   r1   r   r   r   neg_usecaseI   s    r3   c                 C   s   t | S r   )absr1   r   r   r   abs_usecaseL   s    r5   c                 C   s   t | S r   )hashr1   r   r   r   hash_usecaseO   s    r7   c                 C   s
   t | |S r   minr#   r   r   r   min_usecaseR   s    r:   c                 C   s
   t | |S r   maxr#   r   r   r   max_usecaseU   s    r=   c                 C   s   t | S r   )intr1   r   r   r   int_cast_usecaseX   s    r?   c                    s    fdd}|S )Nc                    s   |   S r   r   r1   constr   r   add_constant\   s    z'make_add_constant.<locals>.add_constantr   )rA   rB   r   r@   r   make_add_constant[   s    rC   c                   @   s8   e Zd ZdZdd Zdd Zdd Zdd	 Zd
d ZdS )TestModuleHelpersz?
    Test the various helpers in numba.npdatetime_helpers.
    c                    s   t j tttD ]4\}} ||||f  ||||f qtD ]$} |d  d| qLtd D ]} || qz fdd}|t |t d S )N rE   c                    sH   t | D ]:\}}| d | D ]$} ||  || qqd S r   )	enumerate
assertTrueassertFalsegroupiabfselfr   r   check_units_groupq   s    zDTestModuleHelpers.test_can_cast_timedelta.<locals>.check_units_group)	r   Zcan_cast_timedelta_units	itertoolsproduct
date_units
time_unitsrI   	all_unitsrH   )rQ   rM   rN   r   rR   r   rO   r   test_can_cast_timedeltaf   s    z)TestModuleHelpers.test_can_cast_timedeltac                    s   t j td D ]} ||d qtD ]} d|d q*tttD ],\}} ||d   ||d  qN fdd}|t |t  ddd  d	d
d  d	dd  d	dd d S )NrF      rE   c                    sR   t | D ]D\}}| d | D ].} ||d||f  ||d  qqd S )NrY   )rG   ZassertGreaterassertIsrJ   rO   r   r   rR      s    zFTestModuleHelpers.test_timedelta_conversion.<locals>.check_units_groupr   r      r   r      r   i`'  r   l     !3)	r   Zget_timedelta_conversion_factorrW   assertEqualrS   rT   rV   rU   rZ   )rQ   r   rM   rN   rR   r   rO   r   test_timedelta_conversion|   s    z+TestModuleHelpers.test_timedelta_conversionc                    s  t j  fdd}tttD ]\}}||| q tttD ]\}} || q@tttD ]\}} || q`tttD ]\}} || qtD ]F} |||ddf  |d|ddf  d|d q 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 S )Nc              	      s$    t  | | W 5 Q R X d S r   )assertRaisesRuntimeError)dt_unittd_unitrO   r   r   check_error   s    zFTestModuleHelpers.test_datetime_timedelta_scaling.<locals>.check_errorrY   rE   )rE   rY   rY   r   r   )r   r[   rY   )r   rY   r[   r   r   )r      rY   )r   rY   rd   r   )r   :	 rY   )r   rY   re   r"   )r"        NZorY   )r"   rY   rf   )r   :   )r   rg   i
  )r   rg     )r   rg   i@  )r      Y` rh   )r   rj   ri   )r   Z!get_datetime_timedelta_conversionrS   rT   rV   rU   rW   r]   )rQ   rc   ra   rb   r   r   rO   r   test_datetime_timedelta_scaling   s:    z1TestModuleHelpers.test_datetime_timedelta_scalingc                 C   s   t j}tD ]:}| |||| | |d|| | ||d| q
| |ddd tttD ]\}}| |||d  qdtttD ]\}}| |||| qd S )NrE   )	r   Z combine_datetime_timedelta_unitsrW   r]   rS   rT   rV   rU   rZ   )rQ   rP   r   ra   rb   r   r   r   %test_combine_datetime_timedelta_units   s    z7TestModuleHelpers.test_combine_datetime_timedelta_unitsc                 C   s   t j}tD ]}| ||| q
d}d}t||D ]\}}| ||| q4t||D ]\}}| ||| qZt||D ](\}}| ||| | ||| qd S )N)r   r   r   r   )	r   r   r   r   r   r   r    r!   r"   )r   	same_kindrW   rH   rS   rT   rI   )rQ   rP   uABrM   rN   r   r   r   test_same_kind   s    z TestModuleHelpers.test_same_kindN)	__name__
__module____qualname____doc__rX   r^   rk   rl   rq   r   r   r   r   rD   a   s   'rD   c                   @   s,   e Zd Zdd Zdd Zdd Zdd Zd	S )
TestMiscCompilingc                    s@    fdd}t dt dt d}|| d}|| d S )Nc                    s@   t | ddt}tddtddf}t| } || | d S )NTZnopythonrY   r      r   )r   r&   DTTDassertPreciseEqual)sigrP   argsexpectedrQ   r   r   _check_explicit_signature   s    zPTestMiscCompiling.test_jit_explicit_signature.<locals>._check_explicit_signaturer   r   z5NPDatetime('us')(NPDatetime('ms'), NPTimedelta('us')))r   Z
NPDatetimeNPTimedeltarQ   r   r|   r   r   r   test_jit_explicit_signature   s
    z-TestMiscCompiling.test_jit_explicit_signaturec                    s<    fdd}t dt dt j}|| d}|| d S )Nc                    s0   t | gddt} |tddtd d S )NTrw   rx         )r   r(   r{   rz   )r|   rP   r   r   r   r      s    zVTestMiscCompiling.test_vectorize_explicit_signature.<locals>._check_explicit_signaturer   z)NPTimedelta('s')(NPTimedelta('s'), int64))r   r   int64r   r   r   r   !test_vectorize_explicit_signature   s
    z3TestMiscCompiling.test_vectorize_explicit_signaturec                    s*    fdd}|t d |t dd d S )Nc                    s<   t | }tdd|}tdd}||} ||| d S NTrw      r   rC   r   rz   r{   rA   pyfuncrP   r$   r~   r   r   r   check   s
    
z7TestMiscCompiling.test_constant_datetime.<locals>.checkz
2001-01-01NaTr   ry   rQ   r   r   r   r   test_constant_datetime   s    z(TestMiscCompiling.test_constant_datetimec                    s:    fdd}|t dd |t dd |t dd d S )Nc                    s<   t | }tdd|}tdd}||} ||| d S r   r   r   r   r   r   r     s
    
z8TestMiscCompiling.test_constant_timedelta.<locals>.checkr   r   r   )rz   r   r   r   r   test_constant_timedelta  s    z)TestMiscCompiling.test_constant_timedeltaN)rr   rs   rt   r   r   r   r   r   r   r   r   rv      s   
rv   c                   @   s   e Zd ZeddZdd Zdd Zdd Zd	d
 Zdd Z	dd Z
dd Zdd Zdd Zdd Zdd Zdd Zdd Zdd Zdd  Zd!d" Zd#S )$TestTimedeltaArithmeticTZforceobjc                 C   s   t f | j|S r   r   jitargsrQ   r   r   r   r   r     s    zTestTimedeltaArithmetic.jitc              	      s   t  fdd}|tdtdt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
 |tdtdtd |tddtdd
tdd |tddtddtdd ttf  tddtdd
 W 5 Q R X d S )Nc                    s(     | ||   || | d S r   r{   rM   rN   r~   rO   r   r   r     s    z/TestTimedeltaArithmetic.test_add.<locals>.checkrY   rx   r   r   r   iBB r   r   	   r   r   r   )r   r&   rz   r_   	TypeErrorr   r   r   rO   r   test_add  s    
z TestTimedeltaArithmetic.test_addc              	      s   t  fdd}|tdtdt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
 |tdtdtd |tddtdd
tdd |tddtddtdd ttf  tddtdd
 W 5 Q R X d S )Nc                    s*     | ||   || |  d S r   r   r   rO   r   r   r   -  s    z/TestTimedeltaArithmetic.test_sub.<locals>.checkr   rx   rY   r   r   i- r   r      r   r   r   )r   r'   rz   r_   r   r   r   r   rO   r   test_sub+  s    
z TestTimedeltaArithmetic.test_subc                    s   t  fdd}|tdtdtd |tddtd |tdddtdd |tdddtdd |tdd	td
 |tdd	td |tdddtdd |tddtd
 |tdddtdd |tddtdtdd |tdddtdd d S )Nc                    s(     | ||   || | d S r   r   r   rO   r   r   r   @  s    z/TestTimedeltaArithmetic.test_mul.<locals>.checkr   rx   r   r    r   rd         ?
   ig      nanl               r   )r   r(   rz   npuint32floatr   r   rO   r   test_mul>  s    
z TestTimedeltaArithmetic.test_mulc                    sf   t  t fdd}|tddtdtdd |tddtd |tdddtdd |td	ddtd	d |tddd
td	d |td	dd
td	d |tddtd |tdddtdd |td	ddtd	d |tdddtd	d |td	ddtd	d |tddtdtd	d |td	dtdtd	d d S )Nc                    s(     | ||  | || d S r   r   r   divfloordivrQ   r   r   r   W  s    z/TestTimedeltaArithmetic.test_div.<locals>.checkr    rx   r   rY   r   r   rd   g      ?   r   r   r   g      @g        r   )r   r)   r*   rz   r   r   r   r   r   r   r   test_divT  s     

z TestTimedeltaArithmetic.test_divc              	      s    t  fdd}|tdtdd |tddtddd |tddtddd	 |tdtd
td |tdtd
td |td
td
td |tdtdtd |tdtdtd |tdtd
td ttf  tddtdd W 5 Q R X d S )Nc                    s     | || d S r   r   r   r   rQ   r   r   r   n  s    z;TestTimedeltaArithmetic.test_homogeneous_div.<locals>.checkrd   r   g@r   r   gQFoZc?g:@r   z+infr   z-infr   ZnatrY   r   r   )r   r)   rz   r   r_   r   r   r   r   r   r   test_homogeneous_divl  s    
z,TestTimedeltaArithmetic.test_homogeneous_divc              	      s   t  t fdd}|tdtdd |tdtdd |tddtddd |tddtddd |tddtddd |tdd	tddd |tdd
tddd |tdtdd |tdd	tddd |tdtdd tdk rX|tdd
tddd |tdd
tddd |tddtddd n`ttf  tdd
tdd W 5 Q R X ttf tdd
tdd W 5 Q R X d S )Nc                    sr   |}| }t | st | r&d}d} | ||  || | | || || | d S NFTr   isnatr{   rM   rN   r~   expected_valnot_expected_valeqnerQ   r   r   r     s    z1TestTimedeltaArithmetic.test_eq_ne.<locals>.checkrY   rx   FTr   i  r   r   r[   r   Nat)rY      m  r   in  r   r   )r   r+   r,   rz   r   r_   r   r   r   r   r   r   
test_eq_ne  s*    


 z"TestTimedeltaArithmetic.test_eq_nec              	      s   t t  fdd}|tdtdd |tdtdd |tdtdd |tddtddd |tddtddd |tddtddd |tddtd	dd |tddtd
dd |tdtdd |tddtddd |tdtdd ttf tddtdd W 5 Q R X ttf  tddtdd W 5 Q R X ttf tddtdd W 5 Q R X ttf  tddtdd W 5 Q R X d S )Nc                    sN   |}| }t | st | r&d}d}| ||  | || d S NFr   r   geltrQ   r   r   r     s    z1TestTimedeltaArithmetic.test_lt_ge.<locals>.checkrY   rx   TFr   r   =   <   r   r    r   r   r   r   )r   r-   r0   rz   r_   r   r   r   r   r   r   
test_lt_ge  s,    

   z"TestTimedeltaArithmetic.test_lt_gec              	      s   t t  fdd}|tdtdd |tdtdd |tdtdd |tddtddd |tddtddd |tddtddd |tddtd	dd |tddtd
dd |tddtddd |tdtdd |tddtddd |tdtdd ttf tddtdd W 5 Q R X ttf  tddtdd W 5 Q R X ttf tddtdd W 5 Q R X ttf  tddtdd W 5 Q R X d S )Nc                    sN   |}| }t | st | r&d}d}| ||  | || d S r   r   r   gtlerQ   r   r   r     s    z1TestTimedeltaArithmetic.test_le_gt.<locals>.checkrY   rx   TFr   r   r   r   ;   r   r   r   r   r   r   r   )r   r.   r/   rz   r_   r   r   r   r   r   r   
test_le_gt  s.    

   z"TestTimedeltaArithmetic.test_le_gtc                    sj    t  fdd}|td |td |tdd |tdd |td |tdd d S )Nc                    s     | | 
  d S r   r   rM   posrQ   r   r   r     s    z/TestTimedeltaArithmetic.test_pos.<locals>.checkr   r   r   r   )r   r2   rz   r   r   r   r   test_pos  s    
z TestTimedeltaArithmetic.test_posc                    sj    t  fdd}|td |td |tdd |tdd |td |tdd d S )Nc                    s     | |   d S r   r   r   negrQ   r   r   r     s    z/TestTimedeltaArithmetic.test_neg.<locals>.checkr   r   r   r   )r   r3   rz   r   r   r   r   test_neg  s    
z TestTimedeltaArithmetic.test_negc                    sj    t  fdd}|td |td |tdd |tdd |td |tdd d S )Nc                    s     | t|  d S r   )r{   r4   r   rO   r   r   r     s    z/TestTimedeltaArithmetic.test_abs.<locals>.checkr   r   r   r   )r   r5   rz   r   r   rO   r   test_abs  s    
z TestTimedeltaArithmetic.test_absc                    s`    t  fdd}d}d}t|| tft| tft|  D ]\}}|||  qFd S )Nc                    s     | t|  d S r   )r{   r6   r   rO   r   r   r     s    z0TestTimedeltaArithmetic.test_hash.<locals>.check))r   )r   )r   r   )r   r   )   r   )rx   r   )rx   r   )rx   r   )r   r   )r   r   )'  r   )r   r   )r   r   )r   r   )r   ))2014)2016)2000)2014-02)2014-03)2014-04)2016-02)
2000-12-31)
2014-01-16)
2014-01-05)
2014-01-07)
2014-01-06)
2014-02-02)
2014-02-27)
2014-02-16)
2014-03-01)2000-01-01T01:02:03.002Z)2000-01-01T01:02:03Zr   )r   r7   ziprz   lenry   )rQ   r   ZTD_CASESZDT_CASEScasetypr   rO   r   	test_hash  s    
z!TestTimedeltaArithmetic.test_hashc                    s      fdd}tdtdtdtdftddtddtddtddffD ]$}t||D ]\}}||| qjqZd S )Nc                    s     | || | d S r   r   rM   rN   rP   rQ   usecaser   r   r   3  s    z4TestTimedeltaArithmetic._test_min_max.<locals>.checkr   rY   rx   r   r   )r   rz   rS   rT   rQ   r   r   ZcasesrM   rN   r   r   r   _test_min_max1  s    
"z%TestTimedeltaArithmetic._test_min_maxc                 C   s   |  t d S r   r   r:   r   r   r   r   test_min=  s    z TestTimedeltaArithmetic.test_minc                 C   s   |  t d S r   r   r=   r   r   r   r   test_max@  s    z TestTimedeltaArithmetic.test_maxN)rr   rs   rt   dictr   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r     s"   
+''r   c                   @   s   e Zd ZeddZdd ZdS )TestTimedeltaArithmeticNoPythonTrw   c              	      s    t  fdd}dD ]\}}|t||d qdD ]}|t|d q>jtdd  td	 W 5 Q R X d S )
Nc                    s     | t|  d S r   )r{   r>   r   rO   r   r   r   J  s    z<TestTimedeltaArithmeticNoPython.test_int_cast.<locals>.check))r   r   )r   r   )i0u  r   )i r   )rY   r   ztimedelta64[ns])r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   datetime64[ns]z;Only datetime64[ns] can be converted, but got datetime64[y])msgr   )r   r?   rz   astypery   r_   r   )rQ   r   deltar   timer   rO   r   test_int_castH  s    
z-TestTimedeltaArithmeticNoPython.test_int_castN)rr   rs   rt   r   r   r   r   r   r   r   r   D  s   
r   c                   @   sd   e Zd ZeddZdd Zejdd Zdd Z	d	d
 Z
dd Zdd Zdd Zdd Zdd ZdS )TestDatetimeArithmeticTr   c                 C   s   t f | j|S r   r   r   r   r   r   r   b  s    zTestDatetimeArithmetic.jitc              	   c   s.   t   t jddtd d V  W 5 Q R X d S )Nignorez-Implicitly casting between incompatible kinds)messagecategory)warningscatch_warningsfilterwarningsDeprecationWarningr   r   r   r   silence_numpy_warningse  s    
z-TestDatetimeArithmetic.silence_numpy_warningsc                    s   t  t fdd}|tdtddtd |tdtddtd |tdtd	d
tdd
 |tdtddtd |tdtddtd |tdtddtd |tdtddtd |tdtddtd |tdd
tdd
tdd
 |tdtddtd |tdtddtd |tdtdd
td |tdtddtd |tdtdd td! d"D ]}d#D ]}t|| }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
td$dtd%dtd&dtd'dfD ]\} |||| ||f  |||| ||f || || ||f q&qq|td(tdtd( |td(d)tddtd(d) |td(d)tdd td(d  |tdtd(d
td(d
 |td*td(d
td(d |td(d)td(d td(d   fD ]f}ttf |td+d*td+d W 5 Q R X ttf |td+d*td+d W 5 Q R X q>d,S )-zQ
        Test `datetime64 + timedelta64` and `datetime64 - timedelta64`.
        c              	      sr     `  | ||| |f  || || |f | | || |f | | | W 5 Q R X d S r   r  r{   r   addrQ   subr   r   r   u  s
    
z<TestDatetimeArithmetic.test_add_sub_timedelta.<locals>.checkr   rx   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   z
2014-02-03r   r   r   r   z
2012-02-02z
2012-02-29z
2012-02-16r   r   z2000-01-01T03:02:03Zr   r   )600601604Z801Z1900Z1904Z2200Z2300Z23042400Z6001)rE   -01-12d   r   ir   r   r   
2014-01-01rY   N)	r   r&   r'   ry   rz   r]   r_   r   r   )rQ   r   Zdt_strZ	dt_suffixdttdrP   r   r
  r   test_add_sub_timedeltao  s`    

	      * z-TestDatetimeArithmetic.test_add_sub_timedeltac                 C   sZ   ddddddddd	d
ddg}dddddddg}dd t ||D }|dd |D 7 }|S )Nr  r  r  Z1968Z1969Z1973r   Z2004Z2005Z2100r  Z2401rE   r  r  z-02-28z-12-31z-01-05T12:30:56Zz-01-05T12:30:56.008Zc                 S   s   g | ]\}}t || qS r   r   ).0rM   rN   r   r   r   
<listcomp>  s     z;TestDatetimeArithmetic.datetime_samples.<locals>.<listcomp>c                 S   s   g | ]}t |d qS )r   r   )r  r   r   r   r   r    s     )rS   rT   )rQ   Zdt_yearsZdt_suffixesdtsr   r   r   datetime_samples  s         
 z'TestDatetimeArithmetic.datetime_samplesc              	      s     td fdd	}|tdtdtdd |tdtd	td
d |tdtdtdd |tddtdtdd |tddtdtdd |tdtdtd   V   }t||D ]:\}}t	t
|t
|sqֈ |||| ||f qW 5 Q R X dS )z1
        Test `datetime64 - datetime64`.
        Nc              	      s`      N  | || | | |f  || ||  | |f  | | | W 5 Q R X d S r   r	  r   rQ   r  r   r   r     s    
z>TestDatetimeArithmetic.test_datetime_difference.<locals>.checkr   2017r   r   r   z2017-01ir   z
2014-02-28z
2015-03-01ir   r   r   z
2000-01-01)N)r   r'   ry   rz   r  r  rS   rT   r   rm   r   r{   )rQ   r   r  rM   rN   r   r  r   test_datetime_difference  s    

z/TestDatetimeArithmetic.test_datetime_differencec           	   	      s   t t t t t tfdd  fdd} tdtdd  tdtdd	  tdtd
d	  tdtd
dd	  tdtd
dd	  td
td
dd  tdtddd	  tddtddd	  tddtddd |tddtdd	  tdtdd	  }|D ]}|j	j
dd d d }t|}t||d  }|D ]j}|d| }tt|t|sʐq ||d	 |||td| d	 ||td| |d	 qqbd S )Nc              	      s  |}| }t | st |rd}d}| || |f | || |f || | |f || | |f | || |f | || |f || | |f || | |f  4  | ||| ||f  || || ||f | ||| ||f || || ||f |r | || |f | || |f || | |f || | |f | || |f | || |f || | |f || | |f | |k| W 5 Q R X d S r   )r   r   rI   r  r{   rH   r   )r   r   r   r   r   r   rQ   r   r   check_eq  s8    z9TestDatetimeArithmetic.test_comparisons.<locals>.check_eqc              	      s   |}| }t | st |r&d}d}  t}|| ||| ||f || || ||f | ||| ||f || || ||f |r | |d | |k | W 5 Q R X d S r   )r   r   r  r   r-   r{   )rM   rN   r~   r   r   r   )r  r   r   r   rQ   r   r   check_lt  s    

z9TestDatetimeArithmetic.test_comparisons.<locals>.check_ltr   r  Fz2014-01Tr  r   z
2014-01-02r   z2014-01-01T00:01:00Zr   z2014-01-01T00:01Zr   z2014-01-01T00:01:01Zr   r   [rY   r   r   zM8[%s])r   r+   r,   r-   r.   r/   r0   ry   r  r   strsplitrW   indexr   r   rm   r   r   timedelta64)	rQ   r   r  rM   Za_unitrL   Zunitsr   rN   r   )r  r   r   r   r   r   r   rQ   r   test_comparisons  sN    





%
 
 

z'TestDatetimeArithmetic.test_comparisonsc                    s      fdd}tddtddtddtddftddtddtddtddffD ]$}t||D ]\}}||| qrqbd S )	Nc                    s     | || | d S r   r   r   r   r   r   r   <  s    z3TestDatetimeArithmetic._test_min_max.<locals>.checkr   r   rY   rx   r   r   )r   ry   rS   rT   r   r   r   r   r   :  s    
""z$TestDatetimeArithmetic._test_min_maxc                 C   s   |  t d S r   r   r   r   r   r   r   F  s    zTestDatetimeArithmetic.test_minc                 C   s   |  t d S r   r   r   r   r   r   r   I  s    zTestDatetimeArithmetic.test_maxN)rr   rs   rt   r   r   r   
contextlibcontextmanagerr  r  r  r  r&  r   r   r   r   r   r   r   r   ^  s   

	A	fr   c                   @   s   e Zd ZeddZdS )TestDatetimeArithmeticNoPythonTrw   N)rr   rs   rt   r   r   r   r   r   r   r)  L  s   r)  c                   @   s0   e Zd ZdZdd Zdd Zdd Zdd	 Zd
S )TestMetadataScalingFactorzf
    Tests than non-1 scaling factors are not supported in datetime64
    and timedelta64 dtypes.
    c                 K   s,   t f |t}| |tddtd d S )Nr   10YZ2010)r   r+   rH   ry   rQ   r   r   r   r   r   test_datetimeW  s    z'TestMetadataScalingFactor.test_datetimec              	   C   s$   |    | jdd W 5 Q R X d S NTrw   )assertTypingErrorr-  r   r   r   r   test_datetime_npm[  s    
z+TestMetadataScalingFactor.test_datetime_npmc                 K   s.   t f |t}| |tddtdd d S )Nrx   r+     r   )r   r+   rH   rz   r,  r   r   r   test_timedelta_  s    z(TestMetadataScalingFactor.test_timedeltac              	   C   s$   |    | jdd W 5 Q R X d S r.  )r/  r2  r   r   r   r   test_timedelta_npmc  s    
z,TestMetadataScalingFactor.test_timedelta_npmN)rr   rs   rt   ru   r-  r0  r2  r3  r   r   r   r   r*  Q  s
   r*  c                   @   s   e Zd Zdd ZdS )TestDatetimeDeltaOpsc                 C   s   dd }|}t |}tdttdtftdttdtftdttdtftdttdtftdtdftdttdtjftdttdtjfg}|D ]&\}}| t|||||| qdS )zC
        Test the division of a timedelta by numeric types
        c                 S   s   | | S r   r   r   r   r   r   arr_divm  s    z.TestDatetimeDeltaOps.test_div.<locals>.arr_divr   rY   N)	r   r   ZonesTIMEDELTA_MTIMEDELTA_Yr   Zfloat64rH   array_equal)rQ   r5  py_funccfunc
test_casesrM   rN   r   r   r   r   i  s    	zTestDatetimeDeltaOps.test_divN)rr   rs   rt   r   r   r   r   r   r4  h  s   r4  c                   @   s   e Zd Zdd Zdd Zedd Zdd Zed	d
 Zdd Z	dd Z
dd Zdd Zdd Zdd Zdd Zdd Zdd Zdd Zedd  Zed!d" Zed#d$ Zed%d& Zd'S )(TestDatetimeArrayOpsc              	      s"   fdd}t jt dt dt dt dgdd}t jt dt dt dt dgd	d}|}t|d
|}|t df|t df|t df|t dfg} t jkr|t d|ft d|ft d|ft d|fg |D ]&\}	}
| t ||	|
||	|
 qdS )zY
        Test the addition/subtraction of a datetime array with a timedelta type
        c                    s
    | |S r   r   r   	operationr   r   impl  s    z6TestDatetimeArrayOps._test_td_add_or_sub.<locals>.impl
2011-01-01
1971-02-02
2021-03-03
2004-12-07r   r   zdatetime64[D]parallel  i*N)	r   array
datetime64r   r%  r  extendrH   r8  )rQ   r>  rF  r?  Zarr_oneZarr_twor9  r:  r;  rM   rN   r   r=  r   _test_td_add_or_sub  sB    
z(TestDatetimeArrayOps._test_td_add_or_subc                 C   s   |  tjd d S r   rK  r   r  r   r   r   r   test_add_td  s    z TestDatetimeArrayOps.test_add_tdc                 C   s   |  tjd d S NTrL  r   r   r   r   test_add_td_parallel  s    z)TestDatetimeArrayOps.test_add_td_parallelc                 C   s   |  tjd d S r   rK  r   subtractr   r   r   r   test_sub_td  s    z TestDatetimeArrayOps.test_sub_tdc                 C   s   |  tjd d S rN  rP  r   r   r   r   test_sub_td_parallel  s    z)TestDatetimeArrayOps.test_sub_td_parallelc              	      sl   t  fdd} j}td| d}| ttf|* |tjt	dgddt
dd	 W 5 Q R X d
S )z
        Tests that attempting to add/sub a datetime64 and timedelta64
        with types that cannot be cast raises a reasonable exception.
        c                    s
    | |S r   r   r   r=  r   r   r?    s    z<TestDatetimeArrayOps._test_add_sub_td_no_match.<locals>.implzufunc 'z<' is not supported between datetime64[ns] and timedelta64[M]r@  r   rD  rG  r   N)r   rr   reescapeassertRaisesRegexr   r   r   rH  rI  r%  )rQ   r>  r?  fnamer~   r   r=  r   _test_add_sub_td_no_match  s    
z.TestDatetimeArrayOps._test_add_sub_td_no_matchc                 C   s   |  tj d S r   )rX  r   r  r   r   r   r   test_add_td_no_match  s    z)TestDatetimeArrayOps.test_add_td_no_matchc                 C   s   |  tj d S r   )rX  r   rQ  r   r   r   r   test_sub_td_no_match  s    z)TestDatetimeArrayOps.test_sub_td_no_matchc                    s  |r" t jkrdd }q.dd }n fdd}|}t|d|}t tddtddtd	dtd
dgt tddtddtddtddtddgt tddtddtddtddtddgt tddtddtddtddtddtddgt tddtddtddtddtddtddgt tddtddgt tddtddtddgt tddtd	dtd
dtddgt tddtd	dtd
dtddgt tddtddtd	dtd
dtddgt tddtd	dtd
dtddtddgt tddgt tddtddtddgg}|D ]\}||}	||}
t |	st |
r| t |	 | t |
 n| |	|
 qXd S )Nc                 S   s   |   S r   r8   arrr   r   r   r?    s    z0TestDatetimeArrayOps._test_min_max.<locals>.implc                 S   s   |   S r   r;   r[  r   r   r   r?    s    c                    s    | S r   r   r[  r=  r   r   r?    s    rE  r   r   rY   rx   r   r@  rA  z
1900-01-01rB  rC  r   r   r   )	r   r9   r   rH  ry   rz   r   rH   r]   )rQ   r>  rF  methodr?  r9  r:  r;  r\  Zpy_resZc_resr   r=  r   r     s    


Rz"TestDatetimeArrayOps._test_min_maxc                 C   s   |  tdd d S r   )r   r9   r   r   r   r   test_min_func8  s    z"TestDatetimeArrayOps.test_min_funcc                 C   s   |  tjdd d S r   r   r   r9   r   r   r   r   test_np_min_func;  s    z%TestDatetimeArrayOps.test_np_min_funcc                 C   s   |  tjdd d S r   r_  r   r   r   r   test_min_method>  s    z$TestDatetimeArrayOps.test_min_methodc                 C   s   |  tdd d S r   )r   r<   r   r   r   r   test_max_funcA  s    z"TestDatetimeArrayOps.test_max_funcc                 C   s   |  tjdd d S r   r   r   r<   r   r   r   r   test_np_max_funcD  s    z%TestDatetimeArrayOps.test_np_max_funcc                 C   s   |  tjdd d S r   rc  r   r   r   r   test_max_methodG  s    z$TestDatetimeArrayOps.test_max_methodc                 C   s   |  tjdd d S NTFr_  r   r   r   r   test_min_func_parallelJ  s    z+TestDatetimeArrayOps.test_min_func_parallelc                 C   s   |  tjdd d S rN  r_  r   r   r   r   test_min_method_parallelN  s    z-TestDatetimeArrayOps.test_min_method_parallelc                 C   s   |  tjdd d S rf  rc  r   r   r   r   test_max_func_parallelR  s    z+TestDatetimeArrayOps.test_max_func_parallelc                 C   s   |  tjdd d S rN  rc  r   r   r   r   test_max_method_parallelV  s    z-TestDatetimeArrayOps.test_max_method_parallelN)rr   rs   rt   rK  rM  r   rO  rR  rS  rX  rY  rZ  r   r^  r`  ra  rb  rd  re  rg  rh  ri  rj  r   r   r   r   r<    s2   &

j


r<  __main__)Cru   r'  rS   rT  Zunittestr  numpyr   Znumbar   r   r   Znumba.np.numpy_supportr   Z
numba.corer   r   Znumba.core.errorsr   Znumba.tests.supportr	   r
   r   Znumba.npr   r   r   r6  r7  r   rU   rV   rW   r&   r'   r(   r)   r*   r+   r,   r-   r.   r/   r0   r2   r3   r5   r7   r:   r=   r?   rC   rD   r%  rz   rI  ry   rv   r   r   r   r)  r*  r4  r<  rr   mainr   r   r   r   <module>   sl   

v6  5 o ]
