Server : LiteSpeed
System : Linux server51.dnsbootclub.com 4.18.0-553.62.1.lve.el8.x86_64 #1 SMP Mon Jul 21 17:50:35 UTC 2025 x86_64
User : nandedex ( 1060)
PHP Version : 8.1.33
Disable Function : NONE
Directory :  /opt/cppython/lib/python3.8/test/__pycache__/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]


Current File : //opt/cppython/lib/python3.8/test/__pycache__/test_faulthandler.cpython-38.opt-2.pyc
U

>��g�p�@s2ddlmZddlZddlZddlZddlZddlZddlZddlZddl	m
Z
ddlmZm
Z
ddlZddlZddlmZzddlZWnek
r�dZYnXdZejdkZe�d�p�d	Ze�d
�p�d	Zdekp�dekZd
ekp�dekZddd�Zdd�Zedd��ZGdd�dej�Z e!dk�r.e�"�dS)�)�contextmanagerN)�support)�
script_helper�
is_android)�dedentg�?�ntZCFLAGS�ZCONFIG_ARGSz-fsanitize=undefinedz#--with-undefined-behavior-sanitizerz-fsanitize=memoryz--with-memory-sanitizer�cCsL|}|d|7}|d|7}d|kr<d|d|d|Sd|dSdS)Nz#  File "<string>", line %s in func
z&  File "<string>", line %s in <module>r	�^�
�$�)Zlineno1Zlineno2�header�	min_count�regexr
r
�5/opt/cppython/lib/python3.8/test/test_faulthandler.py�expected_traceback"srcCst�td�|�S)Nz(raising SIGSEGV on Android is unreliable)�unittest�skipIfr)�testr
r
r�skip_segfault_on_android+s
��rc	cs$t��}z
|VW5t�|�XdS�N)�tempfile�mktempr�unlink��filenamer
r
r�temporary_filename0s
rc@sDeZdZd�dd�Zddddddd�dd�Zd	d
�Zdd�Ze�e	j
�d
�d�dd��Ze
dd��Zdd�Zdd�Ze�e	j
dkd�dd��Ze�edkd�e�eed�d�e
dd����Ze�edkd�e�eed �d!�e
d"d#����Zd$d%�Zd&d'�Ze�e	j
�d(�d)�e�eed*�d+�d,d-���Ze
d.d/��Ze�e�p@ed0�e
d1d2���Ze�e	j
dkd3�e�e�pned0�e
d4d5����Z e
d6d7��Z!e
d8d9��Z"d:d;�Z#d<d=�Z$d>d?�Z%d@dA�Z&dddB�dCdD�Z'dEdF�Z(dGdH�Z)e�e	j
dkd3�dIdJ��Z*dKdL�Z+dMdN�Z,dOdP�Z-dQdR�Z.e�eedS�dT�d�dddB�dVdW��Z/dXdY�Z0dZd[�Z1d\d]�Z2d^d_�Z3e�e	j
dkd3�d`da��Z4dbdc�Z5e�eedd�de�d�dfdg��Z6dhdi�Z7djdk�Z8dldm�Z9e�e	j
dkd3�dndo��Z:dpdq�Z;drds�Z<e=dtdu��Z>dvdw�Z?e�e@dx�dydz��ZAe�e@dx�d{d|��ZBe�e@dx�d}d~��ZCe�e@dx�dd���ZDdS)��FaultHandlerTestsNc
Cst|���}g}|dk	r"|�|�t���:tjd||d�}|�|��\}}|��}W5QRXW5QRXt�	|�}	|	�
dd�}	|r�|�|	d�t|d��}
|
�
�}	W5QRX|	�
dd�}	nT|dk	�r|�|	d�t�|tjd�t|ddd	��}
|
�
�}	W5QRX|	�
dd�}	|	��|fS)
N�-c)�pass_fds�ascii�backslashreplacer�rbrF)�closefd)r�strip�appendrZSuppressCrashReportrZspawn_python�communicate�waitZstrip_python_stderr�decode�assertEqual�open�read�os�lseek�SEEK_SET�
splitlines)�self�coder�fdr �process�stdout�stderr�exitcode�output�fpr
r
r�
get_output9s.




zFaultHandlerTests.get_outputTF)r�all_threads�other_regexr3�know_current_thread�py_fatal_errorcCs�|r|rd}
qd}
nd}
d}|	r(|d7}t|�j|||
d���}|rP|d|7}|j|||d�\}}
d	�|�}|�||�|�|
d
�dS)NzCurrent thread 0x[0-9a-f]+zThread 0x[0-9a-f]+ZStackz�
            (?m)^{fatal_error}

            {header} \(most recent call first\):
              File "<string>", line {lineno} in <module>
            z"
Python runtime state: initialized)�lineno�fatal_errorr�|�rr3rr)r�formatr%r:�join�assertRegex�assertNotEqual)r1r2�line_numberr@rr;r<r3r=r>rrr8r7r
r
r�check_error[s&
�

zFaultHandlerTests.check_errorcKsd|}|j|||f|�dS)NzFatal Python error: %s�rH�r1r2rGZ
name_regex�kwr@r
r
r�check_fatal_errorsz#FaultHandlerTests.check_fatal_errorcKsd|}|j|||f|�dS)NzWindows fatal exception: %srIrJr
r
r�check_windows_exception�sz)FaultHandlerTests.check_windows_exceptionZaixz5the first page of memory is a mapped read-only on AIXcCs&ts|�ddd�n|�ddd�dS)Nz�
                import faulthandler
                faulthandler.enable()
                faulthandler._read_null()
                �z4(?:Segmentation fault|Bus error|Illegal instruction)�access violation)�
MS_WINDOWSrLrM�r1r
r
r�test_read_null�s��z FaultHandlerTests.test_read_nullcCs|�ddd�dS)Nzs
            import faulthandler
            faulthandler.enable()
            faulthandler._sigsegv()
            rN�Segmentation fault�rLrQr
r
r�test_sigsegv�s�zFaultHandlerTests.test_sigsegvcCs|jdddddd�dS)Nz�
            import faulthandler
            faulthandler.enable()
            faulthandler._fatal_error_c_thread()
            rNz
in new threadFT)r=r>rTrQr
r
r�test_fatal_error_c_thread�s�z+FaultHandlerTests.test_fatal_error_c_threadcCs|�ddd�dS)Nzs
            import faulthandler
            faulthandler.enable()
            faulthandler._sigabrt()
            rNZAbortedrTrQr
r
r�test_sigabrt�s�zFaultHandlerTests.test_sigabrt�win32z"SIGFPE cannot be caught on WindowscCs|�ddd�dS)Nzr
            import faulthandler
            faulthandler.enable()
            faulthandler._sigfpe()
            rNzFloating point exceptionrTrQr
r
r�test_sigfpe�s�zFaultHandlerTests.test_sigfpezneed _testcapi�SIGBUSzneed signal.SIGBUScCs|�ddd�dS)Nz�
            import faulthandler
            import signal

            faulthandler.enable()
            signal.raise_signal(signal.SIGBUS)
            �z	Bus errorrTrQr
r
r�test_sigbus�s�zFaultHandlerTests.test_sigbus�SIGILLzneed signal.SIGILLcCs|�ddd�dS)Nz�
            import faulthandler
            import signal

            faulthandler.enable()
            signal.raise_signal(signal.SIGILL)
            r[zIllegal instructionrTrQr
r
r�test_sigill�s�zFaultHandlerTests.test_sigillcCs|jddddd�dS)Nz[
            import faulthandler
            faulthandler._fatal_error(b'xyz')
            ��xyzT�r>rTrQr
r
r�test_fatal_error�s
�z"FaultHandlerTests.test_fatal_errorcCs|jddddd�dS)Nza
            import faulthandler
            faulthandler._fatal_error(b'xyz', True)
            r_r`TrarTrQr
r
r�test_fatal_error_without_gil�s
�z.FaultHandlerTests.test_fatal_error_without_gilZopenbsdzVIssue #12868: sigaltstack() doesn't work on OpenBSD if Python is compiled with pthreadZ_stack_overflowz#need faulthandler._stack_overflow()cCs|jddddd�dS)Nzz
            import faulthandler
            faulthandler.enable()
            faulthandler._stack_overflow()
            rNz (?:Segmentation fault|Bus error)z unable to raise a stack overflow)r<rTrQr
r
r�test_stack_overflow�s
�z%FaultHandlerTests.test_stack_overflowcCs|�ddd�dS)Nzw
            import faulthandler
            faulthandler.enable()
            faulthandler._sigsegv(True)
            rNrSrTrQr
r
r�test_gil_releaseds�z#FaultHandlerTests.test_gil_releasedz0sanitizer builds change crashing process output.c	Cs4t��$}|jdjt|�d�dd|d�W5QRXdS)Nz�
                import faulthandler
                output = open({filename}, 'wb')
                faulthandler.enable(output)
                faulthandler._sigsegv()
                r�rS)rrLrC�repr�r1rr
r
r�test_enable_files��z"FaultHandlerTests.test_enable_filez.subprocess doesn't support pass_fds on Windowsc	Cs8t�d��$}|��}|jd|dd|d�W5QRXdS)N�wb+z�
                import faulthandler
                import sys
                faulthandler.enable(%s)
                faulthandler._sigsegv()
                rfrS�r3)r�
TemporaryFile�filenorL)r1r9r3r
r
r�test_enable_fds��z FaultHandlerTests.test_enable_fdcCs|jddddd�dS)Nz�
            import faulthandler
            faulthandler.enable(all_threads=False)
            faulthandler._sigsegv()
            rNrSF�r;rTrQr
r
r�test_enable_single_thread/s
�z+FaultHandlerTests.test_enable_single_threadcCsHd}d}|�|�\}}d�|�}|�||kd||f�|�|d�dS)Nz�
            import faulthandler
            faulthandler.enable()
            faulthandler.disable()
            faulthandler._sigsegv()
            zFatal Python errorrz%r is present in %rr)r:rD�
assertTruerF)r1r2Znot_expectedr6r7r
r
r�test_disable:s


�zFaultHandlerTests.test_disablecCsrtj}z^tjt_t��}z0t��|�t���t��|�t���W5|rXt��nt��XW5|t_XdSr)	�sysr6�
__stderr__�faulthandler�
is_enabled�enable�disablerqZassertFalse)r1Zorig_stderrZwas_enabledr
r
r�test_is_enabledIs
z!FaultHandlerTests.test_is_enabledcCs0d}tjdd|f}t�|�}|�|��d�dS)N�5import faulthandler; print(faulthandler.is_enabled())�-Er�False)rs�
executable�
subprocess�check_outputr*�rstrip)r1r2�argsr8r
r
r�test_disabled_by_default_s
z*FaultHandlerTests.test_disabled_by_defaultcCs`d}tdtjtjjrdndddd|f�}tj��}|�dd�t	j
||d�}|�|��d	�dS)
Nrzr{rz-Xrur�PYTHONFAULTHANDLER��env�True)
�filterrsr}�flags�ignore_environmentr-�environ�copy�popr~rr*r��r1r2r�r�r8r
r
r�test_sys_xoptionsgs�
z#FaultHandlerTests.test_sys_xoptionscCs�d}tjd|f}ttj�}d|d<d|d<tj||d�}|�|��d�ttj�}d|d<d|d<tj||d�}|�|��d	�dS)
Nrzrrr�Z
PYTHONDEVMODEr�r|�1r�)	rsr}�dictr-r�r~rr*r�r�r
r
r�test_env_varss

zFaultHandlerTests.test_env_varrBcCsld}|j||d�}|rd}n|dk	r*d}nd}dd|dd	g}|�|||�\}}|�||�|�|d
�dS)Na[
            import faulthandler

            filename = {filename!r}
            fd = {fd}

            def funcB():
                if filename:
                    with open(filename, "wb") as fp:
                        faulthandler.dump_traceback(fp, all_threads=False)
                elif fd is not None:
                    faulthandler.dump_traceback(fd,
                                                all_threads=False)
                else:
                    faulthandler.dump_traceback(all_threads=False)

            def funcA():
                funcB()

            funcA()
            rB�	���Stack (most recent call first):z#  File "<string>", line %s in funcBz#  File "<string>", line 17 in funcAz&  File "<string>", line 19 in <module>r�rCr:r*)r1rr3r2r?�expected�tracer7r
r
r�check_dump_traceback�s$��z&FaultHandlerTests.check_dump_tracebackcCs|��dSr)r�rQr
r
r�test_dump_traceback�sz%FaultHandlerTests.test_dump_tracebackc	Cs"t��}|j|d�W5QRXdS�Nr)rr�rhr
r
r�test_dump_traceback_file�sz*FaultHandlerTests.test_dump_traceback_filec	Cs*t�d��}|j|��d�W5QRXdS�Nrjrk)rrlr�rm�r1r9r
r
r�test_dump_traceback_fd�sz(FaultHandlerTests.test_dump_traceback_fdcCsdd}d|d}d|d}d}|j|d�}dd|d	g}|�|�\}}|�||�|�|d
�dS)Ni��x�2z...z�
            import faulthandler

            def {func_name}():
                faulthandler.dump_traceback(all_threads=False)

            {func_name}()
            )�	func_namer�z  File "<string>", line 4 in %sz%  File "<string>", line 6 in <module>rr�)r1�maxlenr�Z	truncatedr2r�r�r7r
r
r�
test_truncate�s��zFaultHandlerTests.test_truncatecCspd}|jt|�d�}|�||�\}}d�|�}|r8d}nd}d}t|j|d����}|�||�|�|d�dS)	Na�
            import faulthandler
            from threading import Thread, Event
            import time

            def dump():
                if {filename}:
                    with open({filename}, "wb") as fp:
                        faulthandler.dump_traceback(fp, all_threads=True)
                else:
                    faulthandler.dump_traceback(all_threads=True)

            class Waiter(Thread):
                # avoid blocking if the main thread raises an exception.
                daemon = True

                def __init__(self):
                    Thread.__init__(self)
                    self.running = Event()
                    self.stop = Event()

                def run(self):
                    self.running.set()
                    self.stop.wait()

            waiter = Waiter()
            waiter.start()
            waiter.running.wait()
            dump()
            waiter.stop.set()
            waiter.join()
            rr��
a�
            ^Thread 0x[0-9a-f]+ \(most recent call first\):
            (?:  File ".*threading.py", line [0-9]+ in [_a-z]+
            ){{1,3}}  File "<string>", line 23 in run
              File ".*threading.py", line [0-9]+ in _bootstrap_inner
              File ".*threading.py", line [0-9]+ in _bootstrap

            Current thread 0x[0-9a-f]+ \(most recent call first\):
              File "<string>", line {lineno} in dump
              File "<string>", line 28 in <module>$
            )r?r)rCrgr:rDrr%rEr*)r1rr2r8r7r?rr
r
r�check_dump_traceback_threads�s 
z.FaultHandlerTests.check_dump_traceback_threadscCs|�d�dSr)r�rQr
r
r�test_dump_traceback_threadssz-FaultHandlerTests.test_dump_traceback_threadsc	Cs t��}|�|�W5QRXdSr)rr�rhr
r
r� test_dump_traceback_threads_filesz2FaultHandlerTests.test_dump_traceback_threads_file�dump_traceback_laterz(need faulthandler.dump_traceback_later()r	c
Cs�ttjtd��}d}|jt|||||d�}|�||�\}}	d�|�}|s~|}
|rX|
d9}
d|}tdd||
d	�}|�||�n|�	|d
�|�	|	d�dS)N)Zsecondsa�
            import faulthandler
            import time
            import sys

            timeout = {timeout}
            repeat = {repeat}
            cancel = {cancel}
            loops = {loops}
            filename = {filename!r}
            fd = {fd}

            def func(timeout, repeat, cancel, file, loops):
                for loop in range(loops):
                    faulthandler.dump_traceback_later(timeout, repeat=repeat, file=file)
                    if cancel:
                        faulthandler.cancel_dump_traceback_later()
                    time.sleep(timeout * 5)
                    faulthandler.cancel_dump_traceback_later()

            if filename:
                file = open(filename, "wb")
            elif fd is not None:
                file = sys.stderr.fileno()
            else:
                file = None
            func(timeout, repeat, cancel, file, loops)
            if filename:
                file.close()
            )�timeout�repeat�cancel�loopsrr3rr_zATimeout \(%s\)!\nThread 0x[0-9a-f]+ \(most recent call first\):\n��)rrr)
�str�datetimeZ	timedelta�TIMEOUTrCr:rDrrEr*)
r1r�r�r�rr3Ztimeout_strr2r�r7�countrrr
r
r�check_dump_traceback_laters*�
z,FaultHandlerTests.check_dump_traceback_latercCs|��dSr�r�rQr
r
r�test_dump_traceback_laterZsz+FaultHandlerTests.test_dump_traceback_latercCs|jdd�dS)NT)r�r�rQr
r
r� test_dump_traceback_later_repeat]sz2FaultHandlerTests.test_dump_traceback_later_repeatcCs|jdd�dS)NT)r�r�rQr
r
r� test_dump_traceback_later_cancel`sz2FaultHandlerTests.test_dump_traceback_later_cancelc	Cs"t��}|j|d�W5QRXdSr�)rr�rhr
r
r�test_dump_traceback_later_filecsz0FaultHandlerTests.test_dump_traceback_later_filec	Cs*t�d��}|j|��d�W5QRXdSr�)rrlr�rmr�r
r
r�test_dump_traceback_later_fdgsz.FaultHandlerTests.test_dump_traceback_later_fdcCs|jdd�dS)Nr_)r�r�rQr
r
r�test_dump_traceback_later_twicemsz1FaultHandlerTests.test_dump_traceback_later_twice�registerzneed faulthandler.registercCs�tj}d}|j||||||d�}|�||�\}}	d�|�}|sf|rHd}
nd}
tdd|
�}
|�||
�n|�|d�|r�|�|	d	�n|�|	d	�dS)
Nax
            import faulthandler
            import os
            import signal
            import sys

            all_threads = {all_threads}
            signum = {signum}
            unregister = {unregister}
            chain = {chain}
            filename = {filename!r}
            fd = {fd}

            def func(signum):
                os.kill(os.getpid(), signum)

            def handler(signum, frame):
                handler.called = True
            handler.called = False

            if filename:
                file = open(filename, "wb")
            elif fd is not None:
                file = sys.stderr.fileno()
            else:
                file = None
            if chain:
                signal.signal(signum, handler)
            faulthandler.register(signum, file=file,
                                  all_threads=all_threads, chain={chain})
            if unregister:
                faulthandler.unregister(signum)
            func(signum)
            if chain and not handler.called:
                if file is not None:
                    output = file
                else:
                    output = sys.stderr
                print("Error: signal handler not called!", file=output)
                exitcode = 1
            else:
                exitcode = 0
            if filename:
                file.close()
            sys.exit(exitcode)
            )r;�signum�
unregister�chainrr3rz8Current thread 0x[0-9a-f]+ \(most recent call first\):\nz#Stack \(most recent call first\):\nr�� rr)	�signal�SIGUSR1rCr:rDrrEr*rF)r1rr;r�r�r3r�r2r�r7rr
r
r�check_registerps,.�
z FaultHandlerTests.check_registercCs|��dSr�r�rQr
r
r�
test_register�szFaultHandlerTests.test_registercCs|jdd�dS)NT)r�r�rQr
r
r�test_unregister�sz!FaultHandlerTests.test_unregisterc	Cs"t��}|j|d�W5QRXdSr�)rr�rhr
r
r�test_register_file�sz$FaultHandlerTests.test_register_filec	Cs*t�d��}|j|��d�W5QRXdSr�)rrlr�rmr�r
r
r�test_register_fd�sz"FaultHandlerTests.test_register_fdcCs|jdd�dS)NTror�rQr
r
r�test_register_threads�sz'FaultHandlerTests.test_register_threadscCs|jdd�dS)NT)r�r�rQr
r
r�test_register_chain�sz%FaultHandlerTests.test_register_chainc	csLtj}z8dt_|�t��}dVW5QRX|�t|j�d�W5|t_XdS)Nzsys.stderr is None)rsr6ZassertRaises�RuntimeErrorr*r��	exception)r1r6�cmr
r
r�check_stderr_none�sz#FaultHandlerTests.check_stderr_nonec	Cs�|���t��W5QRX|���t��W5QRXttd�r`|���t�d�W5QRXttd�r�|���t�tj�W5QRXdS)Nr�g����MbP?r�)	r�rurwZdump_traceback�hasattrr�r�r�r�rQr
r
r�test_stderr_None�s





z"FaultHandlerTests.test_stderr_Nonezspecific to WindowscCs(dD]\}}|�d|�d�d|�qdS)N))ZEXCEPTION_ACCESS_VIOLATIONrO)ZEXCEPTION_INT_DIVIDE_BY_ZEROzint divide by zero)ZEXCEPTION_STACK_OVERFLOWzstack overflowz�
                import faulthandler
                faulthandler.enable()
                faulthandler._raise_exception(faulthandler._�)
                rN)rM)r1�exc�namer
r
r�test_raise_exception�s��z&FaultHandlerTests.test_raise_exceptioncCsHdD]>}d|�d�}t|�}|�|�\}}|�|g�|�||�qdS)N)lcs�@lRC�@z�
                    import faulthandler
                    faulthandler.enable()
                    faulthandler._raise_exception(z)
                    �rr:r*)r1Zexc_coder2r8r7r
r
r�test_ignore_exceptions�z'FaultHandlerTests.test_ignore_exceptioncCsFdD]<}|�d|d�d��\}}|�|g�|�|||d@f�qdS)N)ri�xV4i@i@ipi���z{
                import faulthandler
                faulthandler.enable()
                faulthandler._raise_exception(0xr�r�i����)r:r*ZassertIn)r1r�r8r7r
r
r�test_raise_nonfatal_exceptions
�z/FaultHandlerTests.test_raise_nonfatal_exceptioncCs2td�}|�|�\}}|�|g�|�|d�dS)Nz�
            import faulthandler
            faulthandler.enable()
            faulthandler.disable()
            code = faulthandler._EXCEPTION_ACCESS_VIOLATION
            faulthandler._raise_exception(code)
        lr�)r1r2r8r7r
r
r� test_disable_windows_exc_handler-sz2FaultHandlerTests.test_disable_windows_exc_handler)NN)FFr	)FFFFN)E�__name__�
__module__�__qualname__r:rHrLrMrrrs�platform�
startswithrRrrUrVrWrY�	_testcapiZ
skipUnlessr�r�r\r^rbrcrurdre�UB_SANITIZER�MEMORY_SANITIZERrirnrprrryr�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�r�rr�r�rPr�r�r�r�r
r
r
rr8s�
#�$�

		�
			��

	���



.�
;��>�
��Q�









r�__main__)r	)#�
contextlibrr�rur-r�r~rsZ	sysconfigrrZtest.supportrrrr�textwraprr��ImportErrorr�r�rPZget_config_varZ_cflagsZ_config_argsr�r�rrrZTestCaserr��mainr
r
r
r�<module>sN

��
	
	


F1le Man4ger