OwlCyberSecurity - MANAGER
Edit File: util.cpython-38.pyc
U ����e5d_����������������������@���s����d�Z�ddlmZmZ�ddlmZ�dZdZdZdZ dZ dZee e�e�e�e ��Zedks\t �dd ��Zd d��Zdd d�Zdd��Zdd��Zdd��Zdd��Zedd�Zdd��Zdd��ZdS�)zVarious utility functions.�����)� namedtuple�Counter)�commonprefixT�P�����������c�����������������C���sB���t�|��|�|�}|tkr>d|�d�|��||�t�|��|�d���f�}�|�S�)Nz%s[%d chars]%s)�len�_PLACEHOLDER_LEN)�s� prefixlenZ suffixlen�skip��r ����%/usr/lib64/python3.8/unittest/util.py�_shorten���s����&r���c���������������������s����t�tt|���}�ttt|���}|tkr(|�S�t|����t����t|��t�t��}|t kr�tt�t �|���tk�spt �t��t|���t����fdd�|�D���S�t��tt ���t����fdd�|�D���S�)Nc�����������������3���s���|�]}��|�d����V��qd�S��Nr �����.0r �����prefixr���r ���r���� <genexpr>'���s�����z'_common_shorten_repr.<locals>.<genexpr>c�����������������3���s&���|�]}��t�|�d���tt��V��qd�S�r���)r���� _MIN_DIFF_LEN�_MIN_END_LENr���r���r ���r���r���*���s����)�tuple�map� safe_repr�maxr����_MAX_LENGTHr����_MIN_BEGIN_LENr ����_MIN_COMMON_LEN�AssertionErrorr���)�args�maxlenZ common_lenr ���r���r����_common_shorten_repr���s*����� ���r"���Fc�����������������C���sP���zt�|��}W�n�tk r*���t�|��}Y�nX�|r<t|�tk�r@|S�|d�t��d�S�)Nz [truncated]...)�repr� Exception�object�__repr__r���r���)�objZshort�resultr ���r ���r���r���-���s����r���c�����������������C���s���d|�j�|�jf�S�)Nz%s.%s)� __module__�__qualname__)�clsr ���r ���r����strclass6���s����r,���c�����������������C���s��d�}}g�}g�}z�|�|�}||�}||k�rT|��|��|d7�}|�|�|kr�|d7�}q<nv||kr�|��|��|d7�}||�|kr�|d7�}qnnD|d7�}z|�|�|kr�|d7�}q�W�5�|d7�}||�|kr�|d7�}q�X�W�q�tk �r���|�|�|d����|�||d����Y��qY�qX�q||fS�)ar��Finds elements in only one or the other of two, sorted input lists. Returns a two-element tuple of lists. The first list contains those elements in the "expected" list but not in the "actual" list, and the second contains those elements in the "actual" list but not in the "expected" list. Duplicate elements in either input list are ignored. r�������N)�append� IndexError�extend)�expected�actual�i�j�missingZ unexpected�e�ar ���r ���r����sorted_list_difference9���s8���� r8���c�����������������C���sH���g�}|�r@|�����}z|�|��W�q�tk r<���|�|��Y�qX�q||fS�)z�Same behavior as sorted_list_difference but for lists of unorderable items (like dicts). As it does a linear search per item (remove) it has O(n*n) performance.)�pop�remove� ValueErrorr.���)r1���r2���r5����itemr ���r ���r����unorderable_list_differenceb���s����r=���c�����������������C���s���|�|k|�|k��S�)z.Return -1 if x < y, 0 if x == y and 1 if x > yr ���)�x�yr ���r ���r���� three_way_cmps���s����r@���ZMismatchzactual expected valuec�����������������C���s,��t�|��t�|��}}t|�t|��}}t��}g�}t|�D�]�\}} | |krHq6d�} }t||�D�] }||�| krZ| d7�} |||<�qZt|�D�] \}} | | kr�|d7�}|||<�q�| |kr6t| || �}|�|��q6t|�D�]X\}} | |kr�q�d}t||�D�] }||�| kr�|d7�}|||<�q�td|| �}|�|��q�|S�)�HReturns list of (cnt_act, cnt_exp, elem) triples where the counts differr���r-���)�listr���r%���� enumerate�range� _Mismatchr.���)r2���r1���r ����t�m�nZNULLr(���r3����elem�cnt_s�cnt_tr4���Z other_elem�diffr ���r ���r����_count_diff_all_purposey���s<���� rM���c����������� ������C���s����t�|��t�|��}}g�}|���D�]2\}}|�|d�}||krt|||�}|�|��q|���D�]&\}}||krZtd||�}|�|��qZ|S�)rA���r���)r����items�getrE���r.���) r2���r1���r ���rF���r(���rI���rJ���rK���rL���r ���r ���r����_count_diff_hashable����s����rP���N)F)�__doc__�collectionsr���r���Zos.pathr���Z __unittestr���r ���r���r���r���r���r���r���r"���r���r,���r8���r=���r@���rE���rM���rP���r ���r ���r ���r����<module>���s4��� ��� ) #