o
    dX>                     @   s|  d Z ddlZddlZddlZddlZddlmZ	 ej
jddZG dd dZG dd dZej
jd	ed
d
geddgeddgeeddgd eedgd eedgd eddgeedd
gd ejddgg	dd ddd Zdd Zdd Zdd Zej
dej ddd d!d fej d"d d!d fej d#d$d d d!d%fgd&d' Z!d(d) Z"dS )*z1Tests dealing with the NDFrame.allows_duplicates.    NzNot implemented.reasonc                   @   sD  e Zd Zejdeje	g fejddgfej
i fej
dddgifgdd Zejdedged	ded
ejed
dedejgdd Zejdejdg ddejdddgdgedd Zdd Zdd Zejdd	dgejdddgejddejddgddgdd  Zd!d" Zd#d$ Zejd%ejdddgdjdd&ejdd'd(gdjdd&gi fejdddgdjdd&ejdddgdjdd&gd)difejdddgdjdd&ejdddgdjdd&gd*difej
dddgiddgdjdd&ej
dddgid'd(gdjdd&gi fej
dddgiddgdjdd&ej
dddgiddgdjdd&gd)difej
dddgiddgdjdd&ej
d+ddgiddgdjdd&gd*difej
dddgiddgdjdd&ejddgddgd+d,jdd&gd*difgd-d. Zejd/ejej
dddgiddgdjdd&ej
d+ddgidd(gdjdd&ddd0ded1ejej
dddgiddgdjdd&ej
d+ddgidd(gdddd0ded1ej
dddgiddgdej
d+ddgidd(gdddd0dfgd2d3 Zed4d5 Zejdddged6d7 Zd8S )9TestPreservesz	cls, data      Ac                 C   s<   ||}|j jdu sJ ||jdd}|j jdu sJ d S )NTFallows_duplicate_labels)flagsr	   	set_flags)selfclsdataresult r   ^/app/.heroku/python/lib/python3.10/site-packages/pandas/tests/generic/test_duplicate_labels.pytest_construction_ok   s   
z"TestPreserves.test_construction_okfuncaaddrenamenameabsc                 C   s6   t jddgddgdjdd}||jjdu sJ d S Nr   r   r   bindexFr   )pdSeriesr   r
   r	   )r   r   sr   r   r   test_preserved_series!   s   z#TestPreserves.test_preserved_seriesotherr   r   r   cr   r   c                 C   sP   t jddgddgdjdd}||\}}|jjdu sJ |jjdu s&J d S r   )r   r   r   alignr
   r	   )r   r!   r   r   r   r   r   r   
test_align0   s   zTestPreserves.test_alignc                 C   sf   t jddgddgdddgdjd	d
}|jdg jjd	u s J |jd d ddgf jjd	u s1J d S )Nr   r         r   Br   r   r   Fr   r   r)   )r   	DataFramer   locr
   r	   r   dfr   r   r   test_preserved_frame;   s
    &z"TestPreserves.test_preserved_framec                 C   s,   t jtdjdd}| jjdu sJ d S )N)dtypeFr   )r   r   floatr   to_framer
   r	   )r   Zserr   r   r   test_to_frameB   s   zTestPreserves.test_to_framesubframeFTr   c                 C   sx   t jddgdddgdjdd}|r| }t|t jr"|r"| }t||}|jjdu s0J ||jjdu s:J d S )	Nr   r   r   r   r   )r   r   Fr   )	r   r   r   r1   
isinstanceoperatormethodcallerr
   r	   )r   r   r!   r4   r-   r   r   r   test_binopsF   s   zTestPreserves.test_binopsc                 C   s   t dddgijdd}|dg jjdu sJ |d jjdu s"J |jd jjdu s-J |jdg jjdu s9J |jddgf jjdu sGJ d S )Nr   r   r   Fr   r   )r   r*   r   r
   r	   r+   r,   r   r   r   test_preserve_getitemU   s    z#TestPreserves.test_preserve_getitemc                 C   sf   |s|j tjjdd tddgijdd}|d jj	du s#J d|j_	|d jj	du s1J d S )NzUnclear behavior.r   r   r   Fr   T)
nodeZ
add_markerpytestmarkxfailr   r*   r   r
   r	   )r   requestZusing_copy_on_writer-   r   r   r   "test_ndframe_getitem_caching_issue]   s   z0TestPreserves.test_ndframe_getitem_caching_issueobjs, kwargsr   r#   dZignore_indexaxisr)   r   r   c                 C   s&   t j|fi |}|jjdu sJ d S )NF)r   concatr
   r	   )r   objskwargsr   r   r   r   test_concatg   s   ZzTestPreserves.test_concatzleft, right, kwargs, expectedZ
left_indexZright_index)Zmarksc                 C   s(   t j||fi |}|jj|u sJ d S N)r   merger
   r	   )r   leftrightrG   expectedr   r   r   r   
test_merge   s   #zTestPreserves.test_mergec                 C   sB   t dg dijdd}|g dd}|jjdu sJ d S )Nr   )r   r   r&   Fr   )r   r   r   count)r   r*   r   groupbyZaggr
   r	   )r   r-   r   r   r   r   test_groupby   s   zTestPreserves.test_groupbyc                 C   sz   t jdt jdddddd}|r| }|d jjdu s!J |d jjdu s.J |	d jjdu s;J d S )	Nr   2000   )Zperiodsr   F)r   r   r	   r&   )
r   r   Z
date_ranger1   Zrollingmeanr
   r	   ZewmZ	expanding)r   r4   r-   r   r   r   test_window   s   zTestPreserves.test_windowN) __name__
__module____qualname__r<   r=   parametrizer   r   nparrayr*   r   r7   
itemgetterr8   strupperr   r    not_implementedr%   r.   r2   r9   r:   r@   r   rH   paramrO   rR   rV   r   r   r   r   r      s   
	



$

Y
"

r   c                   @   s  e Zd Zejdejddgedfej	dddgifej	ddgddgdfej	dddgifgdd	 Z
ejd
ejddgedej	ddgdej	ddgdgdd Zdd Zejdeddgdfeddgdfeedddgfdeddgdfdfeddgdfeedddgfdeeddgdfdgdd Zejdejdddgddjddejdddgddjddgddifgd d! Zed"d# ZdS )$
TestRaisesz	cls, axesr   )r   r/   r   r   )r   columnsrc   c                 C   sp   |di |}|j jdu sJ d}tjtjj|d |di |jdd W d    d S 1 s1w   Y  d S )NTIndex has duplicates.matchFr   r   )r
   r	   r<   raisesr   errorsDuplicateLabelErrorr   )r   r   Zaxesr   msgr   r   r   test_set_flags_with_duplicates
  s   
"z)TestRaises.test_set_flags_with_duplicatesr   r   r   rc   c                 C   sR   d}t jtjj|d d|j_W d    n1 sw   Y  |jjdu s'J d S )Nrd   re   FT)r<   rg   r   rh   ri   r
   r	   )r   r   rj   r   r   r   +test_setting_allows_duplicate_labels_raises  s
   	
z6TestRaises.test_setting_allows_duplicate_labels_raisesc                 C   sz   t jdddgd}t jddgddgdjdd}d}tjt jj|d	 t ||g W d    d S 1 s6w   Y  d S )
Nr   r   r   r   r   Fr   rd   re   )r   r   r   r<   rg   rh   ri   rE   r   r   r   rj   r   r   r   test_series_raises*  s   "zTestRaises.test_series_raiseszgetter, targetr   Nr+   Zilocc                 C   s   t jddgddgdddgdjd	d
}|rt||}n|}d}tjt jj|d || W d    d S 1 s9w   Y  d S )Nr   r   r&   r'   r(   r   r   r   Fr   rd   re   )r   r*   r   getattrr<   rg   rh   ri   )r   gettertargetr-   rj   r   r   r   test_getitem_raises1  s    
"zTestRaises.test_getitem_raisesrA   r   rD   Fr   r   rC   c                 C   sN   d}t jtjj|d tj|fi | W d    d S 1 s w   Y  d S )Nrd   re   )r<   rg   r   rh   ri   rE   )r   rF   rG   rj   r   r   r   test_concat_raisesM  s   "zTestRaises.test_concat_raisesc                 C   s   t jdg dig ddjdd}t jdg dig dd}d	}tjt jj|d
 t j||ddd W d    d S 1 s>w   Y  d S )Nr   )r   r   r   r"   r   Fr   r)   )r   r   r   rd   re   TrI   )r   r*   r   r<   rg   rh   ri   rK   rn   r   r   r   test_merge_raisesb  s   "zTestRaises.test_merge_raises)rW   rX   rY   r<   r=   rZ   r   r   r0   r*   rk   rm   ro   r7   r]   ra   rs   r   rt   r`   ru   r   r   r   r   rb   	  s^    
	


rb   idxr   r   g?rS   Dr   Z1D)r   r   c                 C   s
   t | jS rJ   )typerW   xr   r   r   <lambda>z  s   
 r{   )Zidsc                 C   s   d}t jtjj|d tjd| djdd W d    n1 s!w   Y  t jtjj|d tjdddgi| djdd W d    n1 sIw   Y  t jtjj|d tjddgg| d	jdd W d    d S 1 sqw   Y  d S )
Nrd   re   r   r   Fr   r   r   rl   )r<   rg   r   rh   ri   r   r   r*   )rv   rj   r   r   r   test_raises_basicm  s    "r|   c                  C   sR   t g d} |  }t jdddgddggit jddgd	d
d}t|| d S )Nr   r   r   r   r#   	positionsr   r   r   r&   r   r   labelr5   r   )r   Index_format_duplicate_messager*   tmassert_frame_equalrv   r   rN   r   r   r   $test_format_duplicate_labels_message  s   "r   c                  C   s^   t jdgg dg} |  }t jdddgddggit jdgdd	ggd
}t|| d S )Nr   r}   r~   r   r   r   r&   r   r   r   )r   
MultiIndexZfrom_productr   r*   r   r   r   r   r   r   *test_format_duplicate_labels_message_multi  s   r   c                  C   sh   t dddgijdd} d}tjt|d | jddd	d
gdd W d    d S 1 s-w   Y  d S )Nr   r   r   Fr   Cannot specifyre   r   r&   r'   T)Zallow_duplicates)r   r*   r   r<   rg   
ValueErrorinsert)r-   rj   r   r   r   test_dataframe_insert_raises  s
   "r   zmethod, frame_onlyZ	set_indexr   T)ZinplaceZreset_indexr   c                 C   s   | S rJ   r   ry   r   r   r   r{     s    Fc                 C   s   t ddgddgdjdd}|d }d|j_d}tjt|d	 | | W d    n1 s0w   Y  |sUtjt|d	 | | W d    d S 1 sNw   Y  d S d S )
Nr   r   r   r(   Fr   r   r   re   )r   r*   r   r
   r	   r<   rg   r   )methodZ
frame_onlyr-   r   rj   r   r   r   test_inplace_raises  s   	

"r   c                  C   s\   t ddgjdd} t| }t| | t dg ijdd} t| }t| | d S )Nr   r   Fr   r   )r   r   r   r   Zround_trip_pickleZassert_series_equalr*   r   )r   r   r   r   r   test_pickle  s   

r   )#__doc__r7   numpyr[   r<   Zpandasr   Zpandas._testingZ_testingr   r=   r>   r`   r   rb   rZ   r   ZPeriodIndexZPeriodZDatetimeIndex	TimestampZTimedeltaIndexZ	TimedeltaZCategoricalIndexZIntervalIndexZIntervalr   from_tuplesr|   r   r   r   r8   r   r   r   r   r   r   <module>   sJ     zd
	

