a
    ضaig                  	   @   sX  d dl Z d dlZd dlmZ d dlmZmZ d dlmZ d dlZ	d dl
mZmZmZ d dlZd dlmZ d dlmZ d dlmZ d dlmZ G dd	 d	ZG d
d dZG dd dZdd Zdd Zedd Zdd Zdd ZddddddgiifdddddddgiiffZdi i fddddddi fddiddiddddgiiffZ ej!"dedd  Z#ej!"d!e d"d# Z$d$d% Z%d&d' Z&d(d) Z'd*d+ Z(d,d- Z)d.d/ Z*d0d1 Z+ej!"d2e	,d3-d4d5dfe	,d3dfe	,d3e	,d4fgd6d7 Z.d8d9 Z/d:d; Z0d<d= Z1d>d? Z2d@dA Z3dBdC Z4dDdE Z5dFdG Z6dHdI Z7dJdK Z8dLdM Z9dS )N    N)ref)patchMock)datetime)assert_array_equalassert_approx_equalassert_array_almost_equal)_api)delete_masked_pointsc                   @   s,   e Zd Zdd Zdd Zdd Zdd Zd	S )
Test_delete_masked_pointsc                 C   s@   t t" tdtdd W d    n1 s20    Y  d S )Nza stringg      ?g      @)pytestraises
ValueErrorr
   nparangeself r   k/Users/vegardjervell/Documents/master/model/venv/lib/python3.9/site-packages/matplotlib/tests/test_cbook.pytest_bad_first_arg   s    z,Test_delete_masked_points.test_bad_first_argc                 C   s^   g d}dddt jt jdg}t||\}}g d}t|t ||  t|t ||  d S )N)abcdef            )r   r   r      )r   nanr
   r   array)r   Za1Za2Zresult1Zresult2indr   r   r   test_string_seq   s    z)Test_delete_masked_points.test_string_seqc              	   C   s   t dddt dddt dddt dddt dddt dddg}tjjdddtjtjdgg dd	}t||}g d
}t|d t||  t|d ||   d S )Ni  r   r   r      r    r   FFTTFFmaskr   r   r    r   )r   r   mar"   r!   r
   r   
compressed)r   datesa_maskedactualr#   r   r   r   test_datetime!   s    
z'Test_delete_masked_points.test_datetimec                 C   sp   t jjdddt jt jdgg dd}tg d}t||}g d}t|d	 ||   t|d ||  d S )
Nr   r   r   r   r&   r'   )rgr   r   myr)   r   )	r   r*   r"   r!   mcolorsZto_rgba_arrayr
   r   r+   )r   r-   Za_rgbar.   r#   r   r   r   	test_rgba,   s    
z#Test_delete_masked_points.test_rgbaN)__name__
__module____qualname__r   r$   r/   r5   r   r   r   r   r      s   r   c                   @   st   e Z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 )Test_boxplot_statsc                 C   s   t jd d| _d| _t jj| j| jfddd| _tg d| _t	
| j| _dd	d
ddt g dddddd
| _ddd| _ddt ddgd| _ddd| _ddd| _d S )Ni  %   r%         ?g      ?)sizemeansigma)r=   medq1q3iqrcilocihiwhislowhishiflierslabelgP$C@g@ÿg>zzD*@gjtxJ*@gDm(
@)Ӿ#W@79qU@gEɳE@gqמC@g]Y?g6 v-@gIQ;@g inޓ?)
rD   rC   rB   r=   r?   rG   r@   rA   rF   rE   gN!@g?)rD   rC   g =ɳE@rI   rJ   )rF   rE   rG   geLM?)rE   rF   g,#W@)r   randomseedZnrowsZncolsZ	lognormaldatasorted
known_keyscbookboxplot_statsstd_resultsr"   known_nonbootstrapped_resknown_bootstrapped_ciknown_whis3_resknown_res_percentilesknown_res_ranger   r   r   r   setup7   s@    zTest_boxplot_stats.setupc                 C   s   t | jtsJ d S N)
isinstancerR   listr   r   r   r   test_form_main_listi   s    z&Test_boxplot_stats.test_form_main_listc                 C   s   | j D ]}t|tsJ qd S rY   )rR   rZ   dictr   resr   r   r   test_form_each_dictl   s    
z&Test_boxplot_stats.test_form_each_dictc                 C   s&   | j D ]}t|t| jksJ qd S rY   )rR   setrO   r^   r   r   r   test_form_dict_keysp   s    
z&Test_boxplot_stats.test_form_dict_keysc                 C   s0   | j d }| j D ]\}}t|| | qd S )Nr   )rR   rS   itemsr   )r   r_   keyvaluer   r   r   test_results_baselinet   s    
z(Test_boxplot_stats.test_results_baselinec                 C   s>   t j| jdd}|d }| j D ]\}}t|| | q"d S )Ni'  )Z	bootstrapr   )rP   rQ   rM   rT   rc   r   r   resultsr_   rd   re   r   r   r   test_results_bootstrappedy   s    z,Test_boxplot_stats.test_results_bootstrappedc                 C   s>   t j| jdd}|d }| j D ]\}}t|| | q"d S )Nr   Zwhisr   )rP   rQ   rM   rU   rc   r   rg   r   r   r   test_results_whiskers_float   s    z.Test_boxplot_stats.test_results_whiskers_floatc                 C   sB   t j| jddgd}|d }| j D ]\}}t|| | q&d S )Nr   d   rj   )rP   rQ   rM   rW   rc   r   rg   r   r   r   test_results_whiskers_range   s    z.Test_boxplot_stats.test_results_whiskers_rangec                 C   sB   t j| jddgd}|d }| j D ]\}}t|| | q&d S )Nr    _   rj   r   )rP   rQ   rM   rV   rc   r   rg   r   r   r   !test_results_whiskers_percentiles   s    z4Test_boxplot_stats.test_results_whiskers_percentilesc                 C   sb   g d}t j| j|d}t||D ]\}}|d |ks"J q"t | j}|D ]}d|vsLJ qLd S )N)ZTest1r   Zardvarkr%   labelsrH   )rP   rQ   rM   zip)r   rq   rh   Zlabr_   r   r   r   test_results_withlabels   s    z*Test_boxplot_stats.test_results_withlabelsc                 C   sF   ddg}t t  tj| j|d W d    n1 s80    Y  d S )Nr   r   rp   )r   r   r   rP   rQ   rM   )r   rq   r   r   r   test_label_error   s    z#Test_boxplot_stats.test_label_errorc                 C   sF   t jjdd}tt t| W d    n1 s80    Y  d S )N)"   ru   ru   )r<   )r   rK   normalr   r   r   rP   rQ   )r   rM   r   r   r   test_bad_dims   s    z Test_boxplot_stats.test_bad_dimsc                 C   s   t jdd}t d|dg}tj|dd}tj|dd}|d d	 dksLJ |d d
 dks`J t|d d ddg |d d	 dksJ |d d
 dksJ t|d d g  d S )N   )shapei   F)Z	autorangeTr   rE   rF   rG   )r   ZzerosZhstackrP   rQ   r   )r   xZbstats_falseZbstats_truer   r   r   "test_boxplot_stats_autorange_false   s    z5Test_boxplot_stats.test_boxplot_stats_autorange_falseN)r6   r7   r8   rX   r\   r`   rb   rf   ri   rk   rm   ro   rs   rt   rw   r|   r   r   r   r   r9   6   s   2
r9   c                   @   s   e Zd Zdd Zdd Zdd Zdd Zd	d
 Z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gdd Ze	j
dddgdd Zdd Zdd ZdS )Test_callback_registryc                 C   s   d| _ t | _d S )Ntest)signalrP   CallbackRegistry	callbacksr   r   r   r   rX      s    zTest_callback_registry.setupc                 C   s$   | j ||}|r | j j| |S rY   )r   connect_pickled_cidsadd)r   sfuncpicklecidr   r   r   r      s    zTest_callback_registry.connectc                 C   s   | j |S rY   )r   
disconnect)r   r   r   r   r   r      s    z!Test_callback_registry.disconnectc                 C   s:   t | jj| jg }t | jj| j}||ks6J |S rY   )lenr   _func_cid_mapgetr   )r   Zcount1Zcount2r   r   r   count   s    zTest_callback_registry.countc                 C   s@   t j  | jji ksJ | jji ks*J | jjt ks<J d S rY   )r   testingbreak_cyclesr   r   r   ra   r   r   r   r   is_empty   s    
zTest_callback_registry.is_emptyc                 C   s.   t j  | jji ksJ | jji ks*J d S rY   )r   r   r   r   r   r   r   r   r   is_not_empty   s    
z#Test_callback_registry.is_not_emptyr   TFc                 C   s   |    t }| | j|j|}t|tks0J |   | | j|j|}||ksVJ |   t| j	j
dksrJ t| j	j	dksJ ~|    d S )Nr   )r   r}   r   r   dummytypeintr   r   r   r   )r   r   mini_mecid1Zcid2r   r   r   test_callback_complete   s    z-Test_callback_registry.test_callback_completec                 C   sN   |    t }| | j|j|}t|tks0J |   | | |    d S rY   	r   r}   r   r   r   r   r   r   r   r   r   r   r   r   r   r   test_callback_disconnect   s    
z/Test_callback_registry.test_callback_disconnectc                 C   sN   |    t }| | j|j|}t|tks0J |   | d |   d S )Nfoor   r   r   r   r   test_callback_wrong_disconnect   s    
z5Test_callback_registry.test_callback_wrong_disconnectc                 C   s|   |    t }| | j|j| t }| | j|j| t }| | j|j| |   |  dkshJ d }d }|    d S )Nr   )r   r}   r   r   r   r   r   )r   r   r   Zmini_me2r   r   r   'test_registration_on_non_empty_registry  s    z>Test_callback_registry.test_registration_on_non_empty_registryc                 C   s   d S rY   r   r   r   r   r   r   *  s    zTest_callback_registry.dummyc                 C   s"   t ttt dsJ d S )Nr   )hasattrr   loadsdumpsrP   r   r   r   r   r   test_pickling-  s    z$Test_callback_registry.test_picklingN)r6   r7   r8   rX   r   r   r   r   r   r   markparametrizer   r   r   r   r   r   r   r   r   r   r}      s    



r}   c                 C   s   t  }|ddd  |t ddd  tt |dd W d    n1 sV0    Y  |  }|j	|j
  krdksn J |t ddd  |dd |  }|j	dksJ d	|j
v sJ d S )
Nr   c                   S   s   d S rY   r   r   r   r   r   <lambda>4      zAtest_callbackregistry_default_exception_handler.<locals>.<lambda>"_get_running_interactive_frameworkc                   S   s   d S rY   r   r   r   r   r   r   7  r   zargument mismatch c                   S   s   dS )Nznot-noner   r   r   r   r   r   >  r   z,takes 0 positional arguments but 1 was given)rP   r   r   setattrr   r   	TypeErrorprocessZ
readouterrouterr)ZcapsysmonkeypatchcbZouterrr   r   r   /test_callbackregistry_default_exception_handler2  s     
*
r   c                    s   G dd dt  dd }dd } fdd}tjd d	}|d
| tj|d	}|d
| tj|d	}|d
| tjd|tg| g|tgg| S )Nc                   @   s   e Zd ZdS )z%raising_cb_reg.<locals>.TestExceptionNr6   r7   r8   r   r   r   r   TestExceptionF  s   r   c                   S   s   t d S rY   )RuntimeErrorr   r   r   r   raise_runtime_errorI  s    z+raising_cb_reg.<locals>.raise_runtime_errorc                   S   s   t d S rY   r   r   r   r   r   raise_value_errorL  s    z)raising_cb_reg.<locals>.raise_value_errorc                    s   t | tr | d S rY   )rZ   r   excpr   r   r   transformerO  s    
z#raising_cb_reg.<locals>.transformerZexception_handlerr   zcb, excp)		ExceptionrP   r   r   r   r   r   r   r   )r   r   r   r   Zcb_oldZcb_filtZcb_filt_passr   r   r   raising_cb_regE  s$    r   c                 C   sJ   |  tddd  t| |d W d    n1 s<0    Y  d S )Nr   c                   S   s   d S rY   r   r   r   r   r   r   i  r   z@test_callbackregistry_custom_exception_handler.<locals>.<lambda>r   )r   rP   r   r   r   )r   r   r   r   r   r   .test_callbackregistry_custom_exception_handlerf  s
    
r   c               	   C   s^  dd } t j| d}dd }dd }|d| |d	| | $ |d |d	 W d    n1 sn0    Y  |jdd
R |d tjtdd |d	 W d    n1 s0    Y  W d    n1 s0    Y  tjtdd |d W d    n1 s0    Y  tjtdd |d	 W d    n1 sP0    Y  d S )Nc                 S   s   | d S rY   r   r   r   r   r   raise_handlerq  s    z5test_callbackregistry_blocking.<locals>.raise_handlerr   c                   S   s   t dd S )N1 should be blockedr   r   r   r   r   
test_func1t  s    z2test_callbackregistry_blocking.<locals>.test_func1c                   S   s   t dd S )N2 should be blockedr   r   r   r   r   
test_func2v  s    z2test_callbackregistry_blocking.<locals>.test_func2Ztest1Ztest2)r   r   matchr   )rP   r   r   Zblockedr   r   r   r   )r   r   r   r   r   r   r   test_callbackregistry_blockingn  s"    

(
F*r   c                  C   s   dddd} g d}g d}g d}|t t|  ks>J |t t|  ksXJ |t t|  ksrJ |t|ksJ |t|ksJ d S )Nr   r   r   r   r   r   r   r   r   ))r   r   )r   r   )r   r   )rN   rP   Zsanitize_sequencekeysvaluesrc   )r   kvir   r   r   test_sanitize_sequence  s    r   r   r   )r   r   Zalias_mappingr   r   zinp, kwargs_to_normc              	   C   sh   t tJ t " tj| fi | W d    n1 s<0    Y  W d    n1 sZ0    Y  d S rY   )r   r   r   r	   'suppress_matplotlib_deprecation_warningrP   normalize_kwargs)inpkwargs_to_normr   r   r   test_normalize_kwargs_fail  s    r   zinp, expected, kwargs_to_normc                 C   sF   t  * |tj| fi |ks$J W d    n1 s80    Y  d S rY   )r	   r   rP   r   )r   expectedr   r   r   r   test_normalize_kwargs_pass  s    
r   c               	   C   st   t tdT} td d| _tjtdd t	d W d    n1 sH0    Y  W d    n1 sf0    Y  d S )Nsys)Zreturn_valuez	\Adummy\Zr   r   )
r   objectrP   r   	_getframer   ZwarnsUserWarningr	   warn_external)Zmock_sysr   r   r   (test_warn_external_frame_embedded_python  s    r   c            	      C   s   t d} t d}t dd d d }t| ||\}}}t jg dtd}t jg dtd}t jg dtd}t|| t|| t|| t| |\}}t|| t|| d S )Nr%   r   r   r   r   r   r   r   dtyper   r   r   r   r   r   r   )r   r   r   r   r   r   r   )r   r   rP   pts_to_prestepasarrayfloatr   	r{   y1y2xsZy1sZy2sZx_targetZ	y1_targetZ	y2_targetr   r   r   test_to_prestep  s    





r   c                  C   s   t g g } | jdksJ d S N)r   r   )rP   r   ry   Zstepsr   r   r   test_to_prestep_empty  s    r   c            	      C   s   t d} t d}t dd d d }t| ||\}}}t jg dtd}t jg dtd}t jg dtd}t|| t|| t|| t| |\}}t|| t|| d S )Nr%   r   r   r   r   )r   r   r   r   r   r   r   )r   r   rP   pts_to_poststepr   r   r   r   r   r   r   test_to_poststep  s    





r   c                  C   s   t g g } | jdksJ d S r   )rP   r   ry   r   r   r   r   test_to_poststep_empty  s    r   c            	      C   s   t d} t d}t dd d d }t| ||\}}}t jg dtd}t jg dtd}t jg dtd}t|| t|| t|| t| |\}}t|| t|| d S )Nr%   r   )r         ?r   r;   r;         @r   r   r   )r   r   r   r   r   r   r   r   )r   r   r   r   r   r   r   r   )r   r   rP   pts_to_midstepr   r   r   r   r   r   r   test_to_midstep  s    





r   c                  C   s   t g g } | jdksJ d S r   )rP   r   ry   r   r   r   r   test_to_midstep_empty  s    r   args   r   r%   c                 C   s8   t t tj|   W d    n1 s*0    Y  d S rY   )r   r   r   rP   r   )r   r   r   r   test_step_fails  s    r   c            
         s  G dd d  fddt dD  \} }}}}}t }|j|  tt|d t|ks`J t|| t|kszJ |dd  D ]}|| |sJ q||  |dd  D ]}|| |rJ qt	
|dd  |dd  D ]\}}	|||	sJ qd S )Nc                   @   s   e Zd ZdS )ztest_grouper.<locals>.DummyNr   r   r   r   r   Dummy  s   r   c                    s   g | ]
}  qS r   r   .0_r   r   r   
<listcomp>  r   z test_grouper.<locals>.<listcomp>r    r   r   )rangerP   Grouperjoinra   r[   Zget_siblingsZjoinedremove	itertoolsproduct)
r   r   r   r   r   objsr1   otherABr   r   r   test_grouper  s    $

$r  c                     s   G dd d  fddt dD } t }|j|   |j}| D ]}t||v s@J q@|t| d  }| dd  D ]}|t| |u srJ qrd S )Nc                   @   s   e Zd ZdS )z#test_grouper_private.<locals>.DummyNr   r   r   r   r   r   '  s   r   c                    s   g | ]
}  qS r   r   r   r   r   r   r   )  r   z(test_grouper_private.<locals>.<listcomp>r    r   r   )r   rP   r   r   _mappingr   )r  r1   mappingoZbase_setr   r   r   test_grouper_private&  s    
r
  c                  C   sj   t d} | j}dt|ks J dt|ks0J t|}|dksFJ dt|ksVJ dt|ksfJ d S )Nr    r   r   )r   r   ZflatnextrP   safe_first_element)r{   itretr   r   r   test_flatiter7  s    

r  c                     s  G dd d t g d} t| dks,J  fddtdD }t |d} t| dks`J td}t |d} t| dksJ  fd	dtd
D }t |d} t| dksJ tjd
d}t |d} t| dksJ dgdgd
gg}t |d} t| t	sJ t| d tj
r6| d jdks:J t| d tj
r\| d jdks`J t| d tj
r| d jdksJ g dd
dgdgg}t |d} t| t	sJ t| d tj
r| d jdksJ t| d tj
r| d jdksJ t| d tj
r$| d jdks(J G dd dtj
}tjdtd}|dt|jd}t |d} t| dksvJ t| d |sJ g d}t |d} t| d t|ksJ t| d tj
sJ d S )Nc                   @   s   e Zd ZdS )ztest_reshape2d.<locals>.DummyNr   r   r   r   r   r   E  s   r   r{   )r   r   c                    s   g | ]
}  qS r   r   r   r   r   r   r   K  r   z"test_reshape2d.<locals>.<listcomp>r    )r   r    c                    s"   g | ]} fd dt dD qS )c                    s   g | ]
}  qS r   r   r   r   r   r   r   T  r   z-test_reshape2d.<locals>.<listcomp>.<listcomp>r    r   r   r   r   r   r   T  r   r   )r   r    )r    r   r   r   r   )r   r   r%   )r   )r   c                       s(   e Zd Z fddZ fddZ  ZS )z%test_reshape2d.<locals>.ArraySubclassc                 3   s    t   D ]}t|V  q
d S rY   )super__iter__r   r"   )r   re   	__class__r   r   r  w  s    z.test_reshape2d.<locals>.ArraySubclass.__iter__c                    s   t t |S rY   )r   r"   r  __getitem__)r   itemr  r   r   r  {  s    z1test_reshape2d.<locals>.ArraySubclass.__getitem__)r6   r7   r8   r  r  __classcell__r   r   r  r   ArraySubclassu  s   r  
   r   )r  )r   buffer)	r   r   r   r   ddr   r   ffr   )rP   _reshape_2Dr   ry   r   r   rK   ZrandrZ   r[   Zndarrayr   rM   r   )xnewr{   r  r   r   r   r   test_reshape2dC  sJ    
&&&&&&		r  c                 C   s   t ddd}| j|g dd}t|d}t|j|D ]\}}t j	|| q<t ddd}| j|g dd}t|d}t|j|D ]\}}t j	|| qd S )N   r  r   r   )columnsr{   )
r   r   reshapeZ	DataFramerP   r  rr   Tr   r   )pdXr{   ZXnewr  r   r   r   test_reshape2d_pandas  s    r&  c                  C   s"  d\} }}dg|  dg|  dg|  }d| f| | | | | fg}t ||ksVJ d\}}|dg|  }t ||ks~J dg| |d |   }|||  f||  | ||  | | fg}t ||ksJ |dg|  }t ||ksJ t dgd g ks
J t g g ksJ d S )N)r   r%   r    TFr   )r      r    )rP   Zcontiguous_regions)r   r   r   r(   r   r   r   r   r   r   test_contiguous_regions  s    
(r(  c                 C   s2   | j tdtddd}t|}|dks.J d S )Nr    r     )indexr   )ZSeriesr   rP   r  )r$  r   r.   r   r   r   %test_safe_first_element_pandas_series  s    
r+  c                 C   s0   t d t| dksJ | d jtks,J d S )NZoopsr   r   )r	   r   r   filename__file__)Zrecwarnr   r   r   test_warn_external  s    
r.  c                  C   sl   dd } dd }dD ]R\}}t || ||}t||d ||d D ]\}}| |||d qNqd S )Nc              	   S   s   | j \}}g td|d ||d }g td|d ||d }g }t|d d |dd  D ]Z\}}	t|d d |dd  D ]6\}
}t| ||	d |
|d f j}|| qq`t|}t	|tj
| ||dsJ d S )Nr   r   r   rstridecstride)ry   r   rr   rP   Z_array_perimeterr#  appendr   r   Zarray_equalZ_array_patch_perimeters)r{   r0  r1  rowscolsZrow_indsZcol_indsZpolysrsZrs_nextcsZcs_nextZpsr   r   r   check  s    
""$
z*test_array_patch_perimeters.<locals>.checkc                    s    fddt d d D S )Nc                    s   g | ]} | d kr|qS )r   r   )r   r   nr   r   r     r   zAtest_array_patch_perimeters.<locals>.divisors.<locals>.<listcomp>r   r  r8  r   r8  r   divisors  s    z-test_array_patch_perimeters.<locals>.divisors))r    r    )r'     )   	   r   r/  )r   r   r"  r   r  )r7  r:  r3  r4  r{   r0  r1  r   r   r   test_array_patch_perimeters  s    
r>  c                     s2  G dd d G dd d }    fdd}|  j _| tjddd	d
 dddd
 dddd
 j j u sJ jju sJ jdksJ jdksJ jdksJ jdksJ jj ksJ jdksJ j	dksJ j
dksJ W d    n1 s0    Y  | d S )Nc                   @   sZ   e Zd Ze Ze Zdd Zdd Zedd Z	e
dd Zed	d
 Zejdd
 ZdS )ztest_setattr_cm.<locals>.Ac                 S   s   d| _ d| _d| _d S )Naardvarkoverridep)r?  r@  _pr   r   r   r   __init__  s    z#test_setattr_cm.<locals>.A.__init__c                 S   s   d S rY   r   r   r   r   r   meth  s    ztest_setattr_cm.<locals>.A.methc                 S   s   d S rY   r   )clsr   r   r   classy  s    z!test_setattr_cm.<locals>.A.classyc                   S   s   d S rY   r   r   r   r   r   static  s    z!test_setattr_cm.<locals>.A.staticc                 S   s   | j S rY   rB  r   r   r   r   prop  s    ztest_setattr_cm.<locals>.A.propc                 S   s
   || _ d S rY   rH  )r   valr   r   r   rI    s    N)r6   r7   r8   r   	cls_levelr@  rC  rD  classmethodrF  staticmethodrG  propertyrI  setterr   r   r   r   r    s   


r  c                   @   s   e Zd ZdS )ztest_setattr_cm.<locals>.BNr   r   r   r   r   r    s   r  c                    s   | j | j usJ | j| ju s J jdks.J | j| ju s>J | j ju sNJ | jdks\J t| drjJ | jdksxJ | jj ksJ | j ju sJ d| jvsJ d| jvsJ d| jvsJ d S )Nr?  r@  extrarA  rK  rF  rG  )rD  r?  rI  rK  r@  r   monkey__dict__)objr  r   r  r   r   verify_pre_post_state  s    z.test_setattr_cm.<locals>.verify_pre_post_stateZsquirrelZmoosec                   S   s   d S rY   r   r   r   r   r   r     r   z!test_setattr_cm.<locals>.<lambda>ZboorP  c                   S   s   d S rY   r   r   r   r   r   r      r   ZbobrF  rG  )	rI  r?  rD  r@  rP  rQ  rK  rF  rG  )rD  rQ  rP   Z_setattr_cmr?  r@  rP  rI  rK  rF  rG  )r  rU  r   rT  r   test_setattr_cm  s2    0rV  c                  C   s   t j} | dddksJ | dddks*J | dddks<J | dddksNJ | dd	dks`J | d
d	dksrJ | dd	dksJ | d
d| d
d  krdksn J d S )Nr   r   0r   r   g(0z-0gHz>r    gӴ:T?z0.00123gӴ:Tz-0.00123   r  z
0.00123456)rP   Z_format_approx)r   r   r   r   test_format_approx2  s    rY  ):r   r   weakrefr   Zunittest.mockr   r   r   Znumpyr   Znumpy.testingr   r   r   r   Z
matplotlibr	   Zmatplotlib.cbookrP   Zmatplotlib.colorscolorsr4   r
   r   r9   r}   r   r   r   r   r   Zfail_mappingZpass_mappingr   r   r   r   r   r   r   r   r   r   r   r   r"  r   r  r
  r  r  r&  r(  r+  r.  r>  rV  rY  r   r   r   r   <module>   sv   "~~!
!


LR