o
    թZh                     @   s   d Z ddlZddlZddlZddlmZmZmZm	Z	m
Z
 ddlmZ ddlmZmZmZmZmZmZmZmZmZmZ edZejdd ZG dd	 d	ZG d
d dZG dd dZdS )z Test cases for .hist method     N)	DataFrameIndexSeries
date_rangeto_datetime)
_check_ax_scales_check_axes_shape_check_colors_check_legend_labels_check_patches_all_filled_check_plot_works_check_text_labels_check_ticks_props
get_x_axis
get_y_axisZ
matplotlibc                   C   s$   t tjdtjdtddddddS )N   dtypez
2020-01-01B)Zperiodsfreqtsindexname)r   npZarangeZfloat64r    r   r   ]/var/www/html/lang_env/lib/python3.10/site-packages/pandas/tests/plotting/test_hist_method.pyr      s
   r   c                   @   s  e Zd Zejdi ddiddigdd Zejdi dd	igd
d Zdd Zdd Z	dd Z
dd Zdd Zdd Zdd Zejjejdg dg dg dg dg dg d g d!gd"d# Zd$d% Zd&d' Zd(d) Zd*d+ Zejd,g d-d.d/ Zejd0d1d2gd3d4 Zejd5d6d7gd8d9 Zd:d; Zd<d= Zd>d? Zejjd@dAdBdC ZdDdE ZdFdG Zejjd@dAdHdI ZdJdK Z dLdM Z!d6S )NTestSeriesPlotskwargsgridFfigsize   
   c                 C   s   t |jfi | d S N)r   histselfr   r   r   r   r   test_hist_legacy_kwargs)   s   z'TestSeriesPlots.test_hist_legacy_kwargsbins   c                 C   sN   t jtdd t|jfd|jji| W d    d S 1 s w   Y  d S )NFZcheck_stacklevelby)tmassert_produces_warningUserWarningr   r%   r   monthr&   r   r   r   test_hist_legacy_kwargs_warning-   s   "z/TestSeriesPlots.test_hist_legacy_kwargs_warningc                 C   s&   t jdd\}}t|j|dd d S )N   T)axdefault_axesmplpyplotsubplotsr   r%   r'   r   figr3   r   r   r   test_hist_legacy_ax3      z#TestSeriesPlots.test_hist_legacy_axc                 C   s(   t jdd\}}t|j||dd d S )Nr2   T)r3   figurer4   r5   r9   r   r   r   test_hist_legacy_ax_and_fig7   s   z+TestSeriesPlots.test_hist_legacy_ax_and_figc                 C   s&   t jdd\}}t|j|dd d S )Nr2   T)r=   r4   r5   )r'   r   r:   _r   r   r   test_hist_legacy_fig;   r<   z$TestSeriesPlots.test_hist_legacy_figc                 C   s>   t jdd\}\}}t|j||dd t|j||dd d S )Nr2      T)r=   r3   r4   r5   )r'   r   r:   ax1ax2r   r   r   test_hist_legacy_multi_ax?   s   z)TestSeriesPlots.test_hist_legacy_multi_axc                 C   sZ   t jdd\}}d}tjt|d |j|j|d W d    d S 1 s&w   Y  d S )Nr2   z`Cannot pass 'figure' when using the 'by' argument, since a new 'Figure' instance will be createdmatch)r,   r=   )r6   r7   r8   pytestraises
ValueErrorr%   r   )r'   r   r:   r?   msgr   r   r   test_hist_legacy_by_fig_errorD   s   "z-TestSeriesPlots.test_hist_legacy_by_fig_errorc                 C   s@   t tjdd}|jddd d }t|jdksJ d S )NrA   r#   rA   )r)   r   )r   r   randomdefault_rngstandard_normalr%   lenpatches)r'   dfr3   r   r   r   test_hist_bins_legacyM   s   z%TestSeriesPlots.test_hist_bins_legacyc                 C   s   |}d}t jt|d |jjdd W d    n1 sw   Y  t jt|d |jjddgd W d    d S 1 s>w   Y  d S )Nz7The 'layout' keyword is not supported when 'by' is NonerE   r2   r2   layoutr2   )rG   rH   rI   heightr%   )r'   hist_dfrR   rJ   r   r   r   test_hist_layoutR   s   "z TestSeriesPlots.test_hist_layoutz by, layout, axes_num, res_layout)genderrA   r2   rA   r[   )rZ      rA   )r]   r2   )category   r2   ra   r`   )r_   rA   r^   ra   rA   rA   )r_   r\   ra   )r]   rA   )r_   r^   ra   ra   r2   ra   )	classroomrc   r]   rc   c                 C   s\   |}t jtdd t|jjt|||d}W d    n1 s w   Y  t|||d d S )NFr+   r,   rV   axes_numrV   )r-   r.   r/   r   rW   r%   getattrr   )r'   rX   r,   rV   ri   Z
res_layoutrR   axesr   r   r   test_hist_layout_with_by[   s
   z(TestSeriesPlots.test_hist_layout_with_byc                 C   s,   |}|j j|jddd}t|dddd d S )Nra   rA   )      )r,   rV   r    ra   ri   rV   r    )rW   r%   r_   r   r'   rX   rR   rk   r   r   r   test_hist_layout_with_by_shaper   s   z.TestSeriesPlots.test_hist_layout_with_by_shapec                 C   s|   ddl m}m} ttjdd}ttjdd}|d |  |d |  | }|j	}t
|dks<J d S )Nr   )gcfsubplotrA   y   z   )Zmatplotlib.pyplotrs   rt   r   r   rM   rN   rO   r%   rk   rP   )r'   rs   rt   xyr:   rk   r   r   r   test_hist_no_overlapx   s   z$TestSeriesPlots.test_hist_no_overlapc                 C   s.   |}|j j|jd ttj dksJ d S )Nr,   r2   )rW   r%   rZ   rP   r6   r7   get_fignums)r'   rX   rR   r   r   r   test_hist_by_no_extra_plots   s   z+TestSeriesPlots.test_hist_by_no_extra_plotsc                 C   sh   ddl m} | }| }|d}d}tjt|d |j||d W d    d S 1 s-w   Y  d S )Nr   )r=   o   z&passed axis not bound to passed figurerE   )r3   r=   )Zpylabr=   Zadd_subplotrG   rH   AssertionErrorr%   )r'   r   r=   Zfig1Zfig2rB   rJ   r   r   r   +test_plot_fails_when_ax_differs_from_figure   s   
"z;TestSeriesPlots.test_plot_fails_when_ax_differs_from_figurehisttype, expected)barT)Z
barstackedT)stepF)Z
stepfilledTc                 C   s4   t tjddd}|j|d}t||d d S )NrA   r2   r#   histtypeZfilled)r   r   rM   rN   integersr%   r   )r'   r   expectedserr3   r   r   r   test_histtype_argument   s   z&TestSeriesPlots.test_histtype_argumentz&by, expected_axes_num, expected_layout)Nr2   rT   )brA   )r2   rA   c                 C   sf   ddg ddg  }t tjdd|dd}d|j_t|jd	d	|d
}t	|||d t
|d d S )N   12rA   r   ar   r   T)r4   legendr,   rh   )r   r   rM   rN   rO   r   r   r   r%   r   r
   )r'   r,   expected_axes_numexpected_layoutr   srk   r   r   r   test_hist_with_legend   s   z%TestSeriesPlots.test_hist_with_legendr,   Nr   c                 C   s|   ddg ddg  }t tjdd|dd}d|j_tjt	d	d
 |j
d|dd W d    d S 1 s7w   Y  d S )Nr   r   r   rA   r   r   r   r    Cannot use both legend and labelrE   Tc)r   r,   label)r   r   rM   rN   rO   r   r   rG   rH   rI   r%   )r'   r,   r   r   r   r   r   test_hist_with_legend_raises   s   "z,TestSeriesPlots.test_hist_with_legend_raisesc                 C   sD   t j \}}|jjd|d}t|jdksJ t|j	 d d S )Nr*   r)   r3   	Frequency)
r6   r7   r8   plotr%   rP   rQ   r   yaxis	get_labelr'   r   r?   r3   r   r   r   test_hist_kwargs   s   z TestSeriesPlots.test_hist_kwargsc                 C   sB   t j \}}|jjd|d}|jjd|d}t|j d d S )Nr*   r   
horizontal)Zorientationr3   r   )r6   r7   r8   r   r%   r   Zxaxisr   r   r   r   r   test_hist_kwargs_horizontal   s   z+TestSeriesPlots.test_hist_kwargs_horizontalc                 C   s4   t j \}}|jjd|d}|jjdd|d}d S )Nr*   r   leftT)alignZstackedr3   )r6   r7   r8   r   r%   r   r   r   r   test_hist_kwargs_align   s   z&TestSeriesPlots.test_hist_kwargs_alignzApi changed in 3.6.0)reasonc                 C   p   t d tj \}}|jjd|d}t|dd | }t	|dgt
|  | }t	|dgt
|  d S NscipyT)logyr3   logr    )rG   importorskipr6   r7   r8   r   r%   r   get_xticklabelsr   rP   get_yticklabelsr'   r   r?   r3   ZxlabelsZylabelsr   r   r   test_hist_kde   s   
zTestSeriesPlots.test_hist_kdec                 C      t d t|jj d S Nr   )rG   r   r   r   kder'   r   r   r   r   test_hist_kde_plot_works      
z(TestSeriesPlots.test_hist_kde_plot_worksc                 C   r   r   )rG   r   r   r   densityr   r   r   r   test_hist_kde_density_works   r   z+TestSeriesPlots.test_hist_kde_density_worksc                 C   r   r   )rG   r   r6   r7   r8   r   r   r   r   r   rP   r   r   r   r   r   test_hist_kde_logy   s   
z"TestSeriesPlots.test_hist_kde_logyc                 C   sb   t d tj \}}|jjddd|d}t|dd t|j	dks%J t
|j	dgd d d S )	Nr   Tr#   r   )r   r)   colorr3   r   r   )Z
facecolors)rG   r   r6   r7   r8   r   r%   r   rP   rQ   r	   r   r   r   r   test_hist_kde_color_bins   s   
z(TestSeriesPlots.test_hist_kde_color_binsc                 C   s^   t d tj \}}|jjdd|d}t|dd | }t	|dks'J t
|dg d S )Nr   Tr)r   r   r3   r   r   r2   )rG   r   r6   r7   r8   r   r   r   	get_linesrP   r	   )r'   r   r?   r3   linesr   r   r   test_hist_kde_color   s   
z#TestSeriesPlots.test_hist_kde_color)"__name__
__module____qualname__rG   markparametrizer(   r1   r;   r>   r@   rD   rK   rS   rY   slowrl   rr   ry   r|   r   r   r   r   r   r   r   Zxfailr   r   r   r   r   r   r   r   r   r   r   (   sf    

		


	

	


r   c                   @   s  e Zd Zejjdd Zejjdd Zejjdd Zejjdd Z	ejjej
d	d
d
dddiddigdd Zejjdd Zejjdd Zejjdd Zejjdd Zdd Zej
dddddddd d dd!d!dd"d"dd#d!dd$d dd%ddd&ddf	d'd( Zd)d* Zd+d, Zd-d. Zej
d/dg d0fg d1g d1fgd2d3 Zej
d4g d5d6d7 Zej
d8dd9gej
d:dd;gd<d= Zej
d8dd9gej
d:dd;gd>d? Zd@dA ZdBdC ZdDdE ZdFdG ZdHdI ZdJdK ZdLdM ZdS )NTestDataFramePlotsc                 C   s>   t jtdd t|j W d    d S 1 sw   Y  d S )NFr+   )r-   r.   r/   r   r%   )r'   rX   r   r   r   test_hist_df_legacy  s   "z&TestDataFramePlots.test_hist_df_legacyc                 C   s   t tjdd}ttjdjdddtjd|d< tj	t
dd t|jdd	}W d    n1 s6w   Y  t|d
dd |d  rJJ t|dg j d S )NrA   rL        j+2Z     ReZr#   sizer   Fr+   )r   r]   rc   rh   rT   )r   r   rM   rN   rO   r   r   int64r-   r.   r/   r   r%   r   get_visibler'   rR   rk   r   r   r   test_hist_df_legacy_layout  s   z-TestDataFramePlots.test_hist_df_legacy_layoutc                 C   s$   t tjdd}t|j d S )NrA   r#   r2   )r   r   rM   rN   rO   r   r%   r'   rR   r   r   r   test_hist_df_legacy_layout2  s   z.TestDataFramePlots.test_hist_df_legacy_layout2c                 C   s   t tjdd}ttjdjdddtjd|d< tj	t
dd	 t|jd
d}W d    n1 s6w   Y  t|dd
d d S )NrA   r#   r*   r   r   r#   r   r*   Fr+   rm   rU      rh   )r   r   rM   rN   rO   r   r   r   r-   r.   r/   r   r%   r   r   r   r   r   test_hist_df_legacy_layout3  s   z.TestDataFramePlots.test_hist_df_legacy_layout3r   T)sharexshareyr    r!   r)   r*   c                 C   s   t tjdd}ttjdjdddtjd|d< tj	t
dd	 t|jfi | W d    d S 1 s9w   Y  d S )
NrA   r   r   r   r#   r   r*   Fr+   )r   r   rM   rN   rO   r   r   r   r-   r.   r/   r   r%   )r'   r   rR   r   r   r   !test_hist_df_legacy_layout_kwargs.  s   "z4TestDataFramePlots.test_hist_df_legacy_layout_kwargsc                 C   sD   |t d}d\}}d\}}|j||||d}t|||||d d S )Nr#         r   (   
xlabelsizexrot
ylabelsizeyrot)ranger%   r   )r'   Zframe_or_seriesobjxfyfr   r   rk   r   r   r   (test_hist_df_legacy_layout_labelsize_rotB  s
   z;TestDataFramePlots.test_hist_df_legacy_layout_labelsize_rotc                    sV   ddl m  ttd}|jdddd} fdd| D }t|d	  d
 d S )Nr   	Rectangler#   Tra   )
cumulativer)   r   c                       g | ]	}t | r|qS r   
isinstance.0rw   r   r   r   
<listcomp>R      zETestDataFramePlots.test_hist_df_legacy_rectangles.<locals>.<listcomp>r^         ?)	matplotlib.patchesr   r   r   r%   get_childrenr-   assert_almost_equal
get_height)r'   r   r3   rectsr   r   r   test_hist_df_legacy_rectanglesK  s
   z1TestDataFramePlots.test_hist_df_legacy_rectanglesc                 C   s(   t td}|jdd}t|dd d S )Nr#   T)r   r   r   )r   r   r%   r   )r'   r   r3   r   r   r   test_hist_df_legacy_scaleU  s   z,TestDataFramePlots.test_hist_df_legacy_scalec                 C   sH   t td}tt |jdd W d    d S 1 sw   Y  d S )Nr#   r   )foo)r   r   r-   external_error_raisedAttributeErrorr%   )r'   r   r   r   r   "test_hist_df_legacy_external_error\  s   "z5TestDataFramePlots.test_hist_df_legacy_external_errorc                 C   s   t tjddtjddddttjdjdddtjdttjdjdddtjdddd	}|t}d
}t	j
t|d |  W d    d S 1 sUw   Y  d S )NrA   r#   r   l     p/ l    @spc/ r   T)utc)r   r   r   dzDhist method requires numerical or datetime columns, nothing to plot.rE   )r   r   rM   rN   r   r   r   ZastypeobjectrG   rH   rI   r%   )r'   rR   Zdf_orJ   r   r   r   *test_hist_non_numerical_or_datetime_raisesc  s*   



"z=TestDataFramePlots.test_hist_non_numerical_or_datetime_raiseslayout_testNrc   )rV   expected_sizer`   re   )r]   r]   rd   )ra   r^   )r^   rA   rb   c                 C   sd   t tjdd}ttjdjdddtjd|d< |j|d d}|d	 }t	|d
|d d S )NrA   rL   r   r   r#   r   rV   rU   r  r]   rh   )
r   r   rM   rN   rO   r   r   r   r%   r   )r'   r  rR   rk   r   r   r   r   rY   |  s   z#TestDataFramePlots.test_hist_layoutc                 C   s   t tjdd}ttjdjdddtjd|d< d}tj	t
|d |jd	d
 W d    n1 s7w   Y  td}tj	t
|d |jdd
 W d    n1 sYw   Y  d}tj	t
|d |jdd
 W d    d S 1 syw   Y  d S )NrA   rL   r   r   r#   r   z1Layout of 1x1 must be larger than required size 3rE   rT   rU   z)Layout must be a tuple of (rows, columns))r2   1At least one dimension of layout must be positiver^   r^   )r   r   rM   rN   rO   r   r   r   rG   rH   rI   r%   reescape)r'   rR   rJ   r   r   r   test_hist_layout_error  s*   	
"z)TestDataFramePlots.test_hist_layout_errorc                 C   sV   t tjdd}ttjdjdddtjd|d< t|j	dd t
j  d S )	NrA   d   rA   r   r   r  r   T)r4   )r   r   rM   rN   rO   r   r   r   r   r%   r6   r7   Ztight_layoutr   r   r   r   test_tight_layout  s   	z$TestDataFramePlots.test_tight_layoutc                 C   s<   t g dg dd}t|jdddddd	}t|dd
 d S )Ng      ?      ?g333333??r]   )pigrabbitr  r  r  )lengthanimalTr  r  r*   r   )r4   columnr,   r)   r   r   )r   r   r%   r   r   r   r   r   test_hist_subplot_xrot  s   z)TestDataFramePlots.test_hist_subplot_xrotzcolumn, expectedwidthr  rW   )r  r  rW   c                    s\   t g dg dg ddg dd}t|jd|dd	  fd
dtdD }||ks,J d S )N)ffffff?皙?g333333?r  g?r  )r]   r  g333333@rA   r2   r  )r  r  duckchickenhorse)r   Tr2   r]   )r4   r  rV   c                    s   g | ]
} d |f   qS )r   )Z	get_title)r   irk   r   r   r         zGTestDataFramePlots.test_hist_column_order_unchanged.<locals>.<listcomp>r]   )r   r   r%   r   )r'   r  r   rR   resultr   r   r    test_hist_column_order_unchanged  s   

z3TestDataFramePlots.test_hist_column_order_unchangedr   r   c                 C   s@   t tjdjddddddgd}|j|d	}t||d
 d S )NrA   r2   r#   r
  r   r   r   columnsr   r   r   r   rM   rN   r   r%   r   r'   r   r   rR   r3   r   r   r   r     s
   z)TestDataFramePlots.test_histtype_argumentr,   r   r  r   c                 C   s   |d u r
|d ur
dnd}d|f}|pddg}|d ur|gd }t ddg ddg  dd	}ttjdd
|ddgd}t|jdd||d}t|||d |d u rZ|d u rZ|d }t	||D ]	\}	}
t
|
|	 q_d S )Nr2   rA   r   r   r   r   r   r   r   r   rA   r   r&  T)r4   r   r,   r  rh   r   )r   r   r   rM   rN   rO   r   r%   r   zipr
   )r'   r,   r  r   r   Zexpected_labelsr   rR   rk   Zexpected_labelr3   r   r   r   r     s0   
z(TestDataFramePlots.test_hist_with_legendc                 C   s   t ddg ddg  dd}ttjdd|dd	gd
}tjtdd |j	d||dd W d    d S 1 s:w   Y  d S )Nr   r   r   r   r)  rA   r*  r   r   r+  r   rE   Tr   )r   r,   r  r   )
r   r   r   rM   rN   rO   rG   rH   rI   r%   )r'   r,   r  r   rR   r   r   r   r     s   "z/TestDataFramePlots.test_hist_with_legend_raisesc                 C   sJ   t tjdd}tj \}}|jj	d|d}t
|jdks#J d S )NrA   rL   r*   r   r#   r   r   rM   rN   rO   r6   r7   r8   r   r%   rP   rQ   r'   rR   r?   r3   r   r   r   test_hist_df_kwargs-  s   z&TestDataFramePlots.test_hist_df_kwargsc                 C   sb   t tjddg dd}ddgd |d< tj \}}|jj	d|d	}t
|jd
ks/J d S )NrA   r#   ra   Ar   CDr%  rw   rx   r*   Er   r   r-  r.  r   r   r   test_hist_df_with_nonnumerics3  s   z0TestDataFramePlots.test_hist_df_with_nonnumericsc                 C   s`   t tjddg dd}ddgd |d< tj \}}|jj	|d	}t
|jd
ks.J d S )NrA   r0  r1  r%  rw   rx   r*   r5  )r3   r   r-  r.  r   r   r   %test_hist_df_with_nonnumerics_no_bins>  s   z8TestDataFramePlots.test_hist_df_with_nonnumerics_no_binsc                 C   s   t tjddtdd}tj \}}|d j	j
d|d}|d j	j
|ddd	 t|dd
gd |  s;J |j  sDJ d S )NrA   r   ra   abcdr%  r   T)r   r3   r   r3   r   secondary_y	b (right)labels)r   r   rM   rN   rO   listr6   r7   r8   r   r%   r
   	get_yaxisr   Zright_axr.  r   r   r   test_hist_secondary_legendI  s   z-TestDataFramePlots.test_hist_secondary_legendc                 C   s   t tjddtdd}tj \}}|d j	j
dd|d}|d j	j
|ddd	 t|jd
dgd |j  r>J |  sFJ d S )NrA   r8  r9  r%  r   Tr   r;  r3   r   r:  	a (right)r<  r=  r   r   rM   rN   rO   r?  r6   r7   r8   r   r%   r
   Zleft_axr@  r   r.  r   r   r   test_hist_secondary_secondaryY  s   z0TestDataFramePlots.test_hist_secondary_secondaryc                 C   s   t tjddtdd}tj \}}|d j	j
dd|d}|d j	j
|dd	 t|jd
dgd |j  s=J |  sEJ d S )NrA   r8  r9  r%  r   TrB  r   )r3   r   rC  r=  rD  r.  r   r   r   test_hist_secondary_primaryh  s   z.TestDataFramePlots.test_hist_secondary_primaryc                    s  t d ttjddgdtjtjgg dgtdd}tg d}tg d	g dgtdd}tg d
g dg}tj	 \}}|j
j||d  fdd| D }dd |D }tj	 \}}	|j
j|	|d  fdd|	 D }
dd |
D }tdd t||D sJ tddgddgg}d}t jt|d tj	 \}}|j
j||d W d    d S 1 sw   Y  d S )Nzmatplotlib.patchesr  333333?皙?)r  g?r  abcr%  )      ?rG  ?)rH  r  rG  )rG  rJ  rJ  )rK  rK  rK  )r3   weightsc                       g | ]
}t | jr|qS r   r   r   r   Zmpl_patchesr   r   r     r!  zFTestDataFramePlots.test_hist_with_nans_and_weights.<locals>.<listcomp>c                 S      g | ]}|  qS r   r   r   rectr   r   r   r         c                    rM  r   rN  r   rO  r   r   r     s
    c                 S   rP  r   rQ  rR  r   r   r   r     rT  c                 s   s    | ]	\}}||kV  qd S r$   r   )r   Zh0Zh1r   r   r   	<genexpr>  s    zETestDataFramePlots.test_hist_with_nans_and_weights.<locals>.<genexpr>rJ  rK  z?weights must have the same shape as data, or be a single columnrE   )rG   r   r   r   nanr?  arrayr6   r7   r8   r   r%   r   allr,  rH   rI   )r'   rR   rL  Z	no_nan_dfZno_nan_weightsr?   Zax0r   ZheightsrB   Zno_nan_rectsZno_nan_heightsZidxerror_weightsrJ   rC   r   rO  r   test_hist_with_nans_and_weightsx  s2   

"z2TestDataFramePlots.test_hist_with_nans_and_weights) r   r   r   rG   r   r   r   r   r   r   r   r   r   r   r   r   r  rY   r	  r  r  r#  r   r   r   r/  r6  r7  rA  rE  rF  rY  r   r   r   r   r      s    





	





	r   c                   @   sj  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
ejjejdg dg dg dgdd Zejjdd Zejjejdg dg dg dgdd Zejjejdi d d!d"gd#d$ Zejjejd%d&d'd(d)d'gd*g d+id,d!ggd-d. Zd/d0 Zd1d2 Zd3d4 Zd5d6 Zd7d8 Zd9d: Zejd;g d<d=d> Zd?S )@TestDataFrameGroupByPlotsc                 C   s   ddl m} tjd}t|ddgd}t|jdddtj	d	|d
< |ddd|d< dgd |d< ||j
|jd}t|ddd d S )Nr   _grouped_histr#   r   r2  r%  r   r   r   r   ra   r3  Xr4  rz   rc   rh   ) pandas.plotting._matplotlib.histr\  r   rM   rN   r   rO   r   r   r   r2  r3  r   r'   r\  rsrR   rk   r   r   r   test_grouped_hist_legacy  s   z2TestDataFrameGroupByPlots.test_grouped_hist_legacyc                 C   s|   t jd}t|ddgd}t|jdddt jd|d< |d	d
d|d< dgd |d< |j|j	d}t
|d
dd d S )Nr#   r   r2  r%  r   r   r   r   r   ra   r3  r]  r4  rz   rc   rh   )r   rM   rN   r   rO   r   r   r   r%   r3  r   r'   r`  rR   rk   r   r   r   *test_grouped_hist_legacy_axes_shape_no_col  s   zDTestDataFrameGroupByPlots.test_grouped_hist_legacy_axes_shape_no_colc                 C   s   t jd}t|ddgd}t|jdddt jd|d	< |d
dd|d< dgd |d< |jddd}t	|ddd t
|dd d S )NrA   r   r2  r%  r   r   r#   r   r   r   ra   r3  r]  r4  r   )r,   Zrotr2   rT   rh   r  )r   rM   rN   r   rO   r   r   r   r%   r   r   rb  r   r   r   #test_grouped_hist_legacy_single_key  s   z=TestDataFrameGroupByPlots.test_grouped_hist_legacy_single_keyc                    s   ddl m  ddlm} tjd}t|ddgd}t	|j
dd	d
tjd|d< |
ddd
|d< d\}}d\}}||j|jdd||||dd	}| D ]}	 fdd|	 D }
|
d  }t|d qNt|||||d d S )Nr   r   r[  rA   r   r2  r%  r   r   r#   r   r   ra   r3  r   r   T)r,   r   r)   r   r   r   r   r   c                    r   r   r   r   r   r   r   r     r   zZTestDataFrameGroupByPlots.test_grouped_hist_legacy_grouped_hist_kwargs.<locals>.<listcomp>r^   r   r   )r   r   r^  r\  r   rM   rN   r   rO   r   r   r   r2  r3  Zravelr   r   r-   r   r   )r'   r\  r`  rR   r   r   r   r   rk   r3   r   rW   r   r   r   ,test_grouped_hist_legacy_grouped_hist_kwargs  s>   zFTestDataFrameGroupByPlots.test_grouped_hist_legacy_grouped_hist_kwargsc                 C   s   ddl m} tjd}t|ddgd}t|jddd	tj	d
|d< |ddd	|d< dgd	 |d< ||j
|jdd}t|dd d S )Nr   r[  rA   r   r2  r%  r   r   r#   r   r   ra   r3  r]  r4  T)r,   r   r   r   )r^  r\  r   rM   rN   r   rO   r   r   r   r2  r3  r   r_  r   r   r   %test_grouped_hist_legacy_grouped_hist  s   z?TestDataFrameGroupByPlots.test_grouped_hist_legacy_grouped_histc                 C   s   ddl m} tjd}t|ddgd}t|jddd	tj	d
|d< |ddd	|d< dgd	 |d< t
t ||j|jdd W d    d S 1 sNw   Y  d S )Nr   r[  rA   r   r2  r%  r   r   r#   r   r   ra   r3  r]  r4  r   )r,   r   )r^  r\  r   rM   rN   r   rO   r   r   r   r-   r   r   r2  r3  )r'   r\  r`  rR   r   r   r   %test_grouped_hist_legacy_external_err  s    "z?TestDataFrameGroupByPlots.test_grouped_hist_legacy_external_errc                 C   s   t jd}t|ddgd}t|jdddt jd|d	< |d
dd|d< dgd |d< d}tj	t
|d |jddd W d    d S 1 sJw   Y  d S )NrA   r   r2  r%  r   r   r#   r   r   r   ra   r3  r]  r4  z$Specify figure size by tuple insteadrE   default)r,   r    )r   rM   rN   r   rO   r   r   r   rG   rH   rI   r%   )r'   r`  rR   rJ   r   r   r   $test_grouped_hist_legacy_figsize_err  s    "z>TestDataFrameGroupByPlots.test_grouped_hist_legacy_figsize_errc                 C   s   d}t tjdjdd|d}t tjdjdd|d}tjdjddg|d}t|||d	}|d
}| }t	|dksDJ t	t
j dksOJ d S )Nr#   rA      r   r$  <   r   r2   )rW   weightrZ   rZ   )r   r   rM   rN   normalchoicer   groupbyr%   rP   r6   r7   r{   )r'   nrl  rW   Z
gender_intZdf_intgbrk   r   r   r   test_grouped_hist_legacy2*  s   
z3TestDataFrameGroupByPlots.test_grouped_hist_legacy2zmsg, plot_col, by_col, layout)z1Layout of 1x1 must be larger than required size 2rl  rZ   rT   )z1Layout of 1x3 must be larger than required size 4rW   r_   r  )r  rW   r_   r  c                 C   sN   |}t jt|d |j|t|||d W d    d S 1 s w   Y  d S )NrE   r  r,   rV   )rG   rH   rI   r%   rj   )r'   rX   rJ   Zplot_colZby_colrV   rR   r   r   r   test_grouped_hist_layout_error5  s   "z8TestDataFrameGroupByPlots.test_grouped_hist_layout_errorc                 C   sX   |}t jtdd t|jd|jdd}W d    n1 sw   Y  t|ddd d S )NFr+   rW   r[   rs  rA   rh   )r-   r.   r/   r   r%   rZ   r   rq   r   r   r    test_grouped_hist_layout_warningR  s   z:TestDataFrameGroupByPlots.test_grouped_hist_layout_warningzlayout, check_layout, figsize)r`   r`   N))r^   r2   r`   N)rm   rm   )rn   r"   c                 C   s,   |}|j d|j||d}t|d||d d S )NrW   )r  r,   rV   r    ra   rp   )r%   r_   r   )r'   rX   rV   Zcheck_layoutr    rR   rk   r   r   r    test_grouped_hist_layout_figsize[  s   z:TestDataFrameGroupByPlots.test_grouped_hist_layout_figsizer   rW   rc   )r  rV   c                 C   sZ   |}t jtdd t|jfddi|}W d    n1 sw   Y  t|ddd d S )NFr+   r,   rf   r]   rc   rh   )r-   r.   r/   r   r%   r   )r'   rX   r   rR   rk   r   r   r   #test_grouped_hist_layout_by_warninge  s
   z=TestDataFrameGroupByPlots.test_grouped_hist_layout_by_warningzkwargs, axes_num, layoutrZ   )r]   r*   rg   rA   r  rW   rl  r_   r]   c                 C   s&   |}|j di |}t|||d d S )Nrh   r   )r%   r   )r'   rX   r   ri   rV   rR   rk   r   r   r   test_grouped_hist_layout_axesn  s   	z7TestDataFrameGroupByPlots.test_grouped_hist_layout_axesc                 C   s`   |}t jdd\}}|jg d|d d}t|ddd t||d  |d j|u s.J d S )NrA   r]   rx  r   r  r3   r  rh   r6   r7   r8   r%   r   r-   Zassert_numpy_array_equalr=   r'   rX   rR   r:   rk   returnedr   r   r   test_grouped_hist_multiple_axes{  s   z9TestDataFrameGroupByPlots.test_grouped_hist_multiple_axesc                 C   s\   |}t jdd\}}|jd|d d}t|ddd t||d  |d j|u s,J d S )	NrA   r]   rf   r2   )r,   r3   r  rh   r   r{  r|  r   r   r   'test_grouped_hist_multiple_axes_no_cols  s   zATestDataFrameGroupByPlots.test_grouped_hist_multiple_axes_no_colsc                 C   s\   |}t jdd\}}d}tjt|d |jd|d}W d    d S 1 s'w   Y  d S )NrA   r]   z@The number of passed axes must be 1, the same as the output plotrE   rW   rz  )r6   r7   r8   rG   rH   rI   r%   )r'   rX   rR   r:   rk   rJ   r   r   r   %test_grouped_hist_multiple_axes_error  s   "z?TestDataFrameGroupByPlots.test_grouped_hist_multiple_axes_errorc                 C   n   |}|j d|jdd\}}t|||sJ t|||s!J t|||r+J t|||r5J d S )NrW   T)r  r,   r   r%   rZ   r   joinedr   r'   rX   rR   rB   rC   r   r   r   test_axis_share_x  s   z+TestDataFrameGroupByPlots.test_axis_share_xc                 C   r  )NrW   T)r  r,   r   )r%   rZ   r   r  r   r  r   r   r   test_axis_share_y  s   z+TestDataFrameGroupByPlots.test_axis_share_yc                 C   sp   |}|j d|jddd\}}t|||sJ t|||s"J t|||s,J t|||s6J d S )NrW   T)r  r,   r   r   r  r  r   r   r   test_axis_share_xy  s   z,TestDataFrameGroupByPlots.test_axis_share_xyr   r   c                 C   sB   t tjdjddddddgd}|jd|d	}t||d
 d S )NrA   r2   r#   rL   r$  r   r   r%  )r,   r   r   r'  r(  r   r   r   r     s
   z0TestDataFrameGroupByPlots.test_histtype_argumentN)r   r   r   ra  rc  rd  re  rf  rg  ri  rr  rG   r   r   r   rt  ru  rv  rw  ry  r~  r  r  r  r  r  r   r   r   r   r   rZ    s`    &


		rZ  ) __doc__r  numpyr   rG   Zpandasr   r   r   r   r   Zpandas._testingZ_testingr-   Zpandas.tests.plotting.commonr   r   r	   r
   r   r   r   r   r   r   r   r6   Zfixturer   r   r   rZ  r   r   r   r   <module>   s"    0

 Y   