a
    ضaP                     @   s  d dl Z d dlZd dlmZ d dlZd dlZd dlmZ d dlmZm	Z	 d dl
Z
d dlZd dlmZmZ d dlmZ d dlmZ d dlZd dlmZmZmZmZmZmZmZmZm Z m!Z!m"Z"m#Z#m$Z$m%Z% dd Z&d	d
 Z'dd Z(dd Z)dd Z*dddie+dfdddde+dfdddde+dfdddie+dfdddde+dfdddde+dfgZ,g dZ-e
j.j/de,e-ddd Z0dd Z1d d! Z2d"d# Z3d$d% Z4d&d' Z5d(d) Z6e
j./d*e6d+d,d- Z7e
j./d.e6d/d0d1 Z8e
j./d2d3d4e9fd5d6e:d7d7fd8d9e9fd7ge9fgd:d; Z;d<d= Z<d>d? Z=e
j.j>ej?d@kdAdBdCdD Z@e
j.j>ej?d@koteA  dEdBdFdG ZBdS )H    N)Path)mock)cyclerCycler)_api_c_internal_utils)validate_boolvalidate_colorvalidate_colorlist_validate_color_or_linecolorvalidate_cyclervalidate_floatvalidate_fontweightvalidate_hatchvalidate_hist_binsvalidate_intvalidate_markeveryvalidate_stringlist_validate_linestyle_listify_validatorc                 C   s  t jddd t jddd t jd }t jd }t| d	 }|d
 t jd| id$ t jd | ksnJ W d    n1 s0    Y  t jd |ksJ t j|d" t jd dksJ W d    n1 s0    Y  t jd |ksJ t j|ddid$ t jd dksJ W d    n1 s,0    Y  t jd |ksJJ t ddidd }|  |  t | t jd dksJ d S )NtextF)usetexlines   )	linewidthtext.usetexlines.linewidthtest_rcparams.rczlines.linewidth: 33rc)fname!   ,   )r    r   c                   S   s   t jd dksJ d S )Nr   r"   mplrcParams r&   r&   n/Users/vegardjervell/Documents/master/model/venv/lib/python3.9/site-packages/matplotlib/tests/test_rcparams.pyfunc;   s    ztest_rcparams.<locals>.func)r$   r   r%   r   
write_text
rc_contextZrc_file)tmpdirr   r   rcpathr(   r&   r&   r'   test_rcparams!   s*    


204

r-   c                  C   s~   t g ddddd} d }|t| ks0J d }|t| ksHJ dd	gt| d
ksbJ dgt| dkszJ d S )N)zApple ChanceryZTextilezZapf ChanceryZcursivez
sans-serifnormal   )font.cursivefont.familyzfont.weight	font.sizea  
RcParams({'font.cursive': ['Apple Chancery',
                           'Textile',
                           'Zapf Chancery',
                           'cursive'],
          'font.family': ['sans-serif'],
          'font.size': 12.0,
          'font.weight': 'normal'})z
font.cursive: ['Apple Chancery', 'Textile', 'Zapf Chancery', 'cursive']
font.family: ['sans-serif']
font.size: 12.0
font.weight: normalr0   r2   zi[vz]r1   family)r$   RcParamslstripreprstrsortedZfind_alllist)r   Zexpected_reprZexpected_strr&   r&   r'   test_RcParams_classG   s    
	r:   c               	   C   s|   t ddi} ddi}ttH tjtdd | | W d    n1 sP0    Y  W d    n1 sn0    Y  d S )Nfigure.figsize)      @*   r<   r=      validatematch)r$   r4   pytestraises
ValueErrorwarnsUserWarningupdate)r   Zbad_dictr&   r&   r'   test_rcparams_updateh   s    rI   c                	   C   sj   t tL t jtdd tddi W d    n1 s>0    Y  W d    n1 s\0    Y  d S )Nr@   rA   r;   r>   )rC   rD   rE   rF   rG   r$   r4   r&   r&   r&   r'   test_rcparams_initq   s    rJ   c               	   C   s<  t   t 2 tj } | D ]}| | tj|< q"W d    n1 sJ0    Y  t  ttj W d    n1 s~0    Y  W d    n1 s0    Y  tt	 t
d  W d    n1 s0    Y  tt	D t  dtjd< W d    n1 s0    Y  W d    n1 s.0    Y  d S )NTzsvg.fonttype)r   Z'suppress_matplotlib_deprecation_warningr$   r*   r%   copydeepcopyrC   rD   rE   r   )Z_copykeyr&   r&   r'   test_Bug_2543w   s    


.
H&
rN   facecolorrZinherit)rP   zaxes.facecolorgZedge)rP   zaxes.edgecolor)zsame facecolorzinherited facecolordifferent facecolorzsame edgecolorzinherited edgecolorrS   zcolor_type, param_dict, target)idsc                 C   s   | d|d|  d< d|  d}t|L t \}}|jtddd | }t|j	| |ksjJ W d    n1 s~0    Y  d S )NrP   zlegend.get_   test)label)
popr$   r*   pltsubplotsZplotrangeZlegendgetattrZlegendPatch)Z
color_typeZ
param_dicttargetZget_func_axZlegr&   r&   r'   test_legend_colors   s    ra   c                  C   s4   dt jd< t jddgddg} |  dks0J d S )NrQ   zlines.markerfacecolorr?      )r$   r%   r   Line2DZget_markerfacecolorlnr&   r&   r'   test_mfc_rcparams   s    
rf   c                  C   s4   dt jd< t jddgddg} |  dks0J d S )NrQ   zlines.markeredgecolorr?   rb   )r$   r%   r   rc   Zget_markeredgecolorrd   r&   r&   r'   test_mec_rcparams   s    
rg   c                  C   s4   dt jd< t \} }|d}| dks0J d S )NrQ   zaxes.titlecolorZTitle)r$   r%   rZ   r[   	set_titleZ	get_color)r_   r`   titler&   r&   r'   test_axes_titlecolor_rcparams   s    

rj   c                 C   sl   t | d }|jddd tjddd t|dd}W d    n1 sL0    Y  |d	d
kshJ d S )Nr   ztimezone: UTCz	UTF-32-BE)encodingzlocale.getpreferredencoding)Zreturn_valueTFtimezoneUTC)r   r)   r   patchr$   Zrc_params_from_fileget)r+   r,   r   r&   r&   r'   test_Issue_1713   s
    ,rp   c                  C   s   dD ]} | t jd< qd S )N)
ZpngZjpegZtiffrawZrgbappmZsgiZbmpZpbmsvgzanimation.frame_formatr#   )fmtr&   r&   r'   test_animation_frame_formats   s    ru   c              !   c   s  t g dd dD dd dD R dd ddd	g fD d
tdg fdddgfddgfddgfddgfddgddgfdddgftddgddgftddgddgff	t tfdtfdtjftddgtjffd
t	t
dddd dddgddgdtdfD dd dD d
t	tdddd dddgddgdtdfD dd dD d
td td!d"ftd#d$d%gtd#d$d%gfd&td!d"td'g d( fd)td!d"td*g d+ fd,td!d"td#d$d%g ftd-d$d%gtd#d$d%gftdd.gd/td'dd.gffd0tfd1tfd2tfd3tfd4tfd5tfd6tfd7tfd8tfd9tfd:tfd;tfd<tfd=tfd>tftd?g d@tftd!g dAtffd
tdBdCtfdDtfdEtffd
tdFg dGfg dGg dGfdHdIgfg dJdKdLgftg dMtg dNgtg dMg dNgftg dMg dNgtg dMg dNgffdOtffd
tdPdQtfdRtfdStfdTtfdUtffd
tdVdWtfdXtffd
tdYdZd[d\g d+fg d+g d+ftd]td]ffdtffd
td^d_d`dadbg d+g d+ftdtd dd ftdddctdddcffd+tfg ddtfg detfg dftfdgtfdhtfditfdjtfdktfdltfdmtfdntfdotfdptfdltfdtft tffd
tdqdrdsdtdudvdwdxdydzd{d|d}d~ddgdddgffg ddg dffdddgfdddgffd	ddgfd	ddgfffdtfdtfddtfg d+tfdtfdddgftfd ddgftfdg d+ftfddgdftff	d
f}|D ]V}|d }| r||d D ]\}}|||fV  qbn |d D ]\}}|||fV  qqHd S )Nc                 s   s   | ]}|d fV  qdS )TNr&   .0r_   r&   r&   r'   	<genexpr>       z/generate_validator_testcases.<locals>.<genexpr>)tyyesontrue1r?   Tc                 s   s   | ]}|d fV  qdS )FNr&   rv   r&   r&   r'   rx      ry   )fnnoofffalse0r   Fc                 s   s   | ]}|t fV  qd S NrE   rv   r&   r&   r'   rx      s   aardvarkrb   )	validatorsuccessfail za,babz
aardvark, zaardvark, ,)r   r   r?   )r?   rb   )r   c                 s   s   | ]}|d dgfV  qdS )r?   rb   Nr&   rv   r&   r&   r'   rx      s   z1, 2      ?      @c                 s   s   | ]}|t fV  qd S r   r   rv   r&   r&   r'   rx      s   )r   r   r?   r?   rb   rV   c                 s   s   | ]}|d dgfV  qdS )r   r   Nr&   rv   r&   r&   r'   rx      s   z1.5, 2.5)r   r   c                 s   s   | ]}|t fV  qd S r   r   rv   r&   r&   r'   rx      s   )r   r   r   r   Nzcycler("color", "rgb")rP   ZrgbZ	linestyle---zW(cycler("color", ["r", "g", "b"]) +
                          cycler("mew", [2, 3, 5]))Zmarkeredgewidth)rb   rV      zcycler(c='rgb', lw=[1, 2, 3])r   r   z5cycler('c', 'rgb') * cycler('linestyle', ['-', '--'])Zlsr   )Zmew   zcycler("bleh, [])zCycler("linewidth", [1, 2, 3])z1cycler('c', [j.__class__(j) for j in ['r', 'b']])z2cycler('c', [j. __class__(j) for j in ['r', 'b']])z2cycler('c', [j.	__class__(j) for j in ['r', 'b']])z2cycler('c', [j.__class__(j) for j in ['r', 'b']])z9cycler('c', [j.__class__(j).lower() for j in ['r', 'b']])z1 + 2zos.system("echo Gotcha")z	import osz9def badjuju(a): return a; badjuju(cycler("color", "rgb"))zcycler("waka", [1, 2, 3])zcycler(c=[1, 2, 3])zcycler(lw=['a', 'b', 'c'])Zwaka)r?   rV   r   )ZC1rQ   rR   ))--|r   )\oOr   )/+*/.xr   r   r   z--_   Xzr,g,b)rQ   rR   r   zr, ,rQ   )r   rR   bluerR   r   )r?   r   r   r   r?   r   Zfish)
Nonenoner   r   )ZAABBCCz#AABBCC)ZAABBCC00z	#AABBCC00)tab:bluer   )C12r   )z	(0, 1, 0))              ?r   )r   r   )z(0, 1, 0, 1))r   r   r   r   )r   r?   r   r?   r   ztab:verybluez(0, 1)z(0, 1, 0, 1, 0)z(0, 1, none)z(0, 1, "0.5")))	linecolorr   )markerfacecolorr   )Zmfcr   )markeredgecolorr   )Zmecr   linemarker)autor   )fdr   )10
   z1, 2, 3   )NNr?   r?   皙?r   )r   r   )r   r   rV   )r?   rb   333333?)r   rb   rV   )r?   rb   r   )r   皙?r   )r   rb   rV   )r?   r   r   )r?   r   )r   r?   abc)r?   r   )r   r   r   )r   r   )r   r   )solidr   )r   r   )dashedr   )-.r   )dashdotr   ):r   )dottedr   r   ) r   r   r   )ZDoTtEdr   )z1, 3)r   )r?   rV   gGz?i  r   g     |@)r?   rb   rV   r   )r   g       @g      @g      @s   dottedr   zutf-16r   r   r   )r   r   iternparraysetrE   r   ZMatplotlibDeprecationWarningr   r   r   r   r   r   r
   r	   r   r   Zaranger   slice	TypeErrorobjectr   encode)ZvalidZvalidation_testsZvalidator_dictr   argr^   Z
error_typer&   r&   r'   generate_validator_testcases   s   





	

6
	
	



  Vr   zvalidator, arg, targetTc                 C   sT   | |}t |tjr$tj|| n,t |ts<||ksPJ nt|t|ksPJ d S r   )
isinstancer   ZndarrayZtestingZassert_equalr   r9   )r   r   r^   resr&   r&   r'   test_validator_valid  s    
r   zvalidator, arg, exception_typeFc                 C   s6   t | | | W d    n1 s(0    Y  d S r   )rC   rD   )r   r   Zexception_typer&   r&   r'   test_validator_invalid  s    r   zweight, parsed_weight)boldr   ZBOLD)d   r   )Z100r   r   )g4@   z20.6c                 C   sP   |t u r<tt  t|  W d    qL1 s00    Y  nt| |ksLJ d S r   )rE   rC   rD   r   )ZweightZparsed_weightr&   r&   r'   test_validate_fontweight  s    (r   c                  C   s2   dd t jD } | D ]}tt j| tsJ qd S )Nc                 S   s   g | ]}d |v r|qS )Zkeymapr&   )rw   kr&   r&   r'   
<listcomp>  ry   z test_keymaps.<locals>.<listcomp>)r$   r%   r   r9   )Zkey_listr   r&   r&   r'   test_keymaps  s    r   c                
   C   s   t jddid t jd du s$J ttB t jdddd W d    n1 sX0    Y  W d    n1 sv0    Y  t jd du sJ W d    n1 s0    Y  d S )Nr   Fr   T)r   z	test.blah)r$   r*   r%   rC   rD   KeyErrorr&   r&   r&   r'   test_rcparams_reset_after_fail  s    <r   linuxz
Linux only)reasonc                 C   sh   i t jdddt| d}ttj, tjtj	ddg|dtj
d W d    n1 sZ0    Y  d S )Nr   )ZDISPLAYZWAYLAND_DISPLAY
MPLBACKENDMPLCONFIGDIR-czBimport matplotlib;matplotlib.use('tkagg');import matplotlib.pyplotT)envcheckstderr)osenvironr7   rC   rD   
subprocessCalledProcessErrorrunsys
executableDEVNULL)r+   r   r&   r&   r'   test_backend_fallback_headless  s    r   Zheadlessc                 C   sR   t d i tjdt| d}tjtjddg|dd}|	 
 dksNJ d S )	Ntkinterr   )r   r   r   a  import matplotlib as mpl; sentinel = mpl.rcsetup._auto_backend_sentinel; assert mpl.RcParams({'backend': sentinel})['backend'] == sentinel; assert dict.__getitem__(mpl.rcParams, 'backend') == sentinel; import matplotlib.pyplot; print(matplotlib.get_backend())T)r   universal_newlinesZagg)rC   Zimportorskipr   r   r7   r   check_outputr   r   striplower)r+   r   backendr&   r&   r'   test_backend_fallback_headful  s    
r   )CrK   r   pathlibr   r   r   Zunittestr   r   r   rC   Z
matplotlibr$   r   r   Zmatplotlib.pyplotZpyplotrZ   Zmatplotlib.colorscolorsZmcolorsZnumpyr   Zmatplotlib.rcsetupr   r	   r
   r   r   r   r   r   r   r   r   r   r   r   r-   r:   rI   rJ   rN   Zto_rgbaZlegend_color_testsZlegend_color_test_idsmarkZparametrizera   rf   rg   rj   rp   ru   r   r   r   rE   r   r   r   r   Zskipifplatformr   Zdisplay_is_validr   r&   r&   r&   r'   <module>   s   @&!	





	 a



