o
    j^                     @   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 e/var/www/html/Deteccion_Ine/venv/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*    )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   r1   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     r5   N)pytestraisesr.   NetworkXPointlessConceptZrandom_labeled_treer9   r   r   r   r   test_random_labeled_tree_n_zeroa      "rG   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 r2   )
r8   r.   random_labeled_rooted_forestr:   r;   r   connected_componentsr<   subgraphr=   )r   r>   r?   cr   r   r   !test_random_labeled_rooted_foresti   s   rM   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   rC   r5   r7   N)r.   rI   r!   r=   Fr   r   r   (test_random_labeled_rooted_forest_n_zerot      rQ   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   r3   r4   r5   r#   r7      +   Znumber_of_treesr6   )
r8   r.   random_unlabeled_rooted_treer:   r;   r   r<   r=   randomr6   r   r>   r?   r   sr   r   r   !test_random_unlabeled_rooted_tree{       
rZ   c                  C   rA   rB   )rD   rE   r.   rF   random_unlabeled_treerV   r   r   r   r   !test_random_unlabeled_tree_n_zero   rH   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 )Nr3   r   r4   )qr6   r   r#   r7   rS   rT   )Znumber_of_forestsr6   )rD   rE   
ValueErrorr.   random_unlabeled_rooted_forestr8   r:   r;   r   rJ   r<   rK   r!   r=   rW   r6   )r   r^   r>   r?   rL   r   rY   r   r   r   #test_random_unlabeled_rooted_forest   s0   	
ra   c                  C   rN   )z,Tests generation of empty unlabeled forests.r   rC   r5   r7   N)r.   r`   r!   r=   rO   r   r   r   #test_random_unlabeled_forest_n_zero   rR   rb   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   r3   r4   r5   r#   r7   rT   rU   )
r8   r.   r\   r:   r;   r   r<   r=   rW   r6   rX   r   r   r   test_random_unlabeled_tree   r[   rc   )rW   rD   Znetworkxr.   Znetworkx.utilsr   r   markZparametrizer/   r0   r'   r1   r@   rG   rM   rQ   rZ   r]   ra   rb   rc   r   r   r   r   <module>   s0    
?
	
