HOME


Mini Shell 1.0
Redirecting to https://devs.lapieza.net/iniciar-sesion Redirecting to https://devs.lapieza.net/iniciar-sesion.
DIR: /proc/self/root/lib/python3.11/test/libregrtest/__pycache__/
Upload File :
Current File : //proc/self/root/lib/python3.11/test/libregrtest/__pycache__/runtest_mp.cpython-311.pyc
�

*�KgcF��Z�ddlZddlZddlZddlZddlZddlZddlZddlZddlZddl	Z	ddl
Z
ddlmZm
Z
mZmZmZddlmZddlmZddlmZddlmZddlmZmZmZmZmZmZm Z ddl!m"Z"dd	l#m$Z$m%Z%ej&d
krddl'Z'dZ(e(e ksJ�dZ)e)e(ksJ�dZ*e+ed
��oe+ed��Z,dedede-fd�Z.de/ee0ffd�Z1de0dededej2fd�Z3dede0de
fd�Z4Gd�d��Z5Gd�de��Z6e0Z7e/ede6fe/ede7fzZ8Gd�d e9��Z:Gd!�d"ej;��Z<d#e=e<de=e<fd$�Z>Gd%�d&��Z?d'eddfd(�Z@Gd)�d*ejA��ZBd+eCe0efdeeCe0efzfd,�ZDdeEeFefd-�ZGdS).�N)�
NamedTuple�NoReturn�Literal�Any�TextIO)�support)�	os_helper)�	Namespace)�Regrtest)�runtest�	is_failed�
TestResult�Interrupted�Timeout�
ChildError�PROGRESS_MIN_TIME)�setup_tests)�format_duration�
print_warning�win32g>@g�r@�setsid�killpg�result�ns�returnc�f�t|t��rdS|jrt||��rdSdS)NTF)�
isinstancer�failfastr
)rrs  �2/usr/lib/python3.11/test/libregrtest/runtest_mp.py�	must_stopr ,s>���&�+�&�&���t�	�{��y���,�,���t��5�c�P�tj|��\}}tdi|��}||fS)N�)�json�loadsr
)�worker_args�ns_dict�	test_namers    r�parse_worker_argsr)4s3����K�0�0��G�Y�	�	�	�W�	�	�B��	�?�r!�testname�	stdout_fhc�^�t|��}||f}tj|��}|j�|j}n
tjg}g|�t
j���d�d�d�d�|�}t||dtj
dktj���}trd|d<tj|fi|��S)	Nz-uz-mz
test.regrtestz
--worker-argsT�nt)�stdout�stderr�text�	close_fds�cwd�start_new_session)�varsr$�dumps�python�sys�
executabler�args_from_interpreter_flags�dict�os�namer	�SAVEDCWD�USE_PROCESS_GROUP�
subprocess�Popen)r*rr+r'r&r8�cmd�kws        r�run_test_in_subprocessrC:s����2�h�h�G��H�%�K��*�[�)�)�K�	�y���Y�
�
��n�%�
�)�J�)��<�>�>�)��)��)� �)��)�(�)�C�
���
��7�d�?���

�
�
�B��'�"&������C�&�&�2�&�&�&r!r(c���t|��t||��}t��ttj|t
���d���t
jd��dS)N)�clsT��flushr)rr�printr$r5�EncodeTestResultr7�exit)rr(rs   r�run_tests_workerrKWs[����O�O�O�
�R��
#�
#�F�	�G�G�G�
�$�*�V�!1�
2�
2�
2�$�?�?�?�?��H�Q�K�K�K�K�Kr!c�*�eZdZdZd�Zd�Zd�Zd�ZdS)�MultiprocessIteratorz8A thread-safe iterator over tests for multiprocess mode.c�D�tj��|_||_dS�N)�	threading�Lock�lock�
tests_iter)�selfrSs  r�__init__zMultiprocessIterator.__init__hs���N�$�$��	�$����r!c��|SrOr#�rTs r�__iter__zMultiprocessIterator.__iter__ls���r!c��|j5|j�t�t|j��cddd��S#1swxYwYdSrO)rRrS�
StopIteration�nextrWs r�__next__zMultiprocessIterator.__next__os���
�Y�	)�	)���&�#�#����(�(�	)�	)�	)�	)�	)�	)�	)�	)�	)�	)�	)�	)����	)�	)�	)�	)�	)�	)s�"7�;�;c�T�|j5d|_ddd��dS#1swxYwYdSrO)rRrSrWs r�stopzMultiprocessIterator.stopusu��
�Y�	#�	#�"�D�O�	#�	#�	#�	#�	#�	#�	#�	#�	#�	#�	#�	#����	#�	#�	#�	#�	#�	#s��!�!N)�__name__�
__module__�__qualname__�__doc__rUrXr\r^r#r!rrMrMdsV������B�B�%�%�%����)�)�)�#�#�#�#�#r!rMc�.�eZdZUeed<eed<eed<dS)�MultiprocessResultrr.�	error_msgN)r_r`rar�__annotations__�strr#r!rrdrdzs.������������K�K�K��N�N�N�N�Nr!rdFTc��eZdZdS)�
ExitThreadN)r_r`rar#r!rriri�s�������Dr!ric���eZdZdeddddf�fd�Zdefd�Zdd�Zdd	�Z		dde	dede
fd
�Zdededefd�Z
dede
fd�Zdd�Zdd�Zdeddfd�Z�xZS)�TestWorkerProcess�	worker_id�runner�MultiprocessTestRunnerrNc���t�����||_|j|_|j|_|j|_|j|_|j|_d|_	d|_
d|_d|_d|_
dS)NF)�superrUrl�pending�outputr�worker_timeout�timeout�regrtest�current_test_name�
start_time�_popen�_killed�_stopped)rTrlrm�	__class__s   �rrUzTestWorkerProcess.__init__�sv���
��������"����~����m����)����,������
�!%��������������
�
�
r!c��d|j��g}|���r|�d��n|�d��|j}|r|�d|����|j}|�Otj��|jz
}|�d|jj	��dt|����f��dd�|��zS)	NzTestWorkerProcess #�running�stoppedztest=zpid=ztime=z<%s>� )rl�is_alive�appendrvrx�time�	monotonicrw�extend�pidr�join)rT�info�test�popen�dts     r�__repr__zTestWorkerProcess.__repr__�s���6�d�n�6�6�7���=�=�?�?�	#��K�K�	�"�"�"�"��K�K�	�"�"�"��%���	(��K�K�����'�'�'��������!�!�D�O�3�B��K�K�1����1�1�6���!4�!4�6�6�8�
9�
9�
9��������&�&r!c��|j}|�dS|jrdSd|_tr|�d�}n|�}td|��tjd���	tr&t
j|jtj
��dS|���dS#t$rYdSt$r }td|�d|����Yd}~dSd}~wwxYw)NTz process groupzKill )�filerGzFailed to kill z: )rxryr>rHr7r/r;rr��signal�SIGKILL�kill�ProcessLookupError�OSErrorr)rTr��what�excs    r�_killzTestWorkerProcess._kill�s
������=��F��<�	��F�����	��*�*�*�D�D��9�D�
�n�d�n�n�3�:�T�:�:�:�:�	=� �
��	�%�)�V�^�4�4�4�4�4��
�
�������!�	�	�	�
�D�D��	=�	=�	=��;�D�;�;�C�;�;�<�<�<�<�<�<�<�<�<�����	=���s$�+B�9B�
C�	C�%C�Cc�<�d|_|���dS)NT)rzr�rWs rr^zTestWorkerProcess.stop�s����
��
�
�����r!��test_resultr.c�d�tj��|jz
|_t	|||��SrO)r�r�rw�duration_secrd)rTr�r.�err_msgs    r�mp_result_errorz!TestWorkerProcess.mp_result_error�s-��$(�>�#3�#3�d�o�#E�� �!�+�v�w�?�?�?r!r(r+c���tj��|_||_	t	||j|��}d|_||_n
#d|_�xYw	|jr|�	��t�	|�|j���}|�J�||�
��d|_d|_S#tj$r'|jrt�|�	��d}Ynt $r|jrt��wxYwn#|�	���xYw	|�
��d|_d|_dS#|�
��d|_d|_wxYw)NF�rt)r�r�rwrvrCrryrxrzr�ri�waitrt�_wait_completedr?�TimeoutExpiredr�)rTr(r+r��retcodes     r�_run_processzTestWorkerProcess._run_process�s����.�*�*���!*���	�*�9�d�g�y�I�I�E� �D�L��D�K�K��	�%)�D�"�����'	*��}�
!��
�
���� � �
��*�*�T�\�*�:�:���*�*�*��2
� � �"�"�"��D�K�%)�D�"�"��5�,�

�

�

��=�%�%�$��
�
���������
�
�
��=�%�%�$��
����	��	��J�J�L�L�L������
� � �"�"�"��D�K�%)�D�"�"�"��
� � �"�"�"��D�K�%)�D�"�)�)�)�)sG�$A�
A�"D�7 B:�:3D�-D�/D�D�E�D#�#E�$E/c��tjdkrtj��}ntjj}t
jd|���5}|�||��}|�	d��|�
�����}ddd��n#1swxYwY|�#|�t|��|��Sd}|dkrd|z}nk|�d��\}}}|���}|sd}n9	t!j|t$���}n#t&$r}	d	|	z}Yd}	~	nd}	~	wwxYw|�$|�t)|��||��St+|||��S)
Nrzw+)�encodingrzExit code %s�
zFailed to parse worker stdout)�object_hookzFailed to parse worker JSON: %s)r7�platform�locale�getencodingr.r��tempfile�
TemporaryFiler��seek�read�stripr�r�
rpartition�rstripr$r%�decode_test_result�	Exceptionrrd)
rTr(r�r+r�r.r��_rr�s
          r�_runtestzTestWorkerProcess._runtests����<�7�"�"��)�+�+�H�H��z�*�H��
#�D�8�
<�
<�
<�	.�	��'�'�	�9�=�=�G��N�N�1�����^�^�%�%�+�+�-�-�F�
	.�	.�	.�	.�	.�	.�	.�	.�	.�	.�	.����	.�	.�	.�	.��?��'�'��	�(:�(:�F�C�C�C����a�<�<�$�w�.�G�G� &� 1� 1�$� 7� 7��F�A�v��]�]�_�_�F��
F�9���F�!�Z��<N�O�O�O�F�F�� �F�F�F�?�#�E�G�G�G�G�G�G�����F�������'�'�
�9�(=�(=�v�w�O�O�O�!�&�&�'�:�:�:s+�AB*�*B.�1B.�D7�7
E�E�Ec��|js�		t|j��}n#t$rYdSwxYw|�|��}|j�d|f��t|j|j	��rdSnJ#t$rYdSt$r1|j�dtj
��f��YdSwxYw|j��dSdS)NFT)rzr[rqrZr�rr�putr rrri�
BaseException�	traceback�
format_exc)rTr(�	mp_results   r�runzTestWorkerProcess.run1s���-�	�
�� $�T�\� 2� 2�I�I��$�����E�E�����!�M�M�)�4�4�	������	� 2�3�3�3��Y�-�t�w�7�7���E����
�
�
���� �
�
�
������y�';�'=�'=� >�?�?�?����
�����-�	�	�	�	�	s.��A>�
-�A>�-�AA>�>
C�6C�Cc	���|j}	|�t��dS#tjt
f$r5}t
d|�dtt���d|����Yd}~dSd}~wwxYw)NzFailed to wait for z completion (timeout=z): )rxr��JOIN_TIMEOUTr?r�r�rr)rTr�r�s   rr�z!TestWorkerProcess._wait_completedDs������	&��J�J�|�$�$�$�$�$���)�7�3�	&�	&�	&��%��%�%�&5�l�&C�&C�%�%� �%�%�
&�
&�
&�
&�
&�
&�
&�
&�
&�����	&���s�%�A0�*A+�+A0rwc�@�	|�d��|���sdStj��|z
}|j�d|�dt
|������|tkr$td|�dt
|������dS��)NTg�?zWaiting for z thread for zFailed to join z in )	r�r�r�r�ru�logrr�r)rTrwr�s   r�wait_stoppedzTestWorkerProcess.wait_stoppedNs���
	��I�I�c�N�N�N��=�=�?�?�
�����!�!�J�.�B��M���;�T�;�;�%4�R�%8�%8�;�;�
<�
<�
<��L� � ��O��O�O�/�"�:M�:M�O�O�P�P�P���
	r!�rN)r�N)r_r`ra�intrUrgr�r�r^rrdr�rr�r�r�r��floatr��
__classcell__�r{s@rrkrk�ss��������#��/G��D�������'�#�'�'�'�'� =�=�=�=�8������	@�@��@��@�

�@�@�@�@�4*�c�4*�f�4*��4*�4*�4*�4*�l';�#�';�*<�';�';�';�';�R����&&�&�&�&��u����������r!rk�workersc���g}|D]\}|j}|s�tj��|jz
}|tkr*|�dt|���d�}|�|���]|S)Nz (�))rvr�r�rwrrr�)r�r}�workerrvr�r0s      r�get_runningr�fs����G��!�!��"�4�� �	��
�^�
�
�� 1�
1��
�"�"�"� 1� 1� 1�?�2�3F�3F�3F�3F�G�D��N�N�4� � � ���Nr!c�h�eZdZdeddfd�Zd
d�Zd
d�Zdedzfd�Zde	ddfd	�Z
d
edefd�Zd
d�Z
dS)rnrurNc�N�||_|jj|_|j|_tj��|_t
|jj��|_|jj	�0t|jj	dz|jj	dz��|_nd|_d|_dS)Ng�?i,)
rur�r�queue�QueuerrrM�testsrqrt�minrsr�)rTrus  rrUzMultiprocessTestRunner.__init__ts��� ��
��=�$����+���05��
�
���+�D�M�,?�@�@����7�?�&�#&�d�g�o��&;�&*�g�o��&>�#@�#@�D���#'�D������r!c�|���fd�td�jjdz��D���_dt	�j���d�}�jjr5|dt
�jj���dt
�j���d�z
}��|���jD]}|�	���dS)Nc�0��g|]}t|�����Sr#)rk)�.0�indexrTs  �r�
<listcomp>z8MultiprocessTestRunner.start_workers.<locals>.<listcomp>�s9���C�C�C�!�*�%��6�6�C�C�Cr!�zRun tests in parallel using z child processesz (timeout: z, worker timeout: r�)
�ranger�use_mpr��lenrtrrsr��start)rT�msgr�s`  r�
start_workersz$MultiprocessTestRunner.start_workers�s����C�C�C�C�%*�1�d�g�n�q�.@�%A�%A�C�C�C���P�S���->�->�P�P�P���7�?�	>��C�&�t�w��7�7�7�7�&�t�':�;�;�;�;�=�
>�C�	
����
�
�
��l�	�	�F��L�L�N�N�N�N�	�	r!c��tj��}|jD]}|����|jD]}|�|���dSrO)r�r�r�r^r�)rTrwr�s   r�stop_workersz#MultiprocessTestRunner.stop_workers�sa���^�%�%�
��l�	�	�F��K�K�M�M�M�M��l�	,�	,�F����
�+�+�+�+�	,�	,r!c�>�|jjdu}t}td�|jD����r�|rtjtd���	|j�	|���S#tj$rYnwxYwt|j��}|r7|jj
s+|�dd�|��z��td�|jD������	|j�	d���S#tj$rYdSwxYw)Nc3�>K�|]}|���V��dSrO)r�)r�r�s  r�	<genexpr>z5MultiprocessTestRunner._get_result.<locals>.<genexpr>�s,����?�?��&�/�/�#�#�?�?�?�?�?�?r!T)rJr�zrunning: %s�, r)rrt�PROGRESS_UPDATE�anyr��faulthandler�dump_traceback_later�MAIN_PROCESS_TIMEOUTrr�getr��Emptyr��pgor�r�)rT�use_faulthandlerrtr}s    r�_get_resultz"MultiprocessTestRunner._get_result�sG�� �G�O�4�7��!���?�?�$�,�?�?�?�?�?�	=��
=��1�2F�7;�=�=�=�=�
��{���w��7�7�7���;�
�
�
���
����"�$�,�/�/�G��
=�t�w�{�
=��������7�);�);�;�<�<�<��?�?�$�,�?�?�?�?�?�	=�"	��;�?�?�1�?�-�-�-���{�	�	�	��4�4�	���s$�A-�-A?�>A?�.D	�	D�Dr�c��|j}t|��}|j�|d|jzz
}n6|jtkr&|jjs|dt|j��zz
}t|j	��}|r'|jjs|dd�
|��zz
}|j�|j
|��dS)Nz (%s)z -- running: %sr�)rrgrer�rrr�rr�r�r�ru�display_progress�
test_index)rTr�rr0r}s     r�display_resultz%MultiprocessTestRunner.display_result�s����!���6�{�{����*��G�i�1�1�1�D�D��!�%6�6�6�t�w�{�6��G�o�f�.A�B�B�B�B�D��d�l�+�+���	;�4�7�;�	;��%��	�	�'�(:�(:�:�:�D��
�&�&�t���=�=�=�=�=r!�itemc�X�|dr|d}td|����dS|xjdz
c_|d}|j�|j��|�|��|jrt|jd���t|j|j	��rdSdS)z&Returns True if test runner must stop.rr�zregrtest worker thread failed: TrFF)
rr�ru�accumulate_resultrr�r.rHr r)rTr�r�r�s    r�_process_resultz&MultiprocessTestRunner._process_result�s�����7�	��a��J��H�J�H�H�I�I�I��4����1������G�	��
�'�'�	�(8�9�9�9����I�&�&�&���	0��)�"�$�/�/�/�/��Y�%�t�w�/�/�	��4��ur!c�0�|���d|_		|���}|�n|�|��}|rn�0n*#t$rt��d|j_YnwxYw|jj	�tj��|j�
��|���dS#|jj	�tj��|j�
��|���wxYw)NrT)r�r�r�r��KeyboardInterruptrHru�interruptedrrtr��cancel_dump_traceback_laterrqr^r�)rTr�r^s   r�	run_testsz MultiprocessTestRunner.run_tests�s+�����������	 �
��'�'�)�)���<���+�+�D�1�1�����
���!�	-�	-�	-��G�G�G�(,�D�M�%�%�%�	-�����w��*��8�:�:�:�
�L���������������
�w��*��8�:�:�:�
�L���������������s*�1A�C�$A6�3C�5A6�6C�ADr�)r_r`rarrUr�r��QueueOutputr�rdr��boolr�r�r#r!rrnrnss����������d����� 
�
�
�
�,�,�,�,��[�4�/�����8>�(:�>�t�>�>�>�>��K��D�����* � � � � � r!rnruc�H�t|�����dSrO)rnr�)rus r�run_tests_multiprocessr��s"���8�$�$�.�.�0�0�0�0�0r!c�<��eZdZdZdedeeeff�fd�Z�xZS)rIz7Encode a TestResult (sub)class object into a JSON dict.�orc���t|t��r t|��}|jj|d<|St���|��S)N�__test_result__)rrr4r{r_rp�default)rTrrr{s   �rrzEncodeTestResult.default�sK����a��$�$�	��!�W�W�F�()��(<�F�$�%��M��w�w���q�!�!�!r!)	r_r`rarbrr:rgrr�r�s@rrIrI�sY�������A�A�"��"��c�3�h��"�"�"�"�"�"�"�"�"�"r!rI�dc��d|vr|S|�d��}t��D]}|j|kr
|di|��cS�dS)z7Decode a TestResult (sub)class object from a JSON dict.rNr#)�pop�get_all_test_result_classesr_)r�cls_namerEs   rr�r�sl����!�!����u�u�&�'�'�H�*�,�,�����<�8�#�#��3�8�8��8�8�O�O�O�$��r!c�
�d}th}t|��|kret|��}g}|D])}|�|������*|�|��t|��|k�e|S)Nr)rr�r��__subclasses__�update)�
prev_count�classes�to_addrEs    rrrs����J��l�G�

�g�,�,��
#�
#���\�\�
����	0�	0�C��M�M�#�,�,�.�.�/�/�/�/����v�����g�,�,��
#�
#��Nr!)Hr�r$r;r�r�r?r7r�rPr�r��typingrrrrrr�r�test.supportr	�test.libregrtest.cmdliner
�test.libregrtest.mainr�test.libregrtest.runtestrr
rrrrr�test.libregrtest.setupr�test.libregrtest.utilsrrr�r�r�r�r��hasattrr>r�r �tuplergr)r@rCrKrMrd�ExcStrr�r�ri�Threadrk�listr�rnr��JSONEncoderrIr:r��set�typerr#r!r�<module>rs�����������	�	�	�	�����
�
�
�
�����
�
�
�
�����������������=�=�=�=�=�=�=�=�=�=�=�=�=�=�������"�"�"�"�"�"�.�.�.�.�.�.�*�*�*�*�*�*�Y�Y�Y�Y�Y�Y�Y�Y�Y�Y�Y�Y�Y�Y�Y�Y�Y�Y�.�.�.�.�.�.�A�A�A�A�A�A�A�A��<�7����M�M�M����+�+�+�+�+�
 ����.�.�.�.����W�R��*�*�D�w�w�r�8�/D�/D���j��i��D������e�I�s�N�&;�����'�S�'�i�'�F�'�z�O_�'�'�'�'�:	��	�s�	�x�	�	�	�	�#�#�#�#�#�#�#�#�,���������

���G�E�N�$6�6�7�%���
�v�@U�:V�V��	�	�	�	�	��	�	�	�Z�Z�Z�Z�Z�	�(�Z�Z�Z�z
��/�0�
�T�:K�5L�
�
�
�
�z �z �z �z �z �z �z �z �z1�X�1�$�1�1�1�1�	"�	"�	"�	"�	"�t�'�	"�	"�	"�	�$�s�C�x�.�	�Z�$�s�C�x�.�-H�	�	�	�	�	�S��j�)9�%:�	�	�	�	�	�	r!