U
    *if-                     @   s  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 d dl	m
Z
 d dlmZmZmZ ejdd Zejdd Zejdd	 Zejd
d Zejdd Zejdd Zejdd Zejdd ZG dd dZG dd dee
jZG dd dee
jZG dd dee
jZG dd dee
jZ G dd dee
j!Z"G d d! d!ee
j#Z$G d"d# d#ee
j%Z&ej'j(d$d%Z)G d&d' d'e
j*Z+G d(d) d)ee
j,Z-G d*d+ d+ee
j.Z/G d,d- d-ee
j0Z1G d.d/ d/ee
j2Z3G d0d1 d1ee
j4Z5G d2d3 d3ee
j6Z7dS )4    N)base)	JSONArray	JSONDtype	make_datac                   C   s   t  S N)r    r   r   X/home/mars/bis/venv/lib/python3.8/site-packages/pandas/tests/extension/json/test_json.pydtype   s    r	   c                  C   s.   t  } t| d t| d kr&t  } qt| S )z*Length-100 PeriodArray for semantics test.r      )r   lenr   )datar   r   r   r      s    r   c                   C   s   t i ddigS )zLength 2 array with [NA, Valid]a
   r   r   r   r   r   data_missing'   s    r   c                   C   s   t ddiddidddgS )Nbr
   c         r   r   r   r   r   r   r   data_for_sorting-   s    r   c                   C   s   t ddii ddigS )Nr   r
   r   r   r   r   r   r   r   data_missing_for_sorting2   s    r   c                 C   s   | j S r   )na_value)r	   r   r   r   r   7   s    r   c                   C   s   t jS r   )operatoreqr   r   r   r   na_cmp<   s    r   c                
   C   s4   t ddiddii i ddddddddiddigS )Nr   r
   r   r   r   r   r   r   r   r   r   data_for_groupingA   s    r   c                   @   s$   e Zd Zedd Zedd ZdS )BaseJSONc                 O   st   |j jdkr\|j |j ksttjt|jt|j	|jd}tjt|jt|j	|jd}t
j||f|| d S )Njson)indexname)r	   r!   AssertionErrorpdSeriesr   valuesZastypeobjectr    tmassert_series_equal)clsleftrightargskwargsr   r   r   r(   V   s      zBaseJSON.assert_series_equalc              
   O   s   | dd}tj|j|j| dd| dd| dd| d	d| d
d |jdkj}|D ] }| j|| || f|| q^|j|d}|j|d}tj||f|| d S )NobjZ	DataFrameZcheck_column_typeequivcheck_namesTcheck_exactFcheck_categoricalz.columns)exactr0   r1   r2   r.   r   )columns)	getr'   Zassert_index_equalr4   Zdtypesr    r(   Zdropassert_frame_equal)r)   r*   r+   r,   r-   obj_typeZjsonscolr   r   r   r6   d   s     




zBaseJSON.assert_frame_equalN)__name__
__module____qualname__classmethodr(   r6   r   r   r   r   r   Q   s   
r   c                   @   s   e Zd ZdS )	TestDtypeNr9   r:   r;   r   r   r   r   r=   {   s   r=   c                       s2   e Zd Zdd Zejjdd fddZ  ZS )TestInterfacec              	   C   s   t tdditdditddig}t|}| || | | |  t|dddg}d}t	j
t|d	 | || W 5 Q R X t	j
t|d	 | | |  W 5 Q R X d S )
Nr   r
   r   r   r   r   r   zExtensionArray are differentmatch)r   collectionsUserDictr#   r$   r(   r6   Zto_frameZtakepytestraisesr"   )selfr   r   r   msgr   r   r   test_custom_asserts   s    
z!TestInterface.test_custom_assertsz:comparison method not implemented for JSONArray (GH-37867)reasonc                    s   t  | d S r   )supertest_containsrF   r   	__class__r   r   rL      s    zTestInterface.test_contains)	r9   r:   r;   rH   rD   markxfailrL   __classcell__r   r   rN   r   r?      s
   r?   c                       sx   e Zd Zejjdd fddZejjdd fddZejjdd fdd	Zejjd
d fddZ	  Z
S )TestConstructorsz&not implemented constructor from dtyperI   c                    s   t | | d S r   )rK   test_from_dtyperM   rN   r   r   rT      s    z TestConstructors.test_from_dtypezRecursionError, GH-33900c              	      s6   t  }zt d t || W 5 t | X d S Nd   )sysgetrecursionlimitsetrecursionlimitrK   *test_series_constructor_no_data_with_indexrF   r	   r   Z	rec_limitrN   r   r   rZ      s
    
z;TestConstructors.test_series_constructor_no_data_with_indexc              	      s6   t  }zt d t || W 5 t | X d S rU   )rW   rX   rY   rK   ,test_series_constructor_scalar_na_with_indexr[   rN   r   r   r\      s
    
z=TestConstructors.test_series_constructor_scalar_na_with_indexzcollection as scalar, GH-33901c                    s   t  || d S r   )rK   )test_series_constructor_scalar_with_index)rF   r   r	   rN   r   r   r]      s    z:TestConstructors.test_series_constructor_scalar_with_index)r9   r:   r;   rD   rP   rQ   rT   rZ   r\   r]   rR   r   r   rN   r   rS      s   

rS   c                       s@   e Zd Zejjdddd Zejjdd fddZ  Z	S )TestReshapingzDifferent definitions of NArI   c                 C   s   dS )z
        The test does .astype(object).stack(). If we happen to have
        any missing values in `data`, then we'll end up with different
        rows since we consider `{}` NA, but `.astype(object)` doesn't.
        Nr   rF   r   r   r   
test_stack   s    zTestReshaping.test_stackzdict for NAc                    s   t  ||S r   )rK   test_unstack)rF   r   r    rN   r   r   ra      s    zTestReshaping.test_unstack)
r9   r:   r;   rD   rP   skipr`   rQ   ra   rR   r   r   rN   r   r^      s   
r^   c                   @   s   e Zd ZdS )TestGetitemNr>   r   r   r   r   rc      s   rc   c                   @   s   e Zd ZdS )	TestIndexNr>   r   r   r   r   rd      s   rd   c                   @   s8   e Zd Zejjdddd Zejjdddd ZdS )TestMissingzSetting a dict as a scalarrI   c                 C   s   dS z;We treat dictionaries as a mapping in fillna, not a scalar.Nr   r_   r   r   r   test_fillna_series   s    zTestMissing.test_fillna_seriesc                 C   s   dS rf   r   r_   r   r   r   test_fillna_frame   s    zTestMissing.test_fillna_frameN)r9   r:   r;   rD   rP   rb   rg   rh   r   r   r   r   re      s   
re   Z
UnhashablerI   c                   @   s   e Zd ZdS )
TestReduceNr>   r   r   r   r   ri      s   ri   c                       s  e Zd Zedd Zedd Zedd Zej	ddd	g fd
dZ
ej	ddd	g fddZejjdddd Zejjdddd Zejjdddd Ze fddZejjdd fddZejjdd fddZejjdddd Z  ZS ) TestMethodsc                 C   s   d S r   r   )rF   Zall_dataZdropnar   r   r   test_value_counts   s    zTestMethods.test_value_countsc                 C   s   d S r   r   rM   r   r   r    test_value_counts_with_normalize   s    z,TestMethods.test_value_counts_with_normalizec                 C   s   d S r   r   r_   r   r   r   test_sort_values_frame   s    z"TestMethods.test_sort_values_frame	ascendingTFc                    s   t  ||| d S r   )rK   test_sort_values)rF   r   rn   sort_by_keyrN   r   r   ro      s    zTestMethods.test_sort_valuesc                    s   t  ||| d S r   )rK   test_sort_values_missing)rF   r   rn   rp   rN   r   r   rq      s
      z$TestMethods.test_sort_values_missingz#combine for JSONArray not supportedrI   c                 C   s   d S r   r   rF   Zdata_repeatedr   r   r   test_combine_le  s    zTestMethods.test_combine_lec                 C   s   d S r   r   rr   r   r   r   test_combine_add  s    zTestMethods.test_combine_addc                 C   s   d S r   r   rM   r   r   r   test_combine_first  s    zTestMethods.test_combine_firstc                    s   t  || d S r   )rK   test_hash_pandas_object_works)rF   r   kindrN   r   r   rv     s    z)TestMethods.test_hash_pandas_object_workszbroadcasting errorc                    s   t  || d S r   )rK   test_where_series)rF   r   r   rN   r   r   rx     s    zTestMethods.test_where_serieszCan't compare dicts.c                    s   t  | d S r   )rK   test_searchsorted)rF   r   rN   r   r   ry     s    zTestMethods.test_searchsortedc                 C   s   d S r   r   )rF   r   r   Z	as_seriesr   r   r   test_equals  s    zTestMethods.test_equals)r9   r:   r;   
unhashablerk   rl   rm   rD   rP   Zparametrizero   rq   rb   rs   rt   ru   rv   rx   ry   rz   rR   r   r   rN   r   rj      s0   





rj   c                   @   s"   e Zd Zejjdddd ZdS )TestCastingz$failing on np.array(self, dtype=str)rI   c                 C   s   dS )zThis currently fails in NumPy on np.array(self, dtype=str) with

        *** ValueError: setting an array element with a sequence
        Nr   r_   r   r   r   test_astype_str$  s    zTestCasting.test_astype_strN)r9   r:   r;   rD   rP   rb   r}   r   r   r   r   r|   #  s   r|   c                       sZ   e Zd Zedd Zedd Zedd Zedd Zej	j
d	d
 fddZ  ZS )TestGroupbyc                 C   s   dS )a  
        This currently fails in Series.name.setter, since the
        name must be hashable, but the value is a dictionary.
        I think this is what we want, i.e. `.name` should be the original
        values, and not the values for factorization.
        Nr   r_   r   r   r    test_groupby_extension_transform1  s    z,TestGroupby.test_groupby_extension_transformc                 C   s   dS )z
        This fails in Index._do_unique_check with

        >   hash(val)
        E   TypeError: unhashable type: 'UserDict' with

        I suspect that once we support Index[ExtensionArray],
        we'll be able to dispatch unique.
        Nr   r_   r   r   r   test_groupby_extension_apply:  s    z(TestGroupby.test_groupby_extension_applyc                 C   s   dS z
        This fails when we get to tm.assert_series_equal when left.index
        contains dictionaries, which are not hashable.
        Nr   r_   r   r   r   test_groupby_extension_aggF  s    z&TestGroupby.test_groupby_extension_aggc                 C   s   dS r   r   r_   r   r   r   test_groupby_extension_no_sortM  s    z*TestGroupby.test_groupby_extension_no_sortz'GH#39098: Converts agg result to objectrI   c                    s   t  | d S r   )rK   test_groupby_agg_extension)rF   r   rN   r   r   r   T  s    z&TestGroupby.test_groupby_agg_extension)r9   r:   r;   r{   r   r   r   r   rD   rP   rQ   r   rR   r   r   rN   r   r~   0  s   



r~   c                       s<   e Zd Z fddZdd Zdd Zef fdd	Z  ZS )	TestArithmeticOpsc                    s<   t |d dkr*tjjdd}|j| t || d S )Nr   r
   zraises in coercing to SeriesrI   )r   rD   rP   rQ   nodeZ
add_markerrK   test_arith_frame_with_scalar)rF   r   Zall_arithmetic_operatorsrequestrP   rN   r   r   r   Z  s    z.TestArithmeticOps.test_arith_frame_with_scalarc              	   C   s0   t |}tjtdd ||  W 5 Q R X d S )Nunsupportedr@   )r#   r$   rD   rE   	TypeError)rF   r   Zserr   r   r   $test_add_series_with_extension_array`  s    
z6TestArithmeticOps.test_add_series_with_extension_arrayc                 C   s   d S r   r   r_   r   r   r   test_divmod_series_arraye  s    z*TestArithmeticOps.test_divmod_series_arrayc                    s   t  j|||tdS )N)exc)rK   _check_divmod_opr   )rF   sopotherr   rN   r   r   r   j  s    z"TestArithmeticOps._check_divmod_op)	r9   r:   r;   r   r   r   NotImplementedErrorr   rR   r   r   rN   r   r   Y  s   r   c                   @   s   e Zd ZdS )TestComparisonOpsNr>   r   r   r   r   r   n  s   r   c                   @   s   e Zd ZdS )TestPrintingNr>   r   r   r   r   r   r  s   r   )8rB   r   rW   rD   Zpandasr#   Zpandas._testingZ_testingr'   Zpandas.tests.extensionr   Z!pandas.tests.extension.json.arrayr   r   r   Zfixturer	   r   r   r   r   r   r   r   r   ZBaseDtypeTestsr=   ZBaseInterfaceTestsr?   ZBaseConstructorsTestsrS   ZBaseReshapingTestsr^   ZBaseGetitemTestsrc   ZBaseIndexTestsrd   ZBaseMissingTestsre   rP   rb   r{   ZBaseNoReduceTestsri   ZBaseMethodsTestsrj   ZBaseCastingTestsr|   ZBaseGroupbyTestsr~   ZBaseArithmeticOpsTestsr   ZBaseComparisonOpsTestsr   ZBasePrintingTestsr   r   r   r   r   <module>   sN   







*"
:)