U
    Fvf                     @   s   d dl 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
 d dlmZ d dlmZ d dlmZ d dlmZ d dlmZmZ d dlmZmZmZmZmZ d dlZd d	lm Z  d dl!Z!e!j"d
d Z#dd Z$e!j%&de' e'ddde'dddde'e'dddgdd Z(e!j%&dddge!j%&dd dgddgddgge!j%&dd dgddgddggdd  Z)d!d" Z*e!j%&d#dd$gd%d&ggd'd( Z+d)d* Z,d+d, Z-d-d. Z.e!j%&d/dd%gd0d1 Z/e!j%&d/dd%gd2d3 Z0d4d5 Z1e!j%&d6ej2ej3gd7d8 Z4d9d: Z5e!j%&d;d%dgd<d= Z6d>d? Z7d@dA Z8e!j%&dBdd%gdCdD Z9e!j%&dEdd%gdFdG Z:e!j%&dHdId%e'dddJfdKde'ddLfdId%e'e'dddfdId%e'ddMfgdNdO Z;e!j%&dBdd%gdPdQ Z<e!j%&dEdd%gdRdS Z=e!j%&dTdd%gdUdV Z>dWdX Z?dYdZ Z@e!j%&d[d\d]gd^d_ ZAe!j%&d[d\d]gd`da ZBdbdc ZCddde ZDe!j%&dfdgdhdi ZEe!j%jFdjddkdldm ZGdndo ZHdpdq ZIe!j%&de' e'd%e'drdsdte'dddgdudv ZJdwdx ZKe!j%&dydzd{d|gd}d~ ZLedgddddd ZMedgddd ZNedgddd ZOdd ZPedgddd ZQedgddd ZRedgddd ZSedgddd ZTedgddd ZUdd ZVdd ZWdd ZXdd ZYdd ZZdd Z[e!j%&ddIdKgdd Z\e!j%&ddIdKgdd Z]dd Z^dd Z_dd Z`e!j%&dd%dgdd Zae!j%&dd%dgdd Zbe dd Zce!j%&ddddge!j%&dd%dgdd Zde!j%&dd%dgdd Zee!j%&dd%dgdd Zfe!j%&dd%dgedgddd Zgdd Zhe!j%&dd%dge!j%&dd%dgddĄ ZidS )    N)mock)MatplotlibDeprecationWarning)
MouseEvent)	Rectangle)Line2D)check_figures_equalimage_comparison)click_and_dragdo_eventget_ax
mock_eventnoop)assert_allclosec                   C   s   t  S N)r    r   r   A/tmp/pip-unpacked-wheel-7vhvci0g/matplotlib/tests/test_widgets.pyax   s    r   c            
   	   C   s:  ddl m} m} ddlm} | dkr0td tjdddddgd	\}}||d
 ddg}||d ddgddgddgdddgddgdd}| |d ddgddgd}| |d ddgddgddgddgdddgddgddddgid}|d
 	d |d 	d  |j
  t }	|j|	d!d" W 5 Q R X d S )#Nr   )CheckButtonsRadioButtons)"_get_running_interactive_framework)ZheadlessNz-Callback exceptions are not raised otherwise.   )   r      )ZnrowsZncolsZfigsizeZwidth_ratios)r   r   ZApplesZOrangesr   r   redZorange      colorfontsize	mistyroseZ	peachpuff	edgecolor	facecolorlabel_propsradio_props)r   r   T)actives)r   r   r   ZdarkredZ
darkorange)r'   r%   frame_propscheck_propsZDefaultZStylizedZpdf)format)matplotlib.widgetsr   r   Zmatplotlib.cbookr   pytestZxfailpltsubplots	set_titlecanvasdrawioBytesIOZsavefig)
r   r   r   figr   Z
default_rbZ	styled_rbZ
default_cbZ	styled_cbZresult_afterr   r   r   test_save_blitted_widget_as_pdf   sR    

   
  



r5   kwargsTr   )useblitbutton
   pixels)minspanxminspany
spancoords)fill)propsc                 C   s   t jtd d}tj| |f|}t|ddddd t|ddddd t|dd	d	dd |d
d dkrt|jdddddgdddddgg|jd |	  |j
\\}}}|jdkst|jdkst|jdkst|jdkst|i kstd S )NspecZreturn_valuepressd   r   xdataydatar8   onmove   release   Zdrawtype)linenone      Y@)err_msg)r   Mockr   widgetsRectangleSelectorr
   getr   geometryassert_called_once	call_argsrE   AssertionErrorrF   )r   r6   onselecttoolepressereleaser   r   r   test_rectangle_selectorB   s&    r[   r=   datazminspanx, x1      %@   zminspany, y1c                 C   s,  t jtd d}d\}}|dkrB| j||f| j||f \}}tj| |d|||d}	t|	||f||fd |	jrxt	|
  t|	ddd |	jst	|  |  t|	||f||fd |	jrt	|  |j\\}
}}|
j|kst	|
j|kst	|j|ks
t	|j|kst	|i ks(t	d S )	Nr@   r9   r9   r:   T)interactiver=   r;   r<   startendr   r      rf   )r   rO   r   	transData	transformrP   rQ   r	   _selection_completedrV   assert_not_calledrT   
reset_mockrU   rE   rF   )r   r=   r;   x1r<   y1rW   Zx0Zy0rX   rY   rZ   r6   r   r   r   test_rectangle_minspana   s6    
 


rn   c              	   C   sL   t | dd }| sttjtdd d|_W 5 Q R X | rHtd S )Nc                  W   s   d S r   r   argsr   r   r   <lambda>       z=test_deprecation_selector_visible_attribute.<locals>.<lambda>z was deprecated in Matplotlib 3.6matchF)rP   rQ   get_visiblerV   r,   warnsr   visibler   rX   r   r   r   +test_deprecation_selector_visible_attribute   s    ry   zdrag_from_anywhere, new_center)<   K   Frf   r   c                 C   sj   t j| td|d}t|ddd |jdks.tt|ddd |j|ksJtt|d	d
d |jdksftd S )NT)rW   r`   drag_from_anywherer   r9   rC   x   ra   )2   A         #   r         r      )      )rP   rQ   r   r	   centerrV   )r   r}   Z
new_centerrX   r   r   r   test_rectangle_drag   s    
r   c                 C   s   t j| tdtdddtddd}t|dd	d
 |j}| tjdddksPt	|j
ddd | tjdddksxt	|jD ]$}| dkst	| dks~t	q~|jddd |jD ]$}| dkst	| dkst	qd S )NTb皙?r#   alpha      ?r   )rW   r`   r?   handle_propsr~   r   ra   r333333?black)markeredgecolorr   )rP   rQ   r   dictr	   _selection_artistget_facecolormcolorsto_rgbarV   	set_props_handles_artistsget_markeredgecolor	get_alphaset_handle_propsr   rX   artistr   r   r   .test_rectangle_selector_set_props_handle_props   s     



r   c                 C   s  t j| tdd}t|ddd |jdks,t|j}|d |d  }}|d	 |d
  }}t|||f||fd |j|d ||d |fkst|j}|d |d |d |d  d   }}|d	 | }}t|||f||fd |j|d ||d |d fk st|j}|d |d |d |d  d   }}|d | }}t|||f||fd |j||d |d |d fksrt|j}|d |d  }}|d |d  }}t|||f||fd |j||d ||d fkstd S )NTrW   r`   r~   r   ra   )        rM         $@      ^@r      r9   r   r   r   r   r   r   )rP   rQ   r   r	   extentsrV   )r   rX   r   rE   rF   	xdata_new	ydata_newr   r   r   test_rectangle_resize   s.    &$&$r   c              	   C   s   t j| tdd}t|ddd tt |d W 5 Q R X tt |d W 5 Q R X |d |d	 |d
 d S )NTr   F   r   }      ra   unsupported_stateclearmovesquarer   )rP   rQ   r   r	   r,   raises
ValueError	add_staterx   r   r   r   test_rectangle_add_state   s    

r   r   c                 C   s"  t j| tdd}t|ddd |jdks,t|r@|d d }nd}|j}|d	 |d
  }}d\}}|| ||  }	}
t|||f|	|
f|d |j|d | |	|d | |
fkst|j}|d	 |d |d
 |d  d   }}d}|| | }	}
t|||f|	|
f|d |j|d | |	|d |d
 fks2t|j}|d	 |d |d
 |d  d   }}d}|| | }	}
t|||f|	|
f|d |j|d | |	|d |d
 fkst|j}|d |d |d
 |d  d   }}d}|| | }	}
t|||f|	|
f|d |j|	|d	 | |d |d
 fks.t|j}|d |d |d
 |d  d   }}d}|| | }	}
t|||f|	|
f|d |j|	|d	 | |d |d
 fkst|j}|d |d  }}d\}}|| ||  }	}
t|||f|	|
f|d |j|	|d	 | |
|d
 | fkstd S )NTr   r   r   ra   )     Q@     @_@     @P@g     @`@r   controlr   r   r9   r   rb   rc   keyr   r   r9   r   r   r   rP   rQ   r   r	   r   rV   r   r   r   rX   Zuse_keyr   rE   rF   xdiffydiffr   r   r   r   r   test_rectangle_resize_center   s    

 
& & & &  
r   c                 C   s"  t j| tdd}t|ddd |jdks,t|r@|d d }nd}|j}|d	 |d
  }}d\}}|| ||  }	}
t|||f|	|
f|d |j|d |	|d |d
 | fkst|j}|d	 |d |d
 |d  d   }}d}|| | }	}
t|||f|	|
f|d |j|d |	|d |d
 | fks2t|j}|d	 |d |d
 |d  d   }}d}|| | }	}
t|||f|	|
f|d |j|d |	|d |d
 | fkst|j}|d |d |d
 |d  d   }}d}|| | }	}
t|||f|	|
f|d |j|	|d	 |d |d
 | fks.t|j}|d |d |d
 |d  d   }}d}|| | }	}
t|||f|	|
f|d |j|	|d	 |d |d
 | fkst|j}|d |d  }}d\}}|| ||  }	}
t|||f|	|
f|d |j|d | |d	 |
|d
 fkstd S )NTr   r   r   s   ra   r   r   r   g     \@r   shiftr   r   r   r   r   r   r9   r   r   r   r   r   r   r   r   r   test_rectangle_resize_square<  s    
 

& 
& 
& 
& 
 r   c           	      C   s*  t j| tdd}t|ddd |d |d t|jd |j}|d	 |d
  }}d\}}|| ||  }}t|||f||fd t|j|d | ||d | |d
 | f |j}|d	 |d |d
 |d  d   }}d}|| | }}t|||f||fd t|j|d | ||d | |d
 | f |j}|d	 |d |d
 |d  d   }}d}|| | }}t|||f||fd t|j|d | ||d | |d
 | f |j}|d |d |d
 |d  d   }}d}|| | }}t|||f||fd t|j||d	 | |d | |d
 | f |j}|d |d |d
 |d  d   }}d}|| | }}t|||f||fd t|j||d	 | |d | |d
 | f |j}|d |d  }}d\}}|| ||  }}t|||f||fd t|j|d | |d	 | ||d
 | f d S )NTr   r   r   ra   r   r   r   r   r   r   r   r   r9   r   r   r   r   )rP   rQ   r   r	   r   r   r   )	r   rX   r   rE   rF   r   r   r   r   r   r   r   #test_rectangle_resize_square_center  sv    


 
&
 
&
 
&
 
&
 
 
r   selector_classc              	   C   sF  || t dd}t|ddd |jdks*tt|jdks<tt|dd	d
 |jtdgks^tt|jdksptt|ddd t|dd	d
 t|jdkst|jdkstt|j	ddd d|_	|j	dkstt|j
tddddgddddggdd t|ddd t|jddd |tjkrBtt d|j_W 5 Q R X d S )NTr   rC   rC   r      ra   rC   r   rC   r   r   on_key_pressr   r   rotater   )r      g(\9@g{Gz?)Zatol-   gR]@     xa@g=
ףp[@g     V@g     W@g=
ףp]@g     b@g(\^@)n   r   )r      )rC   r   rC   g
ףp=b@Zunvalid_value)r   r	   r   rV   len_stater
   setr   ZrotationcornersnparrayrP   rQ   r,   r   r   r   Zrotation_point)r   r   rX   r   r   r   test_rectangle_rotate  s2    
r   c                 C   s   t j| tdd}t|ddd |jdks,tt|jdks>tdD ]<}|| t|jd	ksbt|	| t|jdksBtqBd S )
NTr   r   r   ra   r   r   )r   r   r   r   )
rP   rQ   r   r	   r   rV   r   r   r   Zremove_state)r   rX   stater   r   r   test_rectangle_add_remove_set  s    

r   use_data_coordinatesc                 C   s`  |  d tj| td|d}t|ddd |jdks8t|d |d	 |r|j}|d
 |d |d
 |d    }}}d|d |d |d  d   }}|| | }	}
|d | }t|||f|	|
fd t|j|d | |	|| || g nj|j}|d
 |d  }}d}|| | }	}
|d
 |j	 }t|||f|	|
fd t|j|d | |	ddg d S )N皙?T)rW   r`   r   r   r   ra   r   r   r   r   r   r   r9   r   g      G@g     `@)
Z
set_aspectrP   rQ   r   r	   r   rV   r   r   Z_aspect_ratio_correction)r   r   rX   r   rE   rF   widthr   Zycenterr   r   Zychanger   r   r   *test_rectangle_resize_square_center_aspect  s:    



$"  r   c                 C   s   t j| tddd}d|_t|ddd |jdks4tt|d	dd
d |jdksRtt|dddd dd |jD }|ddddgkstt|d	ddd dd |jD }|ddddgkst|jjdkstt|jdddf ddg dS )z'For ellipse, test out the key modifiersr9   T)rW   
grab_ranger`   rC      rC   r   r   r   )r   r   ra   )r      r   r   r   r   r   )r{   r   r{   r   r_   )r   rf   r   c                 S   s   g | ]}t |qS r   int.0er   r   r   
<listcomp>'  s     z test_ellipse.<locals>.<listcomp>r   r   z
ctrl+shiftc                 S   s   g | ]}t |qS r   r   r   r   r   r   r   ,  s     r   r   )r   I   Nr   r   rC   )	rP   EllipseSelectorr   r   r	   rV   rS   shaper   )r   rX   r   r   r   r   test_ellipse  s"     r   c                 C   s   t j| tdddddd}d|_t|jd |jdks:tt|jd	 |jdksTtt|d
dd |jdksptt|ddd |jdkstt|dd
d |jdkstt	
|jjd  dstt	
|jjd  dstd S )Nr9   Tr   r   )Zmarkerfacecolorr   )rW   r   r`   r   r   ))rC   r   r   rC   )rC   rC   r   r   ))rC   r   r   r   )r   rC   r   r   r   )r   r   ra   )r   r   r   r   )   r   )l      r   r   r_   )r9   rC   r9   rC   r   )rP   rQ   r   r   r   r   rV   Zedge_centersr	   r   
same_colorZ_corner_handlesartistsZget_markerfacecolorr   rx   r   r   r   test_rectangle_handles3  s8      r  r`   c                 C   sd   t jtd d}tj| ||d}t|ddd |  |jdksBt|	  t|ddd |  d S )Nr@   r`   rC   r   r   r   ra   rM        b@g     [@r   r9   rC   )
r   rO   r   rP   rQ   r	   rT   r   rV   rk   r   r`   rW   rX   r   r   r    test_rectangle_selector_onselectT  s    r
  ignore_event_outsidec                 C   s   t jtd d}tj| ||d}t|ddd |  |jdksBt|	  t|ddd |rt|
  |jdkstn|  |jd	kstd S )
Nr@   )r  r  r  ra   r  r   r   r   r   )r        d@r  r  )r   rO   r   rP   rQ   r	   rT   r   rV   rk   rj   )r   r  rW   rX   r   r   r   &test_rectangle_selector_ignore_outsidee  s    r  z$orientation, onmove_callback, kwargs
horizontal)Zminspanr7   vertical)r8   r  c                 C   s   t jtd d}t jtd d}|r(||d< tj| ||f|}t|ddddd t|ddddd t|d	d
d
dd |dd |r|dd d S )Nr@   onmove_callbackrB   rC   r   rD   rG   rH   rI   rJ   )r   rO   r   rP   SpanSelectorr
   assert_called_once_with)r   orientationr  r6   rW   rG   rX   r   r   r   test_span_selector|  s    r  c                 C   sf   t jtd d}tj| |d|d}t|ddd |  |jdksDt|	  t|ddd |  d S )	Nr@   r  r  r   )r   rC   ra   )rC   r   r  )
r   rO   r   rP   r  r	   rT   r   rV   rk   r	  r   r   r   test_span_selector_onselect  s    
r  c                 C   s   t jtd d}t jtd d}tj| |d||d}t|ddd |  |  |jdks\t|	  |	  t|dd	d |r|
  |
  |jdkstn|  |  |jd
kstd S )Nr@   r  )r  r  r   r   ra   )rC   r   r  r  )r   r   )r   rO   r   rP   r  r	   rT   r   rV   rk   rj   )r   r  rW   rG   rX   r   r   r   !test_span_selector_ignore_outside  s(    
r  r}   c                 C   s   t j| tdd|d}t|ddd |jdks0tt|dd	d |rR|jd
ks`tn|jdks`tt|ddd |jdks|td S )Nr  T)rW   	directionr`   r}   r_   r   ra   r  r   r   )r   r   )r   r   r   r   )rP   r  r   r	   r   rV   )r   r}   rX   r   r   r   test_span_selector_drag  s    
r  c              	   C   s   t j| tddd}|jdks t|jjdks0ttt t j| tdd}W 5 Q R X d|_|jdksjt|jjdkszttt d|_W 5 Q R X d S )Nr  T)rW   r  r`   Zinvalid_direction)rW   r  r  Zinvalid_string)	rP   r  r   r  rV   _edge_handlesr,   r   r   rx   r   r   r   test_span_selector_direction  s    
r  c              	   C   s   t j| tddtdddtddd}t|d	d
d |j}| tjdddksRt	|j
ddd | tjdddkszt	|jD ]$}| dkst	| dkst	q|jddd |jD ]$}| dkst	| dkst	qd S )Nr  Tr   r   r   r   r   )rW   r  r`   r?   r   r~   r   ra   r   r   r   r   )rP   r  r   r   r	   r   r   r   r   rV   r   r   	get_colorr   r   r   r   r   r   )test_span_selector_set_props_handle_props  s"    



r  selectorspan	rectanglec                 C   s   t | tdd}|dkr&tj}d|d< ntj}|f |}t|ddd t|d	d	d |jr\td|d
< |f |}|jsxtt|ddd t|d	d	d |jstt	|ddd |jrtd S )NT)r   rW   r`   r!  r  r  r_   r   ra   )r   r   r  r   escaper   )
r   r   rP   r  rQ   r	   ri   rV   r  r
   )r   r   r6   ZSelectorrX   r   r   r   test_selector_clear  s"    





r$  c                 C   s   |dkrt j| tdddd}nt j| tdd}t|ddd |jsFt| sRt|dkrh|jd	ksht|	  |jrzt| rtt|dd
d |jst| st|dkr|jdkstd S )Nr!  r  T)rW   r  r`   r  r   r_   r   ra   r  )r   r   )r9   r   )
rP   r  r   rQ   r	   ri   rV   ru   r   r   )r   r   rX   r   r   r   test_selector_clear_method  s&    



r%  c              	   C   s   t j| tddd}tt |d W 5 Q R X tt |d W 5 Q R X tt |d W 5 Q R X |d d S )Nr  Tr  r   r   r   r   )rP   r  r   r,   r   r   r   rx   r   r   r   test_span_selector_add_state9  s    
r&  c                 C   s   dddg}t j| |ddd}|jD ]}| r2t| r"tq"|d |d |jD ]}| sjt| sZtqZ|j|kstd S )Nr   rf   r   r  F)r7   T)	rP   ZToolLineHandlesr  Zget_animatedrV   ru   set_visibleZset_animated	positions)r   r(  Ztool_line_handler   r   r   r   test_tool_line_handleG  s    





r)  r  )r  r  c                 C   s  t dd\}}|ddgddg |jj  | }| }tj	|t
| dd}| |ksbt| |ksrt| dkr~|n|}|jjt|kstdd	g}d
dg}|}	t|||d | |kst| |kst| dkrdnd}
||
 |	|
 g}|jj|ks
td S )Nr   r9   r   rf   Tr  r  r]   g      '@r^      ra   r   )r-   r.   plotfigurer0   r1   Z
get_xboundZ
get_yboundrP   r  printrV   r  r(  listr	   )r  r4   r   Zx_boundZy_boundrX   bound
press_data	move_datarelease_dataindexhandle_positionsr   r   r   test_span_selector_boundZ  s&    r5  ZQtAgg)Zskip_on_importerrorc               	      s  t ddt j dt t \} }|jdd\}|jg dd\ td || | j	
| j  fdd}tj||d	|dddd
}ddg}ddg}t|d|d |d dd t|d|d |d dd | | fkst|jdkst jstt  d |   jdks.tddg}ddg}ddg}t|d|d |d dd t|d|d |d dd |jdkst jstt  d t|d|d |d dd  jdkstdS )zACheck that the animated artists changed in callbacks are updated.r   r   rC   T)Zanimated皙?c                    s<   t | |f\}}||  } t | d S r   )r   Zsearchsortedmeanset_dataZ	full_like)vminvmaxZindminZindmaxvZln2valuesxr   r   r7    s    z:test_span_selector_animated_artists_callback.<locals>.meanr  )r  r  r`   r}   r7   r   rB   rD   rG   FgSG-?   r   gȄC(rI   N)r   linspacepisinr-   r.   r+  pauseZdraw_artistr0   ZblitZbboxrP   r  r
   Z_get_animated_artistsrV   staler   	get_ydataupdate)r4   r   lnr7  r!  r0  r1  r2  r   r<  r   ,test_span_selector_animated_artists_callbackv  sL    



 rH  c                 C   s   dd }t j| |dd}|j}tddd}tdd	d
dddddddg
}tddddddddddg
}|||}t|| d S )Nc                  W   s   d S r   r   ro   r   r   r   rW     s    z4test_snapping_values_span_selector.<locals>.onselectr  )r  r   r   r^   gr6  r   r   333333?ffffff??g
ףp=
@      @      @r         ?)rP   r  Z_snapr   r@  r   r   )r   rW   rX   Zsnap_functionsnap_valuesr=  expectr   r   r   "test_snapping_values_span_selector  s    
rQ  c                    sl    fdd}t dd }tj |d|d}d|_|jdks@td |_|jd ksTtd|_|jdkshtd S )	Nc                    s
   d _ d S )NT)Z_got_onselect)r9  r:  r   r   r   rW     s    z)test_span_selector_snap.<locals>.onselectr   r?  r  )r  rO  )   r   )r   $   )r   ZarangerP   r  r   rV   rO  )r   rW   rO  rX   r   rR  r   test_span_selector_snap  s    
rU  r   )r   )r7   r?   c                 C   sh   t jtd d}tj| |f|}t|ddddd t|ddddd t|dd	d	dd |d
ddg d S )Nr@   rB   rC   r   rD   rG   r   rI   r   r   r   r  )r   rO   r   rP   ZLassoSelectorr
   r  )r   r6   rW   rX   r   r   r   test_lasso_selector  s    rV  c                 C   s`   t | dd}| dddgks$t|d | dddgksDt|dd }|| d S )N)ar   c)TFTTFr   c                   S   s   d S r   r   r   r   r   r   rq     rr   z#test_CheckButtons.<locals>.<lambda>)rP   r   Z
get_statusrV   Z
set_activeZ
on_clickedZ
disconnect)r   checkZcidr   r   r   test_CheckButtons  s    
rZ  toolbarrL   Ztoolbar2Ztoolmanagerc                 C   s   t jd| tjtd d}tjtd d}t| d}|| |	| |j
dksXtt|d |d |j
dkszt|jdkst|  |  |jdkstt|d t|dd	d
 t|ddd
 |jdkstd S )Nr[  r@    Z_clickzx**2r   r   Z	_keypress+r   5r   )r-   rcParamsZ_setr   rO   r   rP   ZTextBoxZ	on_submitZon_text_changetextrV   r
   set_val
call_countZbegin_typingZstop_typing)r   r[  Zsubmit_eventZtext_change_eventrX   r   r   r   test_TextBox  s$    




rc  zcheck_radio_buttons.pngZmpl20)styleZremove_textc            
   
   C   s8  t  } | j}|jdd |ddddg}t|d}tjtdd	 |j	 W 5 Q R X |dd
ddg}t
|dd}tjtdd	 |j W 5 Q R X |ddddg}tj|ddddgdddgddddgdddgdd}|ddddg}tj
|dddddgdddgddddgdddgdddddgid}	d S )Nr   )left皙?rJ  r   333333?)zRadio 1zRadio 2zRadio 3z$The circles attribute was deprecatedrs   r   )zCheck 1zCheck 2zCheck 3)FTT'The rectangles attribute was deprecated      r   r   greenblue)r   r   r    Z	palegreenZ	lightbluer!   r$   r6  r   r%   r(   r)   )r   r,  Zsubplots_adjustZadd_axesrP   r   r,   rv   DeprecationWarningZcirclesr   
rectangles)
r   r4   Zrax1Zrb1Zrax2Zcb1Zrax3Zrb3Zrax4Zcb4r   r   r   test_check_radio_buttons_image  sR       rp  Zpng)
extensionsc                 C   s   t |  ddg |jg g d}|jddgddg|jtjd d d d	d
gd |jddd|jdd |jddd|jdd d S )NteacoffeeZxticksZyticksrg  UUUUUU?UUUUUU?	font.sizer   ZC0rL   )rh   srX        ?r   rh   va)	rP   r   r.   add_subplotscatter	transAxesr-   r_  r`  fig_testfig_refr   r   r   r   test_radio_buttons-  s     r  c                 C   sh   dgdgd}dddd}t j| dd	g||d
 t |  dd	g}|| ||ddi d S )Nr      r   rk  rl  r   r#   r"   	linewidthrr  rs  r$   rx        b@)rP   r   r.   set_label_propsZset_radio_props)r  r  r%   r&   cbr   r   r   test_radio_buttons_props7  s     
r  c              	   C   sR   t jtdd  tj| ddgdddid}W 5 Q R X t|j dd	gsNt	d S )
Nz"Both the \*activecolor\* parameterrs   rr  rs  r   r#   rk  )activecolorr&   rL   )
r,   rv   UserWarningrP   r   r   r   Z_buttonsr   rV   )r   rbr   r   r   !test_radio_button_active_conflictF  s    r  c                 C   s:   t j| ddgdd t j|  ddgdd}d|_d S )Nrr  rs  rk  )r  r   )rP   r   r.   r  )r  r  r  r   r   r   %test_radio_buttons_activecolor_changeO  s    r  c                 C   s   t |  ddgddg |jg g d}|jddgddgd|jtjd	 d
 d
 ddgd |jddgddgd|jtjd	 d
 d
 ddgd |jddd|jdd |jddd|jdd d S )Nrr  rs  Trt  rg  ru  rv  rx  rw  r   rL   )markerrh   rx  rX  r>  kry  r   rz  )	rP   r   r.   r|  r}  r~  r-   r_  r`  r  r   r   r   test_check_buttonsZ  s      r  c                 C   s   dgdgd}dddd}ddd}t j| d	d
gddg|||d t |  d	d
gddg}|| ||ddi |d|d< ||ddi d S )Nr   r  r   rk  rl  r   r  )r#   r  rr  rs  Trm  rx  r  r#   r"   )rP   r   r.   r  Zset_frame_propspopZset_check_props)r  r  r%   r(   r)   r  r   r   r   test_check_button_propsf  s    
 
r  c              	      s   t |  ddgddg}tjtdd |j W 5 Q R X |jg g d ddgd}|d |d   fd	d
tD }|D ]} 	| qd S )Nr\  Frh  rs   rt  ru  rv  r   c              
      s6   g | ].\}}t d | d  fdd jdqS )rf  r   r   rL   )Zxyr   heightr"   r#   rh   )r   r~  )r   iyr   hwysr   r   r     s   z1test_check_buttons_rectangles.<locals>.<listcomp>)
rP   r   r.   r,   rv   rn  ro  r|  	enumerateZ	add_patch)r  r  r  dyro  r"  r   r  r   test_check_buttons_rectangles}  s     r  c              	   C   s  t |  ddgddg}tjtdd |j W 5 Q R X |jD ]}|d q@|j	g g d}ddg}d}|d	 |d	  }}d
d|j
dd}	t|D ]~\}
}d||d	   }}t||| g|| |gf|	}t||| g||| gf|	}|d |d || || qd S )Nr\  Tz"The lines attribute was deprecatedrs   Frt  ru  rv  r   r  g      ?Zbutt)r   r  rh   Zsolid_capstylerf  )rP   r   r.   r,   rv   rn  linesZ_rectanglesr'  r|  r~  r  r   Zadd_line)r  r  r  r"  r   r  r  r  r  Z
lineparamsr  r  r>  l1l2r   r   r   test_check_buttons_lines  s.    



r  c               	   C   sd   t  \} }tt tj|ddddd W 5 Q R X tt tj|ddddd W 5 Q R X d S )Nr\  r         8@r   )r   labelvalminvalmax	slidermin)r   r  r  r  	slidermax)r-   r.   r,   r   r   rP   Slider)r4   r   r   r   r   'test_slider_slidermin_slidermax_invalid  s    r  c                  C   sp   t  \} }tj|ddddd}tj|dddd|d}|j|jksFttj|dddd|d	}|j|jksltd S )
Nr\  r   r  rL  r   r  r  r  valinitrN  )r   r  r  r  r  r  r   )r   r  r  r  r  r  r-   r.   rP   r  valrV   )r4   r   Zslider_sliderr   r   r   test_slider_slidermin_slidermax  s      r  c                  C   sX   t  \} }tj|ddddd}|j|jks0ttj|ddddd}|j|jksTtd S )Nr\  r   r  g      $r  g      9@)r-   r.   rP   r  r  r  rV   r  r4   r   r  r   r   r   test_slider_valmin_valmax  s    r  c               
   C   s`   t  \} }tj|dddddd}|jdks0ttj|ddddddd	d
gd}|jd	ks\td S )Nr\  r   r  g&@r   )r   r  r  r  r  Zvalstepr^   r   rM  g333333@r  r  r   r   r   test_slider_valstep_snapping  s      
r  c                  C   s   t  \} }tj|dddddd}|d |jdks:t|j 	|j
 }t|jddd	d
g t  \} }tj|dddddd}|d |jdkst|j 	|j
 }t|jddd
d	g d S )Nr\  r   r  rj  r  )r   r  r  r  r  r  r9   ry  g?r   r  )r-   r.   rP   r  ra  r  rV   polyget_extentstransformedr~  invertedr   Zbounds)r4   r   r  boxr   r   r   test_slider_horizontal_vertical  s$     
 
r  c                  C   sD   t  \} }tj|ddddd}|d |  |jdks@td S )Nr\  r   r   r   r        ?)r-   r.   rP   r  ra  resetr  rV   r  r   r   r   test_slider_reset  s
    
r  r  c                    sZ   dkrddddg}nddddg}t  \}}tj|ddd d	d
gd}|j |j }t	|
  | d	dd
dg t	|jd  fdd}|d t	|jd t	||d |j |j }t	|
  | ddddg |d t	|jd t	||d |d t	|jd t	||d |  t	|jd t	||d d S )Nr  r   r   r   r   r\  r   rN  r6  (\?r   r  r  r  r  r  ry  r  )r6  r  c                    s,    dkrdd | j D S dd | j D S d S )Nr  c                 S   s   g | ]}|  d  qS r   )rE  r   r  r   r   r   r     s     z?test_range_slider.<locals>.handle_positions.<locals>.<listcomp>c                 S   s   g | ]}|  d  qS r  )	get_xdatar  r   r   r   r     s     )Z_handles)r  r  r   r   r4    s    z+test_range_slider.<locals>.handle_positions)皙?rI  r  rI  )r   r6  )r6  r   )r9   r   )r-   r.   rP   RangeSliderr  r  r  r~  r  r   
get_pointsflattenr  ra  r  )r  idxr4   r   r  r  r4  r   r  r   test_range_slider  s<        


r  c                 C   s   | dkrddddg}nddddg}t  \}}tj|ddd| ddgd	}|j |j }t	|
  | dd
ddg d S )Nr  r   r   r   r   r\  r   rN  r  ry  r  )r-   r.   rP   r  r  r  r  r~  r  r   r  r  )r  r  r4   r   r  r  r   r   r   "test_range_slider_same_init_values(  s        r  c           	      K   sf   t  }tjtdd}tj||f|}| D ]\}}t||f| q(|j|ksNt|j	|fi fksbtdS )a4  
    Helper function to test Polygon Selector.

    Parameters
    ----------
    event_sequence : list of tuples (etype, dict())
        A sequence of events to perform. The sequence is a list of tuples
        where the first element of the tuple is an etype (e.g., 'onmove',
        'press', etc.), and the second element of the tuple is a dictionary of
         the arguments for the event (e.g., xdata=5, key='shift', etc.).
    expected_result : list of vertices (xdata, ydata)
        The list of vertices that are expected to result from the event
        sequence.
    selections_count : int
        Wait for the tool to call its `onselect` function `selections_count`
        times, before comparing the result to the `expected_result`
    **kwargs
        Keyword arguments are passed to PolygonSelector.
    Nr@   )
r   r   rO   r   rP   PolygonSelectorr
   rb  rV   rU   )	event_sequenceexpected_resultZselections_countr6   r   rW   rX   etype
event_argsr   r   r   check_polygon_selector9  s    r  c                 C   s.   dt | |dfdt | |dfdt | |dfgS )NrG   rE   rF   rB   rI   r   r  r   r   r   polygon_place_vertex[  s    r  c                 C   s2   dt | |dfdt | |ddfdt | |ddfgS )NrG   r  rB   r   rD   rI   r  r  r   r   r   polygon_remove_vertexa  s    r  draw_bounding_boxc                 C   s  t jt| d}dddg}tddtddtddtdd}|||d dddg}tddtddd	td
dfdtdddfdtdddfdtdddfdtdddfdtd
dfftddtdd}|||d dddg}tddtddd	tddfdtdddfdtdddfdtdddfdtdddfdtddfftddtdd}|||d dddg}tddtddtddtdddtdddfdtdddfdtdddfdtdddff}|||d dddg}tddtddtddtddd	tddfdtdddfdtdddfdtdddfdtdddfdtddff}|||d dddg}d	td
dfdtdddfdtdddfdtdddfdtdddfdtd
dfd	tddfdtdddfdtdddfdtdddfdtdddfdtddfftddtddtddtdd}|||d dddg}tddtddd	tddfdtddfftddtddtddtdd}|||d d S )Nr  r   r   r   r   r   r   r   r   r   )r{   r   r   r   r   rG   r  rB   r{   rI   Zon_key_release)r   r{   )r   r{   r   rC   r   r   )r{   r{   )r   r{   )r{   r   rJ   r#  )	functoolspartialr  r  r   )r  Zcheck_selectorr  r  r   r   r   test_polygon_selectorg  s     

	
	





r  c                 C   s"  t j| ttdddtdd|d}tddtddtddtdd}|D ]\}}t||f| qJ|j}| dksxt|	 dkst|j
d	d
d | d	kst|	 d
kst|jD ]$}| dkst|	 dkstq|jd	d
d |jD ]&}| d	kst|	 d
kstqd S )Nr   r   r  r   r   )rW   r?   r   r  r   r   r   r   )rP   r  r   r   r  r
   r   r  rV   r   r   r   r   )r   r  rX   r  r  r  r   r   r   r   ,test_polygon_selector_set_props_handle_props  s2    


r  c                 C   s.   |   }|  }tj|tddid}d|_d S )Nrw   F)rW   r?   )r   r   r   rJ  )r.   rP   rQ   r   r   )r  r  ax_test_rX   r   r   r   test_rect_visibility  s    r  r  r   r   c                 C   sv   dddg}t |d  t |d  t |d  t |d  g}|| t dd |tdd t|g }t||d|d d S )	Nr  r  r  r   r   r      r  )r  insertappendr  sumr  )r  r  vertsr  r   r   r   test_polygon_selector_remove  s    





r  c                 C   s\   dddg}t |d  t |d  t |d  t |d  t|d  }t||dd  d| d d S )Nr  r  r  r   r   r   r  )r  r  r  )r  r  r  r   r   r   (test_polygon_selector_remove_first_point  s    





r  c              	   C   s   dddg}t |d  t |d  t |d  t |d  t|d  t|d  t |d  }tj| t|d}|D ]\}}t||f| qh|j|dd kstd S )Nr  r  r  r   r   r   rW   r  )r  r  rP   r  r   r
   r  rV   )r   r  r  r  rX   r  r  r   r   r   test_polygon_selector_redraw'  s    







r  c                 C   s   dddg}|   }tj|t|d}||_|j|ks6t|  }tj|t|d}t|d  t|d  t|d  t|d  }|D ]\}	}
t||	f|
 q~d S )N)r6  r  )r   rK  )r   r   r  r   r   r   )r|  rP   r  r   r  rV   r  r
   )r  r  r  r  r  Z	tool_testZax_refZtool_refr  r  r  r   r   r   "test_polygon_selector_verts_setter?  s,    
    



r  c                 C   s  ddddg}t |d  t |d  t |d  t |d  t |d  }tj| td	d
}|D ]\}}t||f| qV| j}| jj}td|f|	dd 
  td|f|	d 
  td|f|	dd 
  tj|jddddg td|f|	dd 
  td|f|	d 
  td|f|	dd 
  tj|jddddg tj|jjd td|f|	dd  
  td|f|	dd! 
  tj|jdddg tj|jjd d S )"N)r   r   )r   r   )r   (   )r  r   r   r   r   r   Tr  Zbutton_press_event)r  r  Zmotion_notify_eventrd   Zbutton_release_event)r9   r   r~   )r9   r   )r   r9   r_   re   r|   )r   rf   )rf   r  )r  rf   )      4@      D@r  r  )r  r  g      >@r  )r   )r   )r   )r   )r   )r   )r  rP   r  r   r
   rg   r,  r0   r   rh   Z_processr   Ztestingr   r  Z_boxr   )r   r  r  rX   r  r  tr0   r   r   r   test_polygon_selector_boxW  s    




	    
    
    
    
         r  horizOnvertOnc                 C   s  t  jddd\}}t   }tjd ||fd| |d}t|jdksLtt|jdks^tt	|ddd}|
| |jj  |jD ]}| d	kstq|jD ]}| d
kstqtdd |jD |rdndksttdd |jD | rdndkst|j |_|j |_t	|ddd}|
| tdd |jD |rLdndksXttdd |jD | rtdndkstt	|ddd}|
| |jD ]}| d	kstq|jD ]}| d
kstqd S )Nr   T)ZsharexF)r7   r  r  r   ry  r  )r   r   )ry  ry  c                 S   s   g | ]}|  r|qS r   ru   r   rK   r   r   r   r     s      z$test_MultiCursor.<locals>.<listcomp>r   c                 S   s   g | ]}|  r|qS r   r  r  r   r   r   r     s      c                 S   s   g | ]}|  r|qS r   r  r  r   r   r   r     s      c                 S   s   g | ]}|  r|qS r   r  r  r   r   r   r     s      r  )r-   r,  r.   rP   ZMultiCursorr   ZvlinesrV   Zhlinesr   rG   r0   r1   r  rE  r  r  )r  r  Zax1Zax3Zax2Zmultieventlr   r   r   test_MultiCursor  sP        













r  )jr  r2   Zunittestr   Zmatplotlib._api.deprecationr   Zmatplotlib.backend_basesr   Zmatplotlib.colorscolorsr   r+   rP   Zmatplotlib.pyplotZpyplotr-   Zmatplotlib.patchesr   Zmatplotlib.linesr   Zmatplotlib.testing.decoratorsr   r   Zmatplotlib.testing.widgetsr	   r
   r   r   r   Znumpyr   Znumpy.testingr   r,   Zfixturer   r5   markZparametrizer   r[   rn   ry   r   r   r   r   r   r   r   rQ   r   r   r   r   r   r  r
  r  r  r  r  r  r  r  r$  r%  r&  r)  r5  backendrH  rQ  rU  rV  rZ  rc  rp  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  r  r  r   r   r   r   <module>   s  
'

#
#
I
I?

!
!!









8




$

	

	











,
"
q
 



7