o
    ҷh!                     @   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	 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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_axis
matplotlibc                   C   s   t jddS )Ntsname)tmmakeTimeSeries r   r   Y/var/www/html/venv/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check_stacklevelby)r   assert_produces_warningUserWarningr   r    index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   figr/   r   r   r   test_hist_legacy_ax.      z#TestSeriesPlots.test_hist_legacy_axc                 C   s(   t jdd\}}t|j||dd d S )Nr.   T)r/   figurer0   r1   r5   r   r   r   test_hist_legacy_ax_and_fig2   s   z+TestSeriesPlots.test_hist_legacy_ax_and_figc                 C   s&   t jdd\}}t|j|dd d S )Nr.   T)r9   r0   r1   )r"   r   r6   _r   r   r   test_hist_legacy_fig6   r8   z$TestSeriesPlots.test_hist_legacy_figc                 C   s>   t jdd\}\}}t|j||dd t|j||dd d S )Nr.      T)r9   r/   r0   r1   )r"   r   r6   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 )Nr.   z`Cannot pass 'figure' when using the 'by' argument, since a new 'Figure' instance will be createdmatch)r(   r9   )r2   r3   r4   pytestraises
ValueErrorr    r+   )r"   r   r6   r;   msgr   r   r   test_hist_legacy_by_fig_error?   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 )Nr=   r   r=   )r$   r   )r   nprandomdefault_rngstandard_normalr    lenpatches)r"   dfr/   r   r   r   test_hist_bins_legacyH   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 NonerA   r.   r.   layoutr.   )rC   rD   rE   heightr    )r"   hist_dfrO   rF   r   r   r   test_hist_layoutM   s   "z TestSeriesPlots.test_hist_layoutz by, layout, axes_num, res_layout)genderr=   r.   r=   rX   )rW      r=   )rZ   r.   )category   r.   r^   r]   )r\   r=   r[   r^   r=   r=   )r\   rY   r^   )rZ   r=   )r\   r[   r^   r^   r.   r^   )	classroomr`   rZ   r`   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(   rS   axes_numrS   )r   r)   r*   r   rT   r    getattrr   )r"   rU   r(   rS   rf   
res_layoutrO   axesr   r   r   test_hist_layout_with_byV   s
   z(TestSeriesPlots.test_hist_layout_with_byc                 C   s,   |}|j j|jddd}t|dddd d S )Nr^   r=   )      )r(   rS   r   r^   rf   rS   r   )rT   r    r\   r   r"   rU   rO   ri   r   r   r   test_hist_layout_with_by_shapem   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subplotr=   y   z   )matplotlib.pyplotrq   rr   r   rI   rJ   rK   rL   r    ri   rM   )r"   rq   rr   xyr6   ri   r   r   r   test_hist_no_overlaps   s   z$TestSeriesPlots.test_hist_no_overlapc                 C   s.   |}|j j|jd ttj dksJ d S )Nr(   r.   )rT   r    rW   rM   r2   r3   get_fignums)r"   rU   rO   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   )r9   o   z&passed axis not bound to passed figurerA   )r/   r9   )pylabr9   add_subplotrC   rD   AssertionErrorr    )r"   r   r9   fig1fig2r>   rF   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)
barstackedT)stepF)
stepfilledTc                 C   s4   t tjddd}|j|d}t||d d S )Nr=   r.   r   histtypefilled)r   rI   rJ   rK   integersr    r
   )r"   r   expectedserr/   r   r   r   test_histtype_argument   s   z&TestSeriesPlots.test_histtype_argumentz&by, expected_axes_num, expected_layout)Nr.   rQ   )br=   )r.   r=   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2r=      ar+   r   r   T)r0   legendr(   re   )r   rI   rJ   rK   rL   r+   r   r   r    r   r	   )r"   r(   expected_axes_numexpected_layoutr+   sri   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   r=   r   r   r   r    Cannot use both legend and labelrA   Tc)r   r(   label)r   rI   rJ   rK   rL   r+   r   rC   rD   rE   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$   r/   	Frequency)
r2   r3   r4   plotr    rM   rN   r   yaxis	get_labelr"   r   r;   r/   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)orientationr/   r   )r2   r3   r4   r   r    r   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)alignstackedr/   )r2   r3   r4   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)logyr/   logr    )rC   importorskipr2   r3   r4   r   r    r   get_xticklabelsr   rM   get_yticklabelsr"   r   r;   r/   xlabelsylabelsr   r   r   test_hist_kde   s   
zTestSeriesPlots.test_hist_kdec                 C      t d t|jj d S Nr   )rC   r   r   r   kder"   r   r   r   r   test_hist_kde_plot_works      
z(TestSeriesPlots.test_hist_kde_plot_worksc                 C   r   r   )rC   r   r   r   densityr   r   r   r   test_hist_kde_density_works   r   z+TestSeriesPlots.test_hist_kde_density_worksc                 C   r   r   )rC   r   r2   r3   r4   r   r   r   r   r   rM   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$   colorr/   r   r   )
facecolors)rC   r   r2   r3   r4   r   r    r   rM   rN   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   r/   r   r   r.   )rC   r   r2   r3   r4   r   r   r   	get_linesrM   r   )r"   r   r;   r/   linesr   r   r   test_hist_kde_color   s   
z#TestSeriesPlots.test_hist_kde_color)"__name__
__module____qualname__rC   markparametrizer#   r-   r7   r:   r<   r@   rG   rP   rV   slowrj   rp   rx   r{   r   r   r   r   r   r   r   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"   rU   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 )Nr=   rH        j+2Z     ReZr   sizedtypeFr&   )r   rZ   r`   re   rQ   )r   rI   rJ   rK   rL   r   r   int64r   r)   r*   r   r    r   get_visibler"   rO   ri   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 )Nr=   r   r.   )r   rI   rJ   rK   rL   r   r    r"   rO   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 )Nr=   r   r%   r   r   r   r   r%   Fr&   rk   rR      re   )r   rI   rJ   rK   rL   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 )
Nr=   r   r   r   r   r   r%   Fr&   )r   rI   rJ   rK   rL   r   r   r   r   r)   r*   r   r    )r"   r   rO   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"   frame_or_seriesobjxfyfr   r   ri   r   r   r   (test_hist_df_legacy_layout_labelsize_rot=  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   Tr^   )
cumulativer$   r   c                       g | ]	}t | r|qS r   
isinstance.0rv   r   r   r   
<listcomp>M      zETestDataFramePlots.test_hist_df_legacy_rectangles.<locals>.<listcomp>r[         ?)	matplotlib.patchesr   r   r   r    get_childrenr   assert_almost_equal
get_height)r"   r   r/   rectsr   r   r   test_hist_df_legacy_rectanglesF  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   r/   r   r   r   test_hist_df_legacy_scaleP  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_errorW  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 )Nr=   r   r   l     p/ l    @spc/ )r   T)utc)r   r   r   dzDhist method requires numerical or datetime columns, nothing to plot.rA   )r   rI   rJ   rK   r   r   r   astypeobjectrC   rD   rE   r    )r"   rO   df_orF   r   r   r   *test_hist_non_numerical_or_datetime_raises^  s*   



"z=TestDataFramePlots.test_hist_non_numerical_or_datetime_raiseslayout_testNr`   )rS   expected_sizer]   rb   )rZ   rZ   ra   )r^   r[   )r[   r=   r_   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 )Nr=   rH   r   r   r   r   rS   rR   r  rZ   re   )
r   rI   rJ   rK   rL   r   r   r   r    r   )r"   r  rO   ri   r   r   r   r   rV   w  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 )Nr=   rH   r   r   r   r   z1Layout of 1x1 must be larger than required size 3rA   rQ   rR   z)Layout must be a tuple of (rows, columns))r.   1At least one dimension of layout must be positiver[   r[   )r   rI   rJ   rK   rL   r   r   r   rC   rD   rE   r    reescape)r"   rO   rF   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 )	Nr=   d   r=   r   r   r  r   T)r0   )r   rI   rJ   rK   rL   r   r   r   r   r    r2   r3   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??rZ   )pigrabbitr$  r$  r%  )lengthanimalTr&  r'  r%   r   )r0   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&  rT   )r&  r,  rT   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!  )rZ   r"  g333333@r=   r.   r+  )r$  r%  duckchickenhorse)r+   Tr.   rZ   )r0   r(  rS   c                    s   g | ]
} d |f   qS )r   )	get_title)r  iri   r   r   r        zGTestDataFramePlots.test_hist_column_order_unchanged.<locals>.<listcomp>rZ   )r   r   r    r   )r"   r(  r   rO   resultr   r5  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 )Nr=   r.   r   r  r   r   r   columnsr   r   r   rI   rJ   rK   r   r    r
   r"   r   r   rO   r/   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 )Nr.   r=   r   r   r   r   r   r   r   r   r=   r+   r;  T)r0   r   r(   r(  re   r   )r   r   rI   rJ   rK   rL   r   r    r   zipr	   )r"   r(   r(  r   r   expected_labelsr+   rO   ri   expected_labelr/   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   r=   r>  r   r   r?  r   rA   Tr  )r   r(   r(  r   )
r   r   rI   rJ   rK   rL   rC   rD   rE   r    )r"   r(   r(  r+   rO   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 )Nr=   rH   r%   r   r   r   rI   rJ   rK   rL   r2   r3   r4   r   r    rM   rN   r"   rO   r;   r/   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 )Nr=   r   r^   ABCDr:  rv   rw   r%   Er   r   rC  rD  r   r   r   test_hist_df_with_nonnumerics.  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 )Nr=   rF  rG  r:  rv   rw   r%   rL  )r/   r   rC  rD  r   r   r   %test_hist_df_with_nonnumerics_no_bins9  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 )Nr=   r   r^   abcdr:  r   T)r   r/   r   r/   r   secondary_y	b (right)labels)r   rI   rJ   rK   rL   listr2   r3   r4   r   r    r	   	get_yaxisr   right_axrD  r   r   r   test_hist_secondary_legendD  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 )Nr=   rO  rP  r:  r   Tr   rR  r/   r   rQ  	a (right)rS  rT  r   rI   rJ   rK   rL   rV  r2   r3   r4   r   r    r	   left_axrW  r   rD  r   r   r   test_hist_secondary_secondaryT  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 )Nr=   rO  rP  r:  r   TrZ  r   )r/   r   r[  rT  r\  rD  r   r   r   test_hist_secondary_primaryc  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:  )      ?r`  ?)ra  r.  r`  )r`  rc  rc  )rd  rd  rd  )r/   weightsc                       g | ]
}t | jr|qS r   r   r   r   mpl_patchesr   r   r    r6  zFTestDataFramePlots.test_hist_with_nans_and_weights.<locals>.<listcomp>c                 S      g | ]}|  qS r   r  r  rectr   r   r   r        c                    rf  r   rg  r   rh  r   r   r    s
    c                 S   rj  r   rk  rl  r   r   r   r    rn  c                 s   s    | ]	\}}||kV  qd S r   r   )r  h0h1r   r   r   	<genexpr>  s    zETestDataFramePlots.test_hist_with_nans_and_weights.<locals>.<genexpr>rc  rd  z?weights must have the same shape as data, or be a single columnrA   )rC   r   r   rI   nanrV  arrayr2   r3   r4   r   r    r  allr@  rD   rE   )r"   rO   re  	no_nan_dfno_nan_weightsr;   ax0r	  heightsr>   no_nan_rectsno_nan_heightsidxerror_weightsrF   r?   r   rh  r   test_hist_with_nans_and_weightss  s2   

"z2TestDataFramePlots.test_hist_with_nans_and_weights) r   r   r   rC   r   r   r   r   r   r   r   r   r   r
  r  r  r  rV   r  r   r*  r8  r   r   r   rE  rM  rN  rY  r^  r_  r|  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   rH  r:  r   r   r   rI  r^   rJ  XrK  ry   r`   re   ) pandas.plotting._matplotlib.histr  rI   rJ   rK   r   rL   r   r   r   rH  rJ  r   r"   r  rsrO   ri   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   rH  r:  r   r   r   rI  r   r^   rJ  r  rK  ry   r`   re   )rI   rJ   rK   r   rL   r   r   r   r    rJ  r   r"   r  rO   ri   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 )Nr=   r   rH  r:  r   r   r   r   rI  r   r^   rJ  r  rK  r   )r(   rotr.   rQ   re   r)  )rI   rJ   rK   r   rL   r   r   r   r    r   r   r  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~  r=   r   rH  r:  r   r   r   r   rI  r^   rJ  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  rI   rJ   rK   r   rL   r   r   r   rH  rJ  ravelr  r  r   r  r   )r"   r  r  rO   r   r   r   r   ri   r/   r	  rT   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~  r=   r   rH  r:  r   r   r   r   rI  r^   rJ  r  rK  T)r(   r   r   r   )r  r  rI   rJ   rK   r   rL   r   r   r   rH  rJ  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~  r=   r   rH  r:  r   r   r   r   rI  r^   rJ  r  rK  r   )r(   r  )r  r  rI   rJ   rK   r   rL   r   r   r   r   r  r  rH  rJ  )r"   r  r  rO   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 )Nr=   r   rH  r:  r   r   r   r   rI  r   r^   rJ  r  rK  z$Specify figure size by tuple insteadrA   default)r(   r   )rI   rJ   rK   r   rL   r   r   r   rC   rD   rE   r    )r"   r  rO   rF   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   r=      r   r9  <   r   r.   )rT   weightrW   rW   )r   rI   rJ   rK   normalchoicer   groupbyr    rM   r2   r3   rz   )r"   nr  rT   
gender_intdf_intgbri   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 2r  rW   rQ   )z1Layout of 1x3 must be larger than required size 4rT   r\   r2  )r  rT   r\   r  c                 C   sN   |}t jt|d |j|t|||d W d    d S 1 s w   Y  d S )NrA   r(  r(   rS   )rC   rD   rE   r    rg   )r"   rU   rF   plot_colby_colrS   rO   r   r   r   test_grouped_hist_layout_error0  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&   rT   rX   r  r=   re   )r   r)   r*   r   r    rW   r   ro   r   r   r    test_grouped_hist_layout_warningM  s   z:TestDataFrameGroupByPlots.test_grouped_hist_layout_warningzlayout, check_layout, figsize)r]   r]   N))r[   r.   r]   N)rk   rk   )rl   r   c                 C   s,   |}|j d|j||d}t|d||d d S )NrT   )r(  r(   rS   r   r^   rn   )r    r\   r   )r"   rU   rS   check_layoutr   rO   ri   r   r   r    test_grouped_hist_layout_figsizeV  s   z:TestDataFrameGroupByPlots.test_grouped_hist_layout_figsizer   rT   r`   )r(  rS   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(   rc   rZ   r`   re   )r   r)   r*   r   r    r   )r"   rU   r   rO   ri   r   r   r   #test_grouped_hist_layout_by_warning`  s
   z=TestDataFrameGroupByPlots.test_grouped_hist_layout_by_warningzkwargs, axes_num, layoutrW   )rZ   r%   rd   r=   r(  rT   r  r\   rZ   c                 C   s&   |}|j di |}t|||d d S )Nre   r   )r    r   )r"   rU   r   rf   rS   rO   ri   r   r   r   test_grouped_hist_layout_axesi  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 )Nr=   rZ   r  r   r(  r/   r2  re   r2   r3   r4   r    r   r   assert_numpy_array_equalr9   r"   rU   rO   r6   ri   returnedr   r   r   test_grouped_hist_multiple_axesv  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 )	Nr=   rZ   rc   r.   )r(   r/   r2  re   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 )Nr=   rZ   z@The number of passed axes must be 1, the same as the output plotrA   rT   r  )r2   r3   r4   rC   rD   rE   r    )r"   rU   rO   r6   ri   rF   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 )NrT   T)r(  r(   r   r    rW   r   joinedr   r"   rU   rO   r>   r?   r   r   r   test_axis_share_x  s   z+TestDataFrameGroupByPlots.test_axis_share_xc                 C   r  )NrT   T)r(  r(   r   )r    rW   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 )NrT   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 )Nr=   r.   r   rH   r9  r   r   r:  )r(   r   r   r<  r=  r   r   r   r     s
   z0TestDataFrameGroupByPlots.test_histtype_argumentN)r   r   r   r  r  r  r  r  r  r  r  rC   r   r   r   r  r  r  r  r  r  r  r  r  r  r  r   r   r   r   r   r}    s`    &


		r}  )__doc__r  numpyrI   rC   pandasr   r   r   r   pandas._testing_testingr   pandas.tests.plotting.commonr   r   r   r	   r
   r   r   r   r   r   r   r2   fixturer   r   r   r}  r   r   r   r   <module>   s"    0

 Y   