a
    h/                     @   sZ   d dl Z d dlZd dlmZmZmZ e dZe dZ	G dd dZ
dd Zd	d
 ZdS )    N)edges_equalgraphs_equalnodes_equalnumpyZpandasc                   @   s   e Zd Zdd Zdd Zdd Zdd Zd	d
 Zdd Zdd Z	dd Z
dd Zdd Zdd Zdd Zdd Zdd Zdd Zejdejejgd d! Zd"d# Zd$d% Zd&d' Zd(d) Zd*S )+TestConvertPandasc                 C   s   t jjdd| _| jjdddd}g d}g d}tj|d	d
gd}||d< ||d< || _tjg dgg dd}t||g| _	d S )N   )seed      )      )sizeABC)Dr   Eweightcostcolumnsr   b)      r   r   )r   r   r   r   )
nprandomZRandomStaterngrandintpd	DataFramedfconcatmdf)selfintsar   r!   r#    r'   P/var/www/auris/lib/python3.9/site-packages/networkx/tests/test_convert_pandas.pysetup_method   s    zTestConvertPandas.setup_methodc                 C   sz   t dg}ttjtj| t ddg}ttjtj| t jddgddggtddgddgd}ttjtj| d S )Nr&   g        r	   r   r   r   dtypeindexr   )	r   r    pytestraisesnxNetworkXErrorto_networkx_graphintfrom_pandas_adjacency)r$   Gr!   r'   r'   r(   test_exceptions   s    &z!TestConvertPandas.test_exceptionsc              	   C   s   t dddddfdddd	dfdd
d	ddfg}t | jddd}t||sTJ t |}|jdd
ddd t | jdddt  }t||sJ d S )Nr   r   	   
   r   r   r   r   r	      r   r   r   r   Tr   )r/   Graphfrom_pandas_edgelistr!   r   
MultiGraphadd_edger#   )r$   Gtruer4   ZMGtrueZMGr'   r'   r(   test_from_edgelist_all_attr    s    
z-TestConvertPandas.test_from_edgelist_all_attrc              	   C   s\   t dddddfdddd	dfdd
d	ddfg}t | jddddg}t||sXJ d S )Nr   r   r6   r7   r8   r   r   r	   r9   r   r   r   r   r   r   r/   r:   r;   r!   r   r$   r>   r4   r'   r'   r(   test_from_edgelist_multi_attr0   s    z/TestConvertPandas.test_from_edgelist_multi_attrc              
   C   sb   t ddddddfddddddfddddd	dfg}t | jd
dg d}t||s^J d S )Nr   r   r7   )r   r   r   r   r   r9   r   r   r   r   r@   rA   r'   r'   r(   )test_from_edgelist_multi_attr_incl_target;   s    z;TestConvertPandas.test_from_edgelist_multi_attr_incl_targetc                 C   s2  ddddddfddddddfdddd	d
dfddddddfddddddfddddddfddddddfddddddfddddddfddddd
dfg
}t |}g dg dg dg dg dd}tj|}t j|dddt jd }t j|ddg d!t jd }t||sJ t||s.J d S )"NX1X4zAr   )CoMiStzB6   X21   X3,   Y1Y3zC"   Y2      Z1Z3zD   )
rD   rD   rD   rD   rP   rP   rP   rP   rW   rW   )
rE   rE   rE   rE   rQ   rQ   rQ   rQ   rX   rX   )
rD   rL   rN   rE   rP   rT   rL   rQ   rW   rN   )
rF   rJ   rJ   rJ   rR   rR   rR   rR   rY   rY   )
r   rK   rM   rO   r   rS   rU   rV   r   rZ   )Or   rI   rG   rH   r[   r   T)sourcetarget	edge_attrcreate_using)rI   rG   rH   )r/   ZMultiDiGraphr   r    	from_dictr;   r   )r$   edgesr>   datar!   ZG1ZG2r'   r'   r(   -test_from_edgelist_multidigraph_and_edge_attrF   s>    
z?TestConvertPandas.test_from_edgelist_multidigraph_and_edge_attrc                 C   sR   t ddddifddddifdddd	ifg}t | jd
dd}t||sNJ d S )Nr   r   r   r7   r   r   r9   r   r   r   r   r@   rA   r'   r'   r(   test_from_edgelist_one_attrj   s    z-TestConvertPandas.test_from_edgelist_one_attrc                 C   sR   t ddddifddddifddddifg}t | jddd}t||sNJ d S )Nr   r   r   r   r   r   r   r@   rA   r'   r'   r(    test_from_edgelist_int_attr_nameu   s
    &z2TestConvertPandas.test_from_edgelist_int_attr_namec              	   C   s   t tjtj| jddd t tjtj| jddd tjddgddgddggddgd}t tjtj|ddd	 t tjtj|ddd
 t tjtj|ddd
dg d S )Nr   r   Zmisspellr	   r   str   Tr   r   )r-   r.   r/   r0   r;   r!   r   r    )r$   Z	edgeframer'   r'   r(   test_from_edgelist_invalid_attr}   s&    $z1TestConvertPandas.test_from_edgelist_invalid_attrc                 C   sD   t ddi fddi fddi fg}t | jdd}t||s@J d S )Nr   r   r   r   r   r   r   r@   rA   r'   r'   r(   test_from_edgelist_no_attr   s    "z,TestConvertPandas.test_from_edgelist_no_attrc           	      C   s   t d}|dd t|jD  t |}dd |D }dd |D }dd |D }t|||d}t j|d	d
}t	|
 |
 sJ t| | sJ t j|t jd}t	|
 |
 sJ t| | sJ d S )Nr7   c                 s   s   | ]\}}|||fV  qd S Nr'   .0uvr'   r'   r(   	<genexpr>       z7TestConvertPandas.test_from_edgelist.<locals>.<genexpr>c                 S   s   g | ]\}}}|qS r'   r'   rl   rf   rg   dr'   r'   r(   
<listcomp>   rp   z8TestConvertPandas.test_from_edgelist.<locals>.<listcomp>c                 S   s   g | ]\}}}|qS r'   r'   rq   r'   r'   r(   rs      rp   c                 S   s   g | ]\}}}|d  qS r   r'   rq   r'   r'   r(   rs      rp   )r\   r]   r   r   )r^   r_   )r/   Zcycle_graphadd_weighted_edges_fromlistra   Zto_edgelistr   r    r;   r   nodesr   r1   r:   )	r$   r4   Zedgelistr\   r]   r   ra   ZGGZGWr'   r'   r(   test_from_edgelist   s    

z$TestConvertPandas.test_from_edgelistc                 C   s   t d}|dd t|jD  t j|ddd tt jt j	| |jddD ]\}}}|
dd  qRt j|dd	d tt jt j	| d S )
Nr7   c                 s   s   | ]\}}|||fV  qd S rj   r'   rk   r'   r'   r(   ro      rp   zYTestConvertPandas.test_to_edgelist_default_source_or_target_col_exists.<locals>.<genexpr>r   r\   nameTrb   r]   r/   
path_graphrv   rw   ra   set_edge_attributesr-   r.   r0   to_pandas_edgelistpopr$   r4   rm   rn   rr   r'   r'   r(   4test_to_edgelist_default_source_or_target_col_exists   s    
zFTestConvertPandas.test_to_edgelist_default_source_or_target_col_existsc                 C   s   t d}|dd t|jD  t j|ddd tjt jt j	|dd |jdd	D ]\}}}|
dd  qVt j|dd
d tjt jt j	|d
d d S )Nr7   c                 s   s   | ]\}}|||fV  qd S rj   r'   rk   r'   r'   r(   ro      rp   zXTestConvertPandas.test_to_edgelist_custom_source_or_target_col_exists.<locals>.<genexpr>r   Zsource_col_namerz   )r\   Tr|   Ztarget_col_name)r]   r}   r   r'   r'   r(   3test_to_edgelist_custom_source_or_target_col_exists   s    
zETestConvertPandas.test_to_edgelist_custom_source_or_target_col_existsc                 C   sV   t jdt jd}|dd t| D  t j|ddd tjt j	t j
|dd d S )	Nr7   ru   c                 s   s   | ]\}}|||fV  qd S rj   r'   rk   r'   r'   r(   ro      rp   zITestConvertPandas.test_to_edgelist_edge_key_col_exists.<locals>.<genexpr>r   Zedge_key_namerz   edge_key)r/   r~   r<   rv   rw   ra   r   r-   r.   r0   r   )r$   r4   r'   r'   r(   $test_to_edgelist_edge_key_col_exists   s    z6TestConvertPandas.test_to_edgelist_edge_key_col_existsc                 C   sT   ddg}t jddgddggt||d}tddg}tj|td}t j|| d S )Nr	   r   r   r*   r	   r	   r	   r   r+   )r   r    r2   r/   r:   to_pandas_adjacencytestingassert_frame_equal)r$   nodelistdftruer4   r!   r'   r'   r(   test_from_adjacency   s    z%TestConvertPandas.test_from_adjacencygraphc                 C   s   |ddg}t |}t j||d}t||s2J ddiddiddddiid}||}t j|td}t j||d}t||sJ d S )Nr   r   ru   r   r	   r   )r/   r   r;   r   r   r2   r3   )r$   r   r>   r!   r4   Zadjr'   r'   r(   test_roundtrip   s    
 z TestConvertPandas.test_roundtripc                 C   st   ddddddddddddd}t j|tjd}|g d }tj|t d}tj|tjd}t j	|| d S )Nr   r   r	   r   )r   r   r   ru   )
r   r    r   Zintpr/   r3   ZDiGraphr   r   r   )r$   rb   r   r!   r4   r'   r'   r(   test_from_adjacency_named   s    


z+TestConvertPandas.test_from_adjacency_namedc                 C   s   t 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}tdddd	d
dfdddd
d	dfdddd
d
dfdddd
d	dfg}tj|ddddgdt d}t||sJ tj|dd}|d}g d|_t j	
||g d  d S )NZN1ZN2)r   r   r   r   ZN3ZF1ZF2ZF3ZF4r	   r   )r\   r]   attr1attr2attr3)r   r   r\   r]   r   r   r   )r\   r]   r^   r   r_   r   )r   r    r/   r<   r;   r   r   Zsort_valuesr,   r   r   )r$   r!   r>   r4   Zdf_roundtripr'   r'   r(   test_edgekey_with_multigraph   s<    		

z.TestConvertPandas.test_edgekey_with_multigraphc              	   C   s\   t dddddfdddd	dfdd
d	ddfg}t j| jddddd}t||sXJ d S )Nr   r   r6   r7   r8   r   r   r	   r9   r   r   r   r   Tr   r   r@   rA   r'   r'   r(   (test_edgekey_with_normal_graph_no_action  s    z:TestConvertPandas.test_edgekey_with_normal_graph_no_actionc              	   C   sN   t tjj, tj| jddddt d W d    n1 s@0    Y  d S )Nr\   r]   ZNot_realT)r\   r]   r   r^   r_   )r-   r.   r/   	exceptionr0   r;   r!   r<   )r$   r'   r'   r(   test_nonexisting_edgekey_raises#  s    z1TestConvertPandas.test_nonexisting_edgekey_raisesN)__name__
__module____qualname__r)   r5   r?   rB   rC   rc   rd   re   rh   ri   ry   r   r   r   r   r-   markZparametrizer/   r:   r<   r   r   r   r   r   r'   r'   r'   r(   r   
   s*   $	
$r   c                  C   sN   t d} ddg}tjddgddggt||d}tj|t j| |td d S )Nr   r	   r   r   r*   r   )r/   Zcomplete_graphr   r    r2   r   r   r   )r4   r   expectedr'   r'   r(   &test_to_pandas_adjacency_with_nodelist/  s    
r   c                  C   sh   t  } | jg ddd | jdddd t j| ddgd	}d|d
  vsPJ d|d  vsdJ d S )N))r   r	   r   )r	   r   g       @rt   r   r   d   r	   r   )r   r\   r   )r/   r:   Zadd_edges_fromr=   r   Zto_numpy)r4   r!   r'   r'   r(   %test_to_pandas_edgelist_with_nodelist:  s    r   )r-   Znetworkxr/   Znetworkx.utilsr   r   r   Zimportorskipr   r   r   r   r   r'   r'   r'   r(   <module>   s   

  '