o
    5co                     @   s   d Z ddlmZmZmZmZmZ ddlZddlmZm	Z	 ddl
ZddlZddlZddlmZmZ ddlm  mZ ddlZddlmZmZmZmZmZmZmZ ddlmZ  G dd deZ!e!d	d
Z"e!ddZ#G dd dZ$dd Z%dS )z2
Tests for DatetimeIndex timezone-related methods
    )datedatetimetime	timedeltatzinfoN)gettztzlocal)
conversion	timezones)DatetimeIndexIndex	Timestampbdate_range
date_rangeisnato_datetimec                   @   s2   e Zd ZdZdddZdd Zdd	 Zd
d ZdS )FixedOffsetz&Fixed offset in minutes east from UTC.returnNc                 C   s   t |d| _|| _d S )N)minutes)r   _FixedOffset__offset_FixedOffset__name)selfoffsetname r   c/var/www/html/gps/gps/lib/python3.10/site-packages/pandas/tests/indexes/datetimes/test_timezones.py__init__+   s   
zFixedOffset.__init__c                 C      | j S N)r   r   dtr   r   r   	utcoffset/      zFixedOffset.utcoffsetc                 C   r   r   )r   r   r   r   r   tzname2   r"   zFixedOffset.tznamec                 C   s   t dS )Nr   )r   r   r   r   r   dst5   s   zFixedOffset.dst)r   N)__name__
__module____qualname____doc__r   r!   r#   r$   r   r   r   r   r   (   s    
r   i\z-07:00ic                   @   sz  e Zd Zdd Zejdddgdd Zdd	 Zejd
ddgdd Z	ejdg ddd Z
dd Zdd Zdd Zejd
ddededgdd Zejdddgdd Zdd Zd d! Zejd
ededgd"d# Zejd
ededgd$d% Zejdddgd&d' Zejdddgd(d) Zejd
ddededgd*d+ Zd,d- Zd.d/ Zd0d1 Zejd
ededgd2d3 Zejd
ededgd4d5 Zejd
d6d7gd8d9 Zejd:g d;g d<g d=g d>d?e d@dAdBggdCdD Z!dEdF Z"ejd
dGdHgejdIdJe#j$gdKdLgdMdNggdOdP Z%ejdQg dRg dSdTdGdUe d@dAgdTdGdVe dWdAgg dXg dYdZd?d[e d@dAgdZd?d\e dWdAggejd]ddgd^d_ Z&ejd`dWd@gejd]ddgdadb Z'dcdd Z(e)j*ejdeg dfdgdh Z+ejdddgdidj Z,dkdl Z-ejdddgdmdn Z.dodp Z/ejd
ededgdqdr Z0ejdddgdsdt Z1ejdug dvdwdx Z2ejdug dvdydz Z3d{d| Z4d}d~ Z5dd Z6dd Z7dd Z8dd Z9dd Z:dd Z;ejdddgdd Z<ejdddgdd Z=ejdddgdd Z>ejdddgdd Z?ejdddgdd Z@dd ZAdd ZBejd
ededgdd ZCejdddgdd ZDejd
ededgdd ZEejdg ddd ZFdd ZGejd
dLddeHjIJdLdgdd ZKdLS )TestDatetimeIndexTimezonesc                 C   s~  t jg}t|}|d}t|t|dd |d}t|t|dd |d}t|t|dd ddt jg}t|}|d}t|t|dd |d}ddt jg}t|t|dd |t jd	 }d
dt jg}t|t|dd |d}ddt jg}t|t|dd |t	
dd }d
dt jg}t|t|dd |d}ddt jg}t|t|dd d S )N
US/Pacifictz
US/EasternUTCz2010-12-01 00:00z2010-12-02 00:00z2010-12-01 03:00z2010-12-02 03:00   z2010-12-01 08:00z2010-12-02 08:00z2010-12-01 05:00z2010-12-02 05:00   hz2010-12-01 11:00z2010-12-02 11:00)pdNaTr   tz_localizetmassert_index_equal
tz_convertoffsetsHournptimedelta64)r   datesidxexpectedr   r   r   test_tz_convert_nat@   s6   






z.TestDatetimeIndexTimezones.test_tz_convert_natprefix z	dateutil/c                 C   sL   g d}t ||d d}|d |d }||d d }||ks$J d S )Nz1/1/2012z3/1/2012z4/1/2012r-   r+   r   r*   )r   r7   )r   r@   strdatesr=   convr>   r   r   r   $test_dti_tz_convert_compat_timestampb   s
   z?TestDatetimeIndexTimezones.test_dti_tz_convert_compat_timestampc                 C   s   g d}t |d}|d}tg d}t|j| g d}t |d}|d}tg d}t|j| g d}t |d}|d}tg d}t|j| g d}t |d}|d}tg d}t|j| d S )	N)2008-05-12 09:50:002008-12-12 09:50:352009-05-12 09:50:32r-   r.         rJ   )2008-05-12 13:50:002008-12-12 14:50:352009-05-12 13:50:32	   rP   rP   )rF   rG   2008-05-12 09:50:32)rL   rM   2008-05-12 13:50:32)r   r4   r7   r   r5   r6   hour)r   tsttutr>   r   r   r   %test_dti_tz_convert_hour_overflow_dstl   s(   



z@TestDatetimeIndexTimezones.test_dti_tz_convert_hour_overflow_dstr,   r-   zdateutil/US/Easternc                 C   s<  t d|dt d|dt d|dg}t|}|d}tg d}t|j| t dddt dddt d	ddg}t|}|d
}tg d}t|j| t d|dt d|dt d|dg}t|}|d}tg d}t|j| t dddt dddt dddg}t|}|d
}tg d}t|j| d S )NrF   r+   rG   rH   r.   rI   rL   rM   rN   r-   rO   rQ   rR   )r   r   r7   r   r5   r6   rS   )r   r,   rT   rU   rV   r>   r   r   r   0test_dti_tz_convert_hour_overflow_dst_timestamps   s@   















zKTestDatetimeIndexTimezones.test_dti_tz_convert_hour_overflow_dst_timestampszfreq, n)H   )T<   )Si  c                 C   sn   t tddddtdddd|d}|d}|d	}ttg d
t||dg}t|j	t
| d S )N  r0            r[   freqr.   zEurope/Moscow)r0      r/   )r   r   r4   r7   r:   repeatarrayr5   r6   rS   r   r   rd   nr=   r>   r   r   r   )test_dti_tz_convert_trans_pos_plus_1__bug   s
   "

"zDTestDatetimeIndexTimezones.test_dti_tz_convert_trans_pos_plus_1__bugc                 C   sN  dD ]\}}t dd|dd}|d}ttg dt||||||||||dg}t|jt| t d	d
|dd}|d}ttg dt||||||||||dg}t|jt| t dd|dd}|d}ttg dt||||||||||dg}t|jt| t dd|dd}|d}ttg dt||||||||||||dg}t|jt| qt ddddd}|d}t|jtddg t ddddd}|d}t|jtddg t ddddd}|d}t|jtddg t ddddd}|d}t|jtddg d S )NrY   2014-03-08 23:002014-03-09 09:00r.   rd   r,   r-   )               ra   r   r[   r0   re   r/   r[   z2014-03-08 18:00z2014-03-09 05:00)ra   r   r[      r0   re   r/            rP   z2014-11-01 23:00z2014-11-02 09:00)ro   rp   rq   rr   ra   r   r[   r[   rs   r0   re   z2014-11-01 18:00z2014-11-02 05:00)rr   ra   r   r[   rs   r0   re   r/   rt   ru   rv   rP   
   z2014-03-08 00:00z2014-03-09 00:00Dro   r/   z2014-11-01 00:00z2014-11-02 00:00rp   z2014-11-02 000:00re   )	r   r7   r:   rf   rg   r5   r6   rS   r   rh   r   r   r   test_dti_tz_convert_dst   sj   



"



z2TestDatetimeIndexTimezones.test_dti_tz_convert_dstc                 C   s   |}t ddddd}t dddd}t ddddd}t dddd}t ddd	dd}t ddd	d}t d
dddd}	t d
ddd}
||f||f||f|	|
ffD ].\}}||}|d }t|| |jd u sgJ |dd }|d}t|| qLd S )Nz
2014-01-01z
2014-12-31Mr.   startendrd   r,   r|   r}   rd   rx   z
2014-03-01rZ   z
2014-08-01z
2014-10-31r\   infer)r   r7   r5   r6   r   r4   
_with_freq)r   tz_aware_fixturer,   idx1exp1idx2exp2idx3exp3idx4exp4r=   r>   	convertedresetr   r   r   test_tz_convert_roundtrip
  s$   $


z4TestDatetimeIndexTimezones.test_tz_convert_roundtripc                 C   s`   t dddd}|tj }t|j|j t ddtj d}|d }t|j|j d S )N
2001-01-01
2001-03-01r.   r|   r}   r,   )r   r7   dateutilr,   r   r5   assert_numpy_array_equalasi8)r   dtidti2r   r   r   test_dti_tz_convert_tzlocal!  s   
z6TestDatetimeIndexTimezones.test_dti_tz_convert_tzlocalc                 C   sF   t ddddd}||}t|j|j t|jt|s!J d S )N	3/11/2012	3/12/2012rZ   utcrm   )	r   r7   r5   r   r   r
   
tz_comparer,   maybe_get_tz)r   r,   rngrng_easternr   r   r   *test_dti_tz_convert_utc_to_local_no_modify,  s   

zETestDatetimeIndexTimezones.test_dti_tz_convert_utc_to_local_no_modifytzstrc                 C   sJ   t ddddd}||}|d d d j}|jd d d }t|| d S )Nz
2012-03-09rZ   d   r   rd   periodsr,   )r   r7   rS   r5   assert_almost_equal)r   r   drresultexpr   r   r   test_tz_convert_unsorted>  s
   
z3TestDatetimeIndexTimezones.test_tz_convert_unsortedc                 C   sL   g d}t |}||}t||rJ |j|}t|j|r$J d S )Nz2015-03-08 01:00z2015-03-08 02:00z2015-03-08 03:00)r   r4   r5   shares_memory_data)r   utc_fixturetimesindexresres2r   r   r   test_tz_localize_utc_copiesJ  s   
z6TestDatetimeIndexTimezones.test_tz_localize_utc_copiesc                 C   s   g d}t |}d}tjtjd|d |j|d W d    n1 s&w   Y  tjtjd|d |j|dd W d    n1 sHw   Y  |j|dd}g d	}t|d
d}|d}t	
|| d S )Nr   r-   |matchr+   raise)r,   nonexistentr3   )z2015-03-08 01:00-05:00r3   z2015-03-08 03:00-04:00Tr   )r   pytestraisespytzNonExistentTimeErrorjoinr4   r   r7   r5   r6   )r   r   r   r,   r   
test_timesr   r>   r   r   r   -test_dti_tz_localize_nonexistent_raise_coerceU  s   
zHTestDatetimeIndexTimezones.test_dti_tz_localize_nonexistent_raise_coercec                 C   s  t tdddddtj d}tjtjdd |	| W d    n1 s'w   Y  t tdddddtj |d	}g d
}t
|}|j	|dd}|d }t|| t|t
||dd t tdddddtj d}|	|}|j	|dd}t|| d S )Nr_      rt   r   r/   r   rd   Cannot infer dst timer   r   rd   r,   11/06/2011 00:0011/06/2011 01:00r   11/06/2011 02:0011/06/2011 03:00r   	ambiguousr,   r   r[   rw   )r   r   r2   r8   r9   r   r   r   AmbiguousTimeErrorr4   r   r   r5   r6   )r   r,   r   r   di	localizedr>   localized_inferr   r   r   $test_dti_tz_localize_ambiguous_inferf  s"   

z?TestDatetimeIndexTimezones.test_dti_tz_localize_ambiguous_inferc                 C   s   t tddddddtj d}tjtjdd |	| W d    n1 s(w   Y  t tddddddtj |d	}t tdd
ddddtj d}tjtj
dd |	| W d    n1 sfw   Y  t tddddtjdtjd	}d S )Nr_   r0   rJ   r[      r   z2011-03-13 02:30:00r   r   r   rt   r   0   )r   r   r2   r8   r9   r   r   r   r   r4   r   Minuter   )r   r,   r   r   r   r   $test_dti_tz_localize_ambiguous_times  s     
z?TestDatetimeIndexTimezones.test_dti_tz_localize_ambiguous_timesc                 C   sJ   g d}t |}||}t ||d}|j|jksJ t|j|j d S )NrB   r+   )r   r4   r,   r5   r   values)r   r   rC   r=   rD   	fromdatesr   r   r   &test_dti_tz_localize_pass_dates_to_utc  s   
zATestDatetimeIndexTimezones.test_dti_tz_localize_pass_dates_to_utcc                 C   s   |d }t dddd}||}t ddddd	}t|j|j ||d
 }t|j|j t dddd}tjtj	dd || W d    n1 sNw   Y  t dddd}tjtj
dd || W d    d S 1 ssw   Y  d S )Nr-   1/1/2005z1/1/2005 0:00:30.256Lr~   z1/1/2005 05:00z1/1/2005 5:00:30.256r   r{   r*   z11/6/2011 1:59z11/6/2011 2:00r   r   z3/13/2011 1:59z3/13/2011 2:00z2011-03-13 02:00:00)r   r4   r5   r   r   r7   r   r   r   r   r   )r   r@   r   r   r   dti_utcdti3r   r   r   test_dti_tz_localize  s"   
"z/TestDatetimeIndexTimezones.test_dti_tz_localizec                 C   s   t dddd}||}|tjd }t|j|j t dddd}tj	t
jdd || W d    d S 1 s<w   Y  d S )	Nz	3/10/2012r   30Trc   r/   r   z2012-03-11 02:00:00r   )r   r4   r2   r8   r9   r5   r   r   r   r   r   r   )r   r,   r   r   expected_naiver   r   r   #test_dti_tz_localize_utc_conversion  s   
"z>TestDatetimeIndexTimezones.test_dti_tz_localize_utc_conversionc                 C   s   t dddd}|}||}tjtdd || W d    n1 s%w   Y  |d }|jd u s6J |d }t|| d S )Nz
2014-06-01z
2014-08-3015Tr~   z+Already tz-aware, use tz_convert to convertr   )	r   r4   r   r   	TypeErrorr   r   r5   r6   )r   r   r=   r,   r   r   r>   r   r   r   test_dti_tz_localize_roundtrip  s   


z9TestDatetimeIndexTimezones.test_dti_tz_localize_roundtripc                 C   s>   t dddd}|d}t ddddd}t||d  d S )N1/1/2011r   rZ   r   r*   r   )r   r4   r5   r6   r   )r   r   rD   r   r   r   r   test_dti_tz_localize_naive  s   
z5TestDatetimeIndexTimezones.test_dti_tz_localize_naivec                 C   s   t j tddd}t| d }tddd}|t j }t	
|j| |j tddt j d}|d }t	
|j| |j d S )Nr_   r[   i ʚ;r   r   r|   r}   r   )r   r,   r   r!   r   inttotal_secondsr   r4   r5   r   r   )r   r   r   r   r   r   r   test_dti_tz_localize_tzlocal  s   
z7TestDatetimeIndexTimezones.test_dti_tz_localize_tzlocalc                 C   sP   g d}t |}|j|dd}dtjtjddg}t |dd}t|j|j d S )	Nr   r3   r   r   r   r   r-   r+   )r   r4   r:   NaNr5   r   r   )r   r,   r   r   r   di_testr   r   r   "test_dti_tz_localize_ambiguous_nat  s   z=TestDatetimeIndexTimezones.test_dti_tz_localize_ambiguous_natc           
      C   s  t tdddddtj |d}g d}t|}g d}|j||d	}|d }t	|| t	|t|||d
 |j|t
|d	}t	|| |j|t
|dd	}t	|| t|||d
}t	|| ||7 }t|}d}tjt|d |j||d	 W d    n1 sw   Y  t
||f}|j||d	}||}t	|| t tdddddtj d}t
dgd }||}|j||d	}	t	||	 d S )Nr_   r   rt   r   r/   r   r   )r[   r[   r   r   r   r   r   boolz<Length of ambiguous bool-array must be the same size as valsr   r[   rw   r   )r   r   r2   r8   r9   r   r4   r   r5   r6   r:   rg   astyper   r   	Exceptionhstackappend)
r   r,   r   r   r   is_dstr   r>   msglocalized_is_dstr   r   r   $test_dti_tz_localize_ambiguous_flags  s>   	


z?TestDatetimeIndexTimezones.test_dti_tz_localize_ambiguous_flagsEurope/Londonzdateutil/Europe/Londonc                 C   s   t jtjdd tddddd W d    n1 sw   Y  tddd|dd	}|d
 td|dks5J |d td|dksAJ d S )Nr   r   z2013-10-26 23:00z2013-10-27 01:00r   rZ   r,   rd   r   )rd   r,   r   r   r+   r   z2013-10-27 01:00:00+0000)r   r   r   r   r   r   )r   r,   r   r   r   r   (test_dti_construction_ambiguous_endpointP  s   
zCTestDatetimeIndexTimezones.test_dti_construction_ambiguous_endpointztz, option, expected)r*   shift_forward2019-03-10 03:00)dateutil/US/Pacificr   r   )r*   shift_backward2019-03-10 01:00)r   r   r   r*   r[   )hoursr   c                 C   sn   t jtjdd tddddd W d    n1 sw   Y  tddd||d}|d	 t||d
ks5J d S )Nz2019-03-10 02:00:00r   z2019-03-10 00:00z2019-03-10 02:00r*   rZ   r   )rd   r,   r   r   r+   )r   r   r   r   r   r   )r   r,   optionr>   r   r   r   r   *test_dti_construction_nonexistent_endpoint`  s   
zETestDatetimeIndexTimezones.test_dti_construction_nonexistent_endpointc                 C   s6   t dd}t ddtjd}|tj}t|| d S )N1/1/2009z1/1/2010r+   )r   r   r   r4   r5   r6   )r   r   dr_utcr   r   r   r    test_dti_tz_localize_bdate_rangew  s   
z;TestDatetimeIndexTimezones.test_dti_tz_localize_bdate_rangeEurope/Warsawzdateutil/Europe/Warsawzmethod, expr3   r   Nfooinvalidc           	      C   s   d}t d|dd}|dkr/tjtjdd |j||d W d    d S 1 s(w   Y  d S |dkrVd	}tjt|d |j||d W d    d S 1 sOw   Y  d S |j||d}t|g| |d
}t	|| d S )Nr]   z2015-03-29 02:00:00min)r|   r   rd   r   r   r   r  zoThe nonexistent argument must be one of 'raise', 'NaT', 'shift_forward', 'shift_backward' or a timedelta objectr+   )
r   r   r   r   r   r4   
ValueErrorr   r5   r6   )	r   r,   methodr   ri   r   r   r   r>   r   r   r    test_dti_tz_localize_nonexistent}  s   ""z;TestDatetimeIndexTimezones.test_dti_tz_localize_nonexistentzstart_ts, tz, end_ts, shift)2015-03-29 02:20:00r  z2015-03-29 03:00:00forward)r	  r  z2015-03-29 01:59:59.999999999backwardr	  z2015-03-29 03:20:00z2015-03-29 01:20:00r   )2018-03-11 02:33:00r*   z2018-03-11 03:00:00r
  )r  r*   z2018-03-11 01:59:59.999999999r  r  z2018-03-11 03:33:00z2018-03-11 01:33:00tz_typec           	      C   sZ   || }t |trd| }tt|g}|j||d}tt|g|}t|| d S )Nshift_r  )
isinstancestrr   r   r4   r5   r6   )	r   start_tsr,   end_tsshiftr  r   r   r>   r   r   r   &test_dti_tz_localize_nonexistent_shift  s   0
zATestDatetimeIndexTimezones.test_dti_tz_localize_nonexistent_shiftr   c                 C   sb   |d }t tdg}d}tjt|d |j|t|dd W d    d S 1 s*w   Y  d S )Nr  r	  z<The provided timedelta will relocalize on a nonexistent timer   )secondsr  )r   r   r   r   r  r4   r   )r   r   r  r,   r   r   r   r   r   .test_dti_tz_localize_nonexistent_shift_invalid  s   "zITestDatetimeIndexTimezones.test_dti_tz_localize_nonexistent_shift_invalidc                 C   s   t ddddd}| }t ddddd}t||d  |js"J |jr'J t ddddd}| }t ddddd}t|| |jsFJ |jrKJ t dddt d}| }t dddt d}t||d  |jsoJ |jrtJ d S )N1/1/2000 9:30rw   rx   r-   r   1/1/2000r.   )r   	normalizer5   r6   r   is_normalizedr   )r   r   r   r>   r   r   r   test_normalize_tz  s$   




z,TestDatetimeIndexTimezones.test_normalize_tztimezone)r*   r-   r.   zAsia/KolkatazAsia/ShanghaizAustralia/Canberrac                 C   s   t |4 tdddt d}| }tdddt d}|d }t || |js,J |jr1J W d    d S 1 s<w   Y  d S )Nr  rw   rx   r   r  )r5   set_timezoner   r   r  r   r6   r  )r   r  r   r   r>   r   r   r   test_normalize_tz_local  s   

"z2TestDatetimeIndexTimezones.test_normalize_tz_localc                 C   s,   t tdddg|d d}|j |d  d S )N  r[   ESTr+   r   )r   r   rS   )r   r@   r   r   r   r   "test_dti_constructor_static_tzinfo  s   z=TestDatetimeIndexTimezones.test_dti_constructor_static_tzinfoc              	   C   s   t dd}tdddddd|d}tdd	dddd|d}t||d
}||jks(J t|t||d}t|| tdd}|j|jk sFJ d S )Ni  z+07:00r  r0   r   r/   r   r   rt   r   r   r,   z3/11/2012 05:00:00+07:00z6/11/2012 05:00:00+07:00)	r   r   r   r,   lenr5   r6   r   all)r   offr|   r}   r   rng2rng3r   r   r   "test_dti_constructor_with_fixed_tz  s   

z=TestDatetimeIndexTimezones.test_dti_constructor_with_fixed_tzc                 C   s2   t dd|dd}tt|ddd}t|| d S )Nz
2012-06-02rw   r  )r   r,   r   rx   )r   rd   )r   r   listr5   r6   )r   r   r   dr2r   r   r   test_dti_convert_datetime_list%  s   z9TestDatetimeIndexTimezones.test_dti_convert_datetime_listc                 C   s,   t ddddd}t|dd}t|| d S )Nz03/12/2012 00:00rw   zW-FRIr-   r   )datar,   )r   r   r5   r6   )r   r   r'  r   r   r   test_dti_construction_univalent+  s   z:TestDatetimeIndexTimezones.test_dti_construction_univalentc                 C   s0   t ddd|dg}t|}t|j|sJ d S )Nr  rv   ro   r"  )r   r   r
   r   r,   )r   r,   dr   r   r   r   test_dti_from_tzaware_datetime0  s   z9TestDatetimeIndexTimezones.test_dti_from_tzaware_datetimec                 C   sn   ddg}t ||}tddd|d}|d}t||d}tt||d}|||fD ]}t|| q,dS )	z^Test different DatetimeIndex constructions with timezone
        Follow-up of GH#4229
        z11/10/2005 08:00:00z11/10/2005 09:00:00z2005-11-10 08:00:00rZ   rs   )r|   rd   r   r,   Nr+   )	r   r4   r   r   r   r:   rg   r5   r6   )r   r   arrr   r   r   r   otherr   r   r   test_dti_tz_constructors7  s   
z3TestDatetimeIndexTimezones.test_dti_tz_constructorsdtype)Nzdatetime64[ns, CET]zdatetime64[ns, EST]zdatetime64[ns, UTC]c                 C   @   t tdddtjg}tdtjg|d}|j}t|| d S )Ni  rt   re   z2018-06-04 10:00:00r4  )r:   rg   r   r2   r3   r   r5   r   r   r4  r>   r   r   r   r   r   test_date_accessorJ     z-TestDatetimeIndexTimezones.test_date_accessorc                 C   r5  )Nrw   rp   r   2018-06-04 10:20:30r6  )r:   rg   r   r2   r3   r   r5   r   r7  r   r   r   test_time_accessorW  r9  z-TestDatetimeIndexTimezones.test_time_accessorc                 C   sN   t |}ttddd|dtjg}tdtjg|d}|j}t	
|| d S )Nrw   rp   r   r"  r:  r+   )r
   r   r:   rg   r   r2   r3   r   timetzr5   r   )r   tz_naive_fixturer,   r>   r   r   r   r   r   test_timetz_accessord  s
   
z/TestDatetimeIndexTimezones.test_timetz_accessorc                 C   s.   t dddd}||d }|jd usJ d S )Nz
2012-12-01rw   r   r#  r   )r   dropr,   )r   indr   r   r   test_dti_drop_dont_lose_tzo  s   z5TestDatetimeIndexTimezones.test_dti_drop_dont_lose_tzc                 C   sR   t dgdd}|j|dj|jksJ t dgddd}|jddj|jks'J d S )	Nz2019-01-01 10:00rZ   rc   r+   z2019-01-02 12:00r.   r\   r   )r   r4   rd   r7   )r   r=  t3t4r   r   r   test_dti_tz_conversion_freqv  s   z6TestDatetimeIndexTimezones.test_dti_tz_conversion_freqc                 C   sd   d}d}t d|d}t d|d}t|||d}tg d||g dd	}||d
 }t|| d S )NzEurope/Brussels15min201710290100r+   201710290300r~   )201710290115201710290130201710290145201710290200201710290215201710290230201710290245rK  rL  rM  rN  rG  )TTTTTTTFFFFF)r,   rd   r   r   )r   r   r   r?  r5   r6   )r   r,   rd   r|   r}   r   r>   r   r   r   r   test_drop_dst_boundary}  s    z1TestDatetimeIndexTimezones.test_drop_dst_boundaryc                 C   sB  t ddddd}tddgdd}t dddd}|d}t|d | |d	 }tddd}|jd
ks6J |jd
ks=J ||ksCJ t|d d | t ddddd}tddgddd}t|| tddd}|jd	ksqJ |d	 |ksyJ tddd}|jdksJ |d |ksJ t ddddd}|d jd
ksJ d S )Nz3/11/2012 03:00   rZ   r-   r   z3/11/2012 04:00r+   r   r   r0   rs   z3/11/2012 00:00z3/11/2012 01:00r   r[   rw   )r   r   r4   r5   r6   r   r   rS   )r   r   r'  r(  valr   r   r   r   test_date_range_localize  s0   

z3TestDatetimeIndexTimezones.test_date_range_localizec                 C   s   t dddd}|d}|d}t|||D ]\}}}||ks"J ||ks(J ||ks.J q||k s7J ||k s?J ||k sGJ d S )Nr  rp   r.   r#  r-   zEurope/Berlin)r   r7   zipr%  )r   	utc_rangeeastern_rangeberlin_rangeabcr   r   r   +test_timestamp_equality_different_timezones  s   

zFTestDatetimeIndexTimezones.test_timestamp_equality_different_timezonesc                 C   sj   t ddddd}|dd d d d }|d	d
 d d d }|j|jks&J ||}|j|jks3J d S )Nr   r   rZ   r   r   rw   Z   r   rp   P   )r   r,   intersection)r   r   leftrightr   r   r   r   test_dti_intersection  s   
z0TestDatetimeIndexTimezones.test_dti_intersectionc                 C   s2   t ddddd}t ddddd}||rJ d S )Nr   r   rZ   r   r   r-   )r   equals)r   r^  r_  r   r   r   test_dti_equals_with_tz  s   z2TestDatetimeIndexTimezones.test_dti_equals_with_tzc                 C   s<   t td|dtjg}t|d sJ |d jd usJ d S )Nz2013-1-1r+   r[   r   )r   r   r2   r3   r   r   )r   r   r=   r   r   r   test_dti_tz_nat  s   z*TestDatetimeIndexTimezones.test_dti_tz_natc                 C   s   t dd|d}|t}t|D ]\}}|| }||ksJ |j|jks&J q|t}t|D ]\}}|| }||ks>J |j|jksFJ q0d S )Nz	2/13/20105/6/2010r+   )r   r   object	enumerater   )r   r   r   objsixexvalr   r   r    test_dti_astype_asobject_tzinfos  s   

z;TestDatetimeIndexTimezones.test_dti_astype_asobject_tzinfosc                 C   s,   t dd}||}t|}d|v sJ d S )Nz	4/13/2010rd  z2010-04-13 00:00:00)r   r4   repr)r   r   r   r   rng_reprr   r   r   test_dti_with_timezone_repr  s   

z6TestDatetimeIndexTimezones.test_dti_with_timezone_reprc                 C   s@   t dd|d}|td}|j|jksJ |j|jksJ d S )Nr  rp   r#  r/   )r   takeranger,   rd   )r   r   r   r   r   r   r   test_dti_take_dont_lose_meta  s   z7TestDatetimeIndexTimezones.test_dti_take_dont_lose_metac                 C   s   t |}tddddd}||}|d |}|d }||ks#J |j|jks+J tddddd}||}d	t|d
 jv sLdt|d
 jv sNJ d S d S )Nr   r   rZ   r   rm   r   z	3/13/2012z	3/14/2012EDTr   tzfile)r
   r   r   r7   
astimezoner   rl  )r   r   r,   r   r   r>   stampr   r   r   #test_utc_box_timestamp_and_localize  s   


z>TestDatetimeIndexTimezones.test_utc_box_timestamp_and_localizec                 C   s~   t jd}|jt d}tj|gtd}t|dd}|j	t
ju s#J tddt d}| }t|dd}|j	t
ju s=J d S )	Nz2012-06-13T01:39:00Zr"  r6  Tr   z2012-11-03 03:00z2012-11-05 03:00r+   )r   parserparsereplacer   r:   rg   re  r   r,   r   r   r   to_pydatetime)r   r    r1  r   r   r   r   r   test_dti_to_pydatetime)  s   z1TestDatetimeIndexTimezones.test_dti_to_pydatetimec              
   C   sh   t tdddtdtdddtdtdddtdg}t|}| }t|| | }t|| d S )N  r[   r"  rs   r0   )	r:   rg   r   	fixed_offr   rz  r5   r   	_mpl_repr)r   r<   r   r   r   r   r   test_dti_to_pydatetime_fizedtz7  s   z9TestDatetimeIndexTimezones.test_dti_to_pydatetime_fizedtz
US/Centralc                 C   sN  t dddtjd}t|dtj d}|jtju sJ tddtjd	}tdd|d	}||}|j|u s6J |d
 	 j
d d}t||j}|d
 j|u sPJ |d
 	 j
d d}t||j}|d
 j|u sjJ tt dddtjdt dddtjd}d}tjt|d tt dddtjdd|d	 W d    d S 1 sw   Y  d S )Nr_   r0      r"  2   r   r   r   r+   r   i  r[   i  z>Start and end cannot both be tz-aware with different timezonesr   )r   r   r   r   r2   r8   r9   r,   r7   rz  ry  r	   localize_pydatetimer   r   r   r   )r   r,   r|   r   centralnaivecompr   r   r   r   test_with_tzG  s(   
 "z'TestDatetimeIndexTimezones.test_with_tzc                 C   sd   g d}t ||d d}|jdk sJ tddd|d d	}ttjdtjd
}t	|j| d S )NrB   r-   r+   r   z2011-10-02 00:00r1   rw   zAmerica/Atikokanr   r6  )
r   rS   r%  r   r   r:   arangeint64r5   r6   )r   r@   rC   r   r   r>   r   r   r   test_field_access_localizef  s   z5TestDatetimeIndexTimezones.test_field_access_localizec                    s   t dddt dddt dddg} fdd|D }t|}t|j s'J t|dd}td	d |D }t	|j
| |jtju sFJ d S )
Nr|  r[   rs   r0   c                    s   g | ]}t | qS r   )r	   r  .0ri  r+   r   r   
<listcomp>y  s    zZTestDatetimeIndexTimezones.test_dti_convert_tz_aware_datetime_datetime.<locals>.<listcomp>Tr   c                 S   s   g | ]}t |jqS r   )r   valuer  r   r   r   r  ~  s    )r   r   r
   r   r,   r   r:   rg   r5   r   r   r   r   )r   r,   r<   dates_awarer   r   ex_valsr   r+   r   +test_dti_convert_tz_aware_datetime_datetimet  s   "zFTestDatetimeIndexTimezones.test_dti_convert_tz_aware_datetime_datetimesetop)unionr]  symmetric_differencec                 C   s   t ddddd}t ddddd}tt t|||}W d    n1 s'w   Y  t|d||d}t|| t|rW|d	 jj	dksMJ |d
 jj	dksYJ d S d S )Nz2012-11-15 00:00:00rt   rZ   r  r   z2012-11-15 12:00:00r-   Or   r   )
r   r5   assert_produces_warningFutureWarninggetattrr   r6   r$  r,   zone)r   r  r   r'  r   r>   r   r   r   test_dti_setop_aware  s   z/TestDatetimeIndexTimezones.test_dti_setop_awarec                 C   sf   t tdtjg}t ddgdd}||}ttdtjtdddtdddgtd}t|| d S )Nz
2011-01-01z
2012-01-01z
2012-01-02z
Asia/Tokyor+   r6  )	r   r   r2   r3   r  r   re  r5   r6   )r   r   r'  r   r>   r   r   r   test_dti_union_mixed  s   


	z/TestDatetimeIndexTimezones.test_dti_union_mixedr.   ic                 C   s6   t ddg|d}t|D ]\}}||| ksJ qd S )Nz2018-02-08 15:00:00.168456358z2018-02-08 15:00:00.168456359r+   )r   rf  )r   r,   r   rh  rT   r   r   r   $test_iteration_preserves_nanoseconds  s   z?TestDatetimeIndexTimezones.test_iteration_preserves_nanoseconds)Lr%   r&   r'   r?   r   markparametrizerE   rW   rX   rj   ry   r   r   r   r  r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r2   r3   r  r  r  r  tdskip_if_windowsr  r!  r)  r,  r.  r0  r3  r8  r;  r>  rA  rD  rO  rR  rZ  r`  rb  rc  rk  rn  rq  rv  r{  r  r  r  r  r  r  r   r,   tzoffsetr  r   r   r   r   r)   =   s@   "
	 
/

C
		





	

8


+




	
	,!









r)   c                  C   s   t dddd} | jdksJ | d }|jdksJ | d}|jdks&J | jddd}|jd u s4J |jd u s;J | d d	 }|d}|jdksMJ d S )
Nrk   rl   rZ   rc   r.   r-   r   r  r[   )r   rd   r4   inferred_freq)r   r   r   r   r   r   !test_tz_localize_invalidates_freq  s   


r  )&r(   r   r   r   r   r   r   dateutil.tzr   r   numpyr:   r   r   pandas._libs.tslibsr	   r
   pandas.util._test_decoratorsutil_test_decoratorsr  pandasr2   r   r   r   r   r   r   r   pandas._testing_testingr5   r   r}  fixed_off_no_namer)   r  r   r   r   r   <module>   s2    $	

        {