o
    ]Zh^                     @   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 S/var/www/auris/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   nilZin_r   ter   r   r	   r
   r   r   r   test_basic_prefix_tree	   sV   r&   r"   r   )ababsad)r'   r(   r)    )distantZdisparagingr+   Z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   r0   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)ranger-   random_labeled_rooted_treeutilsmiscr   is_treegraph)r   t1t2r   r   r   test_random_labeled_rooted_treeW   s   r?   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     r4   N)pytestraisesr-   NetworkXPointlessConceptZrandom_labeled_treer8   r   r   r   r   test_random_labeled_tree_n_zeroa      "rF   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 r1   )
r7   r-   random_labeled_rooted_forestr9   r:   r   connected_componentsr;   subgraphr<   )r   r=   r>   cr   r   r   !test_random_labeled_rooted_foresti   s   rL   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   rB   r4   r6   N)r-   rH   r!   r<   Fr   r   r   (test_random_labeled_rooted_forest_n_zerot      rP   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   r2   r3   r4   r#   r6      +   Znumber_of_treesr5   )
r7   r-   random_unlabeled_rooted_treer9   r:   r   r;   r<   randomr5   r   r=   r>   r   sr   r   r   !test_random_unlabeled_rooted_tree{       
rY   c                  C   r@   rA   )rC   rD   r-   rE   random_unlabeled_treerU   r   r   r   r   !test_random_unlabeled_tree_n_zero   rG   r\   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 )Nr2   r   r3   )qr5   r   r#   r6   rR   rS   )Znumber_of_forestsr5   )rC   rD   
ValueErrorr-   random_unlabeled_rooted_forestr7   r9   r:   r   rI   r;   rJ   r!   r<   rV   r5   )r   r]   r=   r>   rK   r   rX   r   r   r   #test_random_unlabeled_rooted_forest   s0   	
r`   c                  C   rM   )z,Tests generation of empty unlabeled forests.r   rB   r4   r6   N)r-   r_   r!   r<   rN   r   r   r   #test_random_unlabeled_forest_n_zero   rQ   ra   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   r2   r3   r4   r#   r6   rS   rT   )
r7   r-   r[   r9   r:   r   r;   r<   rV   r5   rW   r   r   r   test_random_unlabeled_tree   rZ   rb   )rV   rC   Znetworkxr-   Znetworkx.utilsr   r   markZparametrizer.   r/   r&   r0   r?   rF   rL   rP   rY   r\   r`   ra   rb   r   r   r   r   <module>   s0    
?
	
