o
    ҷh                     @   s  d dl Z d dlZd dl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
gd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gddd Zejdd d d d!d d"d gg d#d$d%d& Zejddgdd'd( Zejddgdd)d* Zejddgdd+d, Zejd-d.gdd/d0 Zejddgdd1d2 Zejd3d4 Zejd5efd6d7ZdS )8    N)Seriesoptionsc                   C      t )z3A fixture providing the ExtensionDtype to validate.NotImplementedError r   r   R/var/www/html/venv/lib/python3.10/site-packages/pandas/tests/extension/conftest.pydtype      r	   c                   C   r   )z
    Length-100 array for this type.

    * data[0] and data[1] should both be non missing
    * data[0] and data[1] should not be equal
    r   r   r   r   r   data      r   c                 C   s   | j s| jdkstd t)z
    Length-100 array in which all the elements are two.

    Call pytest.skip in your fixture if the dtype does not support divmod.
    mzNot a numeric dtype)_is_numerickindpytestskipr   r	   r   r   r   data_for_twos   s   
r   c                   C   r   )zLength-2 array with [NA, Valid]r   r   r   r   r   data_missing+   r
   r   )paramsc                 C   s    | j dkr|S | j dkr|S dS )z5Parametrized fixture giving 'data' and 'data_missing'r   r   Nparam)requestr   r   r   r   r   all_data1   s
   

r   c                    s    fdd}|S )a  
    Generate many datasets.

    Parameters
    ----------
    data : fixture implementing `data`

    Returns
    -------
    Callable[[int], Generator]:
        A callable that takes a `count` argument and
        returns a generator yielding `count` datasets.
    c                 3   s    t | D ]} V  qd S N)range)count_r   r   r   genJ   s   zdata_repeated.<locals>.genr   )r   r   r   r   r   data_repeated:   s   r    c                   C   r   )z
    Length-3 array with a known sort order.

    This should be three items [B, C, A] with
    A < B < C

    For boolean dtypes (for which there are only 2 values available),
    set B=C=True
    r   r   r   r   r   data_for_sortingQ   s   r!   c                   C   r   )z{
    Length-3 array with a known sort order.

    This should be three items [B, NA, A] with
    A < B and NA missing.
    r   r   r   r   r   data_missing_for_sorting_   r   r"   c                   C   s   t jS )z
    Binary operator for comparing NA values.

    Should return a function of two arguments that returns
    True if both arguments are (scalar) NA for your type.

    By default, uses ``operator.is_``
    )operatoris_r   r   r   r   na_cmpj   s   
r%   c                 C      | j S )z>The scalar missing value for this type. Default dtype.na_value)na_valuer   r   r   r   r'   w      r'   c                   C   r   )z
    Data for factorization, grouping, and unique tests.

    Expected to be like [B, B, NA, NA, A, A, B, C]

    Where A < B < C and NA is missing.

    If a dtype has _is_boolean = True, i.e. only 2 unique non-NA entries,
    then set C=B.
    r   r   r   r   r   data_for_grouping}   s   r)   TFc                 C   r&   )z#Whether to box the data in a Seriesr   r   r   r   r   box_in_series   r(   r+   c                 C   s   dS N   r   xr   r   r   <lambda>       r0   c                 C   s   dgt |  S r,   )lenr.   r   r   r   r0      s    c                 C   s   t dgt|  S r,   )r   r2   r.   r   r   r   r0      s    c                 C   s   | S r   r   r.   r   r   r   r0      r1   )scalarlistseriesobject)r   idsc                 C   r&   )z,
    Functions to test groupby.apply().
    r   r*   r   r   r   groupby_apply_op   s   r8   c                 C   r&   )zU
    Boolean fixture to support Series and Series.to_frame() comparison testing.
    r   r*   r   r   r   as_frame      r9   c                 C   r&   )zL
    Boolean fixture to support arr and Series(arr) comparison testing.
    r   r*   r   r   r   	as_series   r:   r;   c                 C   r&   )zd
    Boolean fixture to support comparison testing of ExtensionDtype array
    and numpy array.
    r   r*   r   r   r   	use_numpy      r<   ffillbfillc                 C   r&   )z{
    Parametrized fixture giving method parameters 'ffill' and 'bfill' for
    Series.fillna(method=<method>) testing.
    r   r*   r   r   r   fillna_method   r=   r@   c                 C   r&   )zR
    Boolean fixture to support ExtensionDtype _from_sequence method testing.
    r   r*   r   r   r   as_array   r:   rA   c                 C   s
   t t S )z
    A scalar that *cannot* be held by this ExtensionArray.

    The default should work for most subclasses, but is not guaranteed.

    If the array can hold any item (i.e. object dtype), then use pytest.skip.
    )r6   __new__r   r   r   r   invalid_scalar   s   
	rC   returnc                   C   s   t jjo	t jjdkS )z7
    Fixture to check if Copy-on-Write is enabled.
    block)r   modecopy_on_writedata_managerr   r   r   r   using_copy_on_write   s   rI   )r#   r   pandasr   r   fixturer	   r   r   r   r   r    r!   r"   r%   r'   r)   r+   r8   r9   r;   r<   r@   rA   rC   boolrI   r   r   r   r   <module>   sd    














	





