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_file_eintr.cpython-38.pyc
U

>��gf*�@sddlZddlZddlZddlZddlZddlZddlZddlZddlZe�	ej
dkd�Gdd�d��ZGdd�deej�Z
Gdd	�d	eej�ZGd
d�de�ZGdd
�d
eej�ZGdd�deej�ZGdd�de�ZGdd�deej�ZGdd�deej�Zedk�re��dS)�N�posixztests requires a posix system.c@sReZdZdd�Zdd�Zdd�Zdd	d
�Zdd�Zd
Zdd�Z	dd�Z
dd�ZdS)�TestFileIOSignalInterruptcCs
d|_dS�N)�_process��self�r�3/opt/cppython/lib/python3.8/test/test_file_eintr.py�setUpszTestFileIOSignalInterrupt.setUpcCs<|jr8|j��dkr8z|j��Wntk
r6YnXdSr)r�poll�kill�OSErrorrrrr	�tearDowns
z"TestFileIOSignalInterrupt.tearDowncCs
d|jS)z�Returns the infile = ... line of code for the reader process.

        subclasseses should override this to test different IO objects.
        z=import %s as io ;infile = io.FileIO(sys.stdin.fileno(), "rb")��modnamerrrr	�_generate_infile_setup_code$s�z5TestFileIOSignalInterrupt._generate_infile_setup_code�TcCs~|j��dkr<t�d�z|j��Wntk
r:YnX|r^|j��\}}||7}||7}|�d||��|��f�dS)a;A common way to cleanup and fail with useful debug output.

        Kills the process if it is still running, collects remaining output
        and fails the test with an error message including the output.

        Args:
            why: Text to go after "Error from IO process" in the message.
            stdout, stderr: standard output and error from the process so
                far to include in the error message.
            communicate: bool, when True we call communicate() on the process
                after killing it to gather additional output.
        Ng�������?z/Error from IO process %s:
STDOUT:
%sSTDERR:
%s
)	rr�time�sleep�	terminater
�communicate�fail�decode)r�why�stdout�stderrrZ
stdout_endZ
stderr_endrrr	�fail_with_process_info-s
�z0TestFileIOSignalInterrupt.fail_with_process_infocCsH|��}t|�dkstd��tjtjddd|dd|ddgtjtjtjd	�|_|jj	�
td
��}|d
kr�|jd|d�|jj�
|�d
}g}|s�t�|jj	gddd�\}}}|j�tj�|d7}|dkr�|j��|�d�q�|jj	��}|dk�r|jd|d�|jjdd�\}	}
|jj�rD|jd|jj|	|
dd�dS)anGeneric buffered read method test harness to validate EINTR behavior.

        Also validates that Python signal handlers are run during the read.

        Args:
            data_to_write: String to write to the child process for reading
                before sending it a signal, confirming the signal was handled,
                writing a final newline and closing the infile pipe.
            read_and_verify_code: Single "line" of code to read from a file
                object named 'infile' and validate the result.  This will be
                executed as part of a python subprocess fed data_to_write.
        iz#data_to_write must fit in pipe buf.z-uz-czXimport signal, sys ;signal.signal(signal.SIGINT, lambda s, f: sys.stderr.write("$\n")) ;z ;z"sys.stderr.write("Worm Sign!\n") ;zinfile.close())�stdinrrsWorm Sign!
zwhile awaiting a sign)rrrg�������?���z,reader process failed to handle our signals.s$
zwhile awaiting signal�
)�inputzexited rc=%dF)rN)r�len�AssertionError�
subprocess�Popen�sys�
executable�PIPErr�readrr�write�select�send_signal�signal�SIGINTrr�readliner�
returncode)r�
data_to_write�read_and_verify_codeZinfile_setup_codeZ	worm_signZsignals_sentZrlist�_Zsignal_linerrrrr	�
_test_readingHsd
�������	��

�

�z'TestFileIOSignalInterrupt._test_readingz�got = infile.{read_method_name}() ;expected = {expected!r} ;assert got == expected, ("{read_method_name} returned wrong data.\n""got data %r\nexpected %r" % (got, expected))cCs|jd|jjddd�d�dS)�1readline() must handle signals and not lose data.�
hello, world!r/shello, world!
�Zread_method_nameZexpected�r1r2N�r4�_READING_CODE_TEMPLATE�formatrrrr	�
test_readline�s��z'TestFileIOSignalInterrupt.test_readlinecCs"|jd|jjdddgd�d�dS)�2readlines() must handle signals and not lose data.�hello
world!�	readlinesshello
sworld!
r7r8Nr9rrrr	�test_readlines�s��z(TestFileIOSignalInterrupt.test_readlinescCs8|jd|jjddd�d�|jd|jjddd�d�dS)z0readall() must handle signals and not lose data.r>�readall�
hello
world!
r7r8r)Nr9rrrr	�test_readall�s����z&TestFileIOSignalInterrupt.test_readallN)rrT)�__name__�
__module__�__qualname__r
rrrr4r:r<r@rCrrrr	rs	�
I�rc@seZdZdZdS)�CTestFileIOSignalInterrupt�_ioN�rDrErFrrrrr	rG�srGc@seZdZdZdS)�PyTestFileIOSignalInterrupt�_pyioNrIrrrr	rJ�srJc@seZdZdd�Zdd�ZdS)�TestBufferedIOSignalInterruptcCs
d|jS)z?Returns the infile = ... line of code to make a BufferedReader.ziimport %s as io ;infile = io.open(sys.stdin.fileno(), "rb") ;assert isinstance(infile, io.BufferedReader)rrrrr	r�s�z9TestBufferedIOSignalInterrupt._generate_infile_setup_codecCs|jd|jjddd�d�dS)z<BufferedReader.read() must handle signals and not lose data.r>r)rBr7r8Nr9rrrr	rC�s��z*TestBufferedIOSignalInterrupt.test_readallN)rDrErFrrCrrrr	rL�srLc@seZdZdZdS)�CTestBufferedIOSignalInterruptrHNrIrrrr	rM�srMc@seZdZdZdS)�PyTestBufferedIOSignalInterruptrKNrIrrrr	rN�srNc@s,eZdZdd�Zdd�Zdd�Zdd�Zd	S)
�TestTextIOSignalInterruptcCs
d|jS)z>Returns the infile = ... line of code to make a TextIOWrapper.zvimport %s as io ;infile = io.open(sys.stdin.fileno(), "rt", newline=None) ;assert isinstance(infile, io.TextIOWrapper)rrrrr	r�s�z5TestTextIOSignalInterrupt._generate_infile_setup_codecCs|jd|jjddd�d�dS)r5r6r/zhello, world!
r7r8Nr9rrrr	r<�s��z'TestTextIOSignalInterrupt.test_readlinecCs"|jd|jjdddgd�d�dS)r=s
hello
world!r?zhello
zworld!
r7r8Nr9rrrr	r@�s��z(TestTextIOSignalInterrupt.test_readlinescCs|jd|jjddd�d�dS)z-read() must handle signals and not lose data.r>r)z
hello
world!
r7r8Nr9rrrr	rC�s��z&TestTextIOSignalInterrupt.test_readallN)rDrErFrr<r@rCrrrr	rO�srOc@seZdZdZdS)�CTestTextIOSignalInterruptrHNrIrrrr	rP�srPc@seZdZdZdS)�PyTestTextIOSignalInterruptrKNrIrrrr	rQ�srQ�__main__)�osr+r-r$r&rZunittestrHrKZ
skipUnless�namerZTestCaserGrJrLrMrNrOrPrQrD�mainrrrr	�<module>s* 


F1le Man4ger