o
    h^                     @   s   d dl Z d dlZd dlZd dlmZmZ ejdej	ej
fdd Zejdg dg dg d	g d
f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S )    N)arbitrary_elementgraphs_equalprefix_tree_fnc                    s  g d}| | d\}} fdd}t  | |d\}}}t | dks'J t | }t | dks7J t | dksAJ t  | |d\}}	t | dksUJ t |	 dks_J t  |	 |d\}}
t | dkssJ t |
 dks}J t |
 }t | dksJ t  | |d\}}t | dksJ t | }t | dksJ t  | |d\}}}t | dksJ t | dksJ t | dksJ t | }t | dksJ t | }t | dksJ t | }t | dksJ ||d u sJ ||d	ksJ ||d
ks&J ||dks/J ||	dks8J ||
dksAJ ||dksJJ ||dksSJ ||d	ks\J ||dkseJ ||dksnJ ||dkswJ d S )Natoteatedteniininn)r   c                    s    j |  d S )Nsource)nodes)vT X/var/www/vscode/kcb/lib/python3.10/site-packages/networkx/generators/tests/test_trees.pysource_label   s   z,test_basic_prefix_tree.<locals>.source_label)key   r      r   r   tnoedNIL)sortedlenr   )r   stringsrootr   r   r   r   r   nilin_r   ter   r   r	   r
   r   r   r   test_basic_prefix_tree	   sV   r'   r"   r   )ababsad)r(   r)   r*    )distantdisparagingr,   diamondrubyc                 C   s   t t| t| sJ dS )zBEnsure results are consistent between prefix_tree implementations.N)r   nxprefix_treeprefix_tree_recursive)r"   r   r   r   test_implementations_consistentI   s   r3   c                  C   sn   t ddD ]/} tj| dd}tj| dd}tjj||sJ t|s&J d|jv s-J d|jvs4J qd S Nr   
   *   seedr#   roots)ranger0   random_labeled_rooted_treeutilsmiscr   is_treegraph)r   t1t2r   r   r   test_random_labeled_rooted_treeW   s   rB   c                  C   z   t tj tjddd} W d   n1 sw   Y  t tj tjddd} W d   dS 1 s6w   Y  dS zETests if n = 0 then the NetworkXPointlessConcept exception is raised.r     r7   N)pytestraisesr0   NetworkXPointlessConceptrandom_labeled_treer;   r   r   r   r   test_random_labeled_tree_n_zeroa      "rJ   c                  C   s   t ddD ]:} tj| dd}tj| dd}tjj||sJ t|D ]}t||s0J q$d|j	vs8J d|j	v s?J qd S r4   )
r:   r0   random_labeled_rooted_forestr<   r=   r   connected_componentsr>   subgraphr?   )r   r@   rA   cr   r   r   !test_random_labeled_rooted_foresti   s   rP   c                  C   8   t jddd} t| dksJ t| jd dksJ dS )z*Tests generation of empty labeled forests.r   rE   r7   r9   N)r0   rL   r!   r?   Fr   r   r   (test_random_labeled_rooted_forest_n_zerot      rT   c                  C   s   t ddD ]/} tj| dd}tj| dd}tjj||sJ t|s&J d|jv s-J d|jvs4J qtjdddd	}t	d tjddtd	}t dD ]+} tjj||  ||  s^J t||  sgJ d||  jv spJ d||  jvsyJ qNd S )
Nr   r5   r6   r7   r#   r9      +   number_of_treesr8   )
r:   r0   random_unlabeled_rooted_treer<   r=   r   r>   r?   randomr8   r   r@   rA   r   sr   r   r   !test_random_unlabeled_rooted_tree{       
r^   c                  C   rC   rD   )rF   rG   r0   rH   random_unlabeled_treerZ   r   r   r   r   !test_random_unlabeled_tree_n_zero   rK   ra   c                  C   s  t t tjdddd W d    n1 sw   Y  tddD ]N} td| d D ]D}tj| |dd}tj| |dd}tjj||sGJ t	|D ]}t
||sXJ t||ks`J qLd|jvshJ d|jv soJ q+q"tjddd	d
}td	 tjddtd
}tdD ]8} tjj||  ||  sJ t	||  D ]}t
||  |sJ qd||  jvsJ d||  jv sJ qd S )Nr5   r   r6   )qr8   r   r#   r9   rV   rW   )number_of_forestsr8   )rF   rG   
ValueErrorr0   random_unlabeled_rooted_forestr:   r<   r=   r   rM   r>   rN   r!   r?   r[   r8   )r   rb   r@   rA   rO   r   r]   r   r   r   #test_random_unlabeled_rooted_forest   s0   	
rf   c                  C   rQ   )z,Tests generation of empty unlabeled forests.r   rE   r7   r9   N)r0   re   r!   r?   rR   r   r   r   #test_random_unlabeled_forest_n_zero   rU   rg   c                  C   s   t ddD ]/} tj| dd}tj| dd}tjj||sJ t|s&J d|jvs-J d|jvs4J qtjdddd}t	d tjddtd}t dD ]+} tjj||  ||  s^J t||  sgJ d||  jvspJ d||  jvsyJ qNd S )	Nr   r5   r6   r7   r#   r9   rW   rX   )
r:   r0   r`   r<   r=   r   r>   r?   r[   r8   r\   r   r   r   test_random_unlabeled_tree   r_   rh   )r[   rF   networkxr0   networkx.utilsr   r   markparametrizer1   r2   r'   r3   rB   rJ   rP   rT   r^   ra   rf   rg   rh   r   r   r   r   <module>   s0    
?
	
