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/sqlite3/test/__pycache__/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]


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

?��g�C�@s�ddlZddlZddlZddlZddlZddlmZddlm	Z	Gdd�dej
�ZGdd�dej
�Zdd	�Z
d
d�Zedkr�e�dS)
�N)�support)�patchc@seZdZdd�Zdd�Zdd�Zdd�Zd	d
�Zdd�Zd
d�Z	e
�ej
dkd�dd��Zdd�Zdd�Zdd�Zdd�Zdd�Zdd�Zdd �Zd!d"�Zd#d$�Zd%d&�Zd'd(�Zd)d*�Zd+d,�Zd-d.�Zd/d0�Zd1d2�Zd3d4�Zd5d6�Z d7d8�Z!d9d:�Z"d;d<�Z#d=d>�Z$d?d@�Z%dAS)B�RegressionTestscCst�d�|_dS)N�:memory:)�sqlite�connect�con��self�r�6/opt/cppython/lib/python3.8/sqlite3/test/regression.py�setUp#szRegressionTests.setUpcCs|j��dS�N)r�closer	rrr�tearDown&szRegressionTests.tearDowncCs|j��}|�d�dS)Nzpragma user_version)r�cursor�execute�r
�currrr�CheckPragmaUserVersion)s
z&RegressionTests.CheckPragmaUserVersioncCs@tjdtjd�}z|j��}|�d�W5|��|��XdS)Nr�Zdetect_typeszpragma schema_version)rr�PARSE_COLNAMESrrrr�r
rrrrr�CheckPragmaSchemaVersion.s
z(RegressionTests.CheckPragmaSchemaVersioncs�tjddd���fdd�td�D�}|d�d�td�D]"}|d�d	d
d�td�D��q:td�D]}||�d|d�qf���dS)
Nr�)Zcached_statementscsg|]}����qSr)r��.0�x�rrr�
<listcomp>=sz7RegressionTests.CheckStatementReset.<locals>.<listcomp>rzcreate table test(x)�
�insert into test(x) values (?)cSsg|]
}|f�qSrrrrrrr@s� zselect x from test)rr�ranger�executemany�rollback)r
�cursors�irrr�CheckStatementReset8s z#RegressionTests.CheckStatementResetcCsN|j��}|�d�|�|jddd�|�d�|�|jddd�dS)Nz select 1 as "foo bar [datetime]"rzfoo bar [datetime]zselect 1 as "foo baz"zfoo baz)rrr�assertEqual�descriptionrrrr�CheckColumnNameWithSpacesGs



z)RegressionTests.CheckColumnNameWithSpacescCsLt�d�}g}td�D](}|��}|�|�|�dt|��q|��dS)Nr�izselect 1 x union select )rrr#r�appendr�strr)r
rr&r'rrrr�#CheckStatementFinalizationOnCloseDbOs

z3RegressionTests.CheckStatementFinalizationOnCloseDb)��r1zneeds sqlite 3.2.2 or newercCs�t�d�}|�d�|�d�z|�d�Wntjk
rBYnX|�d�z|��Wn tjk
rz|�d�YnXdS)Nrz3create table foo(x, unique(x) on conflict rollback)zinsert into foo(x) values (1)zinsert into foo(x) values (2)z1pysqlite knew nothing about the implicit ROLLBACK)rrrZ
DatabaseError�commit�OperationalErrorZfail�r
rrrr�CheckOnConflictRollback]s



z'RegressionTests.CheckOnConflictRollbackcCs(|j�d�|j�d�|j�d�dS)N�create table foo(bar)�drop table foo�rrr	rrr�-CheckWorkaroundForBuggySqliteTransferBindingslsz=RegressionTests.CheckWorkaroundForBuggySqliteTransferBindingscCs|j�d�dS�N�r8r	rrr�CheckEmptyStatementusz#RegressionTests.CheckEmptyStatementcCshd}tjdtjd�}|�d�|�dtj��f�|�|�|�d�|�d�|�d�|�|�dS)	Nzselect * from foorrzcreate table foo(bar timestamp)zinsert into foo(bar) values (?)r7zcreate table foo(bar integer)�insert into foo(bar) values (5))rr�PARSE_DECLTYPESr�datetimeZnow)r
ZSELECTrrrr�CheckTypeMapUsage|s




z!RegressionTests.CheckTypeMapUsagec	s\G�fdd�d�}|�dg�tjdtjd�}|�d�|�t��|�d��W5QRXdS)NcseZdZ�fdd�ZdS)z0RegressionTests.CheckBindMutatingList.<locals>.Xcs���dS)Nz...)�clear)r
�protocol�Z
parametersrr�__conform__�sz<RegressionTests.CheckBindMutatingList.<locals>.X.__conform__N)�__name__�
__module__�__qualname__rDrrCrr�X�srHrrrz$create table foo(bar X, baz integer)z'insert into foo(bar, baz) values (?, ?))rrr>r�assertRaises�
IndexError)r
rHrrrCr�CheckBindMutatingList�s

z%RegressionTests.CheckBindMutatingListc	CsP|�tj��$}|j�dttdg��f���W5QRXd}|�|t	|j
��dS)Nz"select 'xxx' || ? || 'yyy' colname�z9Could not decode to UTF-8 column 'colname' with text 'xxx)rIrr3rr�bytes�	bytearray�fetchoneZassertInr.�	exception)r
�cm�msgrrr�CheckErrorMsgDecodeError�s�z(RegressionTests.CheckErrorMsgDecodeErrorcCs|�ttjid�dSr)rI�	TypeErrorrZregister_adapterr	rrr�CheckRegisterAdapter�sz$RegressionTests.CheckRegisterAdaptercs�G�fdd�dt�}t�d��d�_dD]@}|j|d��*|�_|���_|���_||��_W5QRXq(d�_d�_dtfdtfd	tfd
tfdtfg}|D]J\}}|j|d��0|�	|��|�_W5QRX|�
�jd�W5QRXq�dS)Ncs eZdZdd�Z�fdd�ZdS)z9RegressionTests.CheckSetIsolationLevel.<locals>.CustomStrcSsdSrrr	rrr�upper�sz?RegressionTests.CheckSetIsolationLevel.<locals>.CustomStr.uppercs
d�_dSr:��isolation_levelr	rrr�__del__�szARegressionTests.CheckSetIsolationLevel.<locals>.CustomStr.__del__N)rErFrGrVrYrrrr�	CustomStr�srZr)r;�DEFERREDZ	IMMEDIATEZ	EXCLUSIVE)�levelr[���abczIMMEDIATEEXCLUSIVE�é)r.rrrX�subTest�lower�
capitalizerT�
ValueErrorrIr))r
rZr\Zpairs�value�excrrr�CheckSetIsolationLevel�s,


�z&RegressionTests.CheckSetIsolationLevelc	CspGdd�dtj�}t�d�}||�}|�tj��|�d���W5QRX|�tjd��|��W5QRXdS)Nc@seZdZdd�ZdS)z?RegressionTests.CheckCursorConstructorCallCheck.<locals>.CursorcSsdSrrr4rrr�__init__�szHRegressionTests.CheckCursorConstructorCallCheck.<locals>.Cursor.__init__N�rErFrGrhrrrr�Cursor�srjrz
select 4+5z$^Base Cursor\.__init__ not called\.$)	rrjrrI�ProgrammingErrorr�fetchall�assertRaisesRegexr)r
rjrrrrr�CheckCursorConstructorCallCheck�s
�z/RegressionTests.CheckCursorConstructorCallCheckcCs(Gdd�dt�}|j�d|d�f�dS)Nc@seZdZdS)z/RegressionTests.CheckStrSubclass.<locals>.MyStrN)rErFrGrrrr�MyStr�srozselect ?r_)r.rr)r
rorrr�CheckStrSubclass�sz RegressionTests.CheckStrSubclassc	Cs>Gdd�dtj�}|d�}|�tj��|��}W5QRXdS)Nc@seZdZdd�ZdS)zGRegressionTests.CheckConnectionConstructorCallCheck.<locals>.ConnectioncSsdSrr)r
�namerrrrh�szPRegressionTests.CheckConnectionConstructorCallCheck.<locals>.Connection.__init__Nrirrrr�
Connection�srrr)rrrrIrkr�r
rrrrrrr�#CheckConnectionConstructorCallCheck�sz3RegressionTests.CheckConnectionConstructorCallCheckc	s�G�fdd�dtj�}Gdd�dtj��|d�}|��}|�d�|�ddd	d
g�|�d�|��|�tj��|�	�W5QRXdS)NcseZdZ�fdd�ZdS)z;RegressionTests.CheckCursorRegistration.<locals>.Connectioncs�|�Srrr	�rjrrr�szBRegressionTests.CheckCursorRegistration.<locals>.Connection.cursorN)rErFrGrrrurrrr�srrc@seZdZdd�ZdS)z7RegressionTests.CheckCursorRegistration.<locals>.CursorcSstj�||�dSr)rrjrhr4rrrrh�sz@RegressionTests.CheckCursorRegistration.<locals>.Cursor.__init__Nrirrrrrj�srjrzcreate table foo(x)zinsert into foo(x) values (?))r0)�)rzselect x from foo)
rrrrjrrr$r%rIZInterfaceErrorrlrsrrur�CheckCursorRegistration�s

z'RegressionTests.CheckCursorRegistrationcCstjddd�}dS)NrrW)rrr4rrr�CheckAutoCommitszRegressionTests.CheckAutoCommitcCs4|j��}|�d�|�d�|�d�|��}dS)Nr6r=zpragma page_size)rrrrO)r
r�rowrrr�CheckPragmaAutocommits




z%RegressionTests.CheckPragmaAutocommitcCs|�tj|jd�dS�Nr])rIr�Warningrr	rrr�CheckConnectionCallsz#RegressionTests.CheckConnectionCallcCs"dd�}|�tj|jjd|�dS)NcSsdSr{r)�a�brrr�collation_cbsz4RegressionTests.CheckCollation.<locals>.collation_cbu�)rIrrkrZcreate_collation)r
r�rrr�CheckCollations
�zRegressionTests.CheckCollationc	sft�d�}|�����d���d��fdd�}|�tj����ddd�|�D��W5QRXdS)	Nrzcreate table a (bar)zcreate table b (baz)c3s��dd�dVdS)Nzinsert into a (bar) values (?))r]r])rr�rrr�foo/sz4RegressionTests.CheckRecursiveCursorUse.<locals>.foozinsert into b (baz) values (?)css|]}|fVqdSrr)rr'rrr�	<genexpr>5sz:RegressionTests.CheckRecursiveCursorUse.<locals>.<genexpr>)rrrrrIrkr$)r
rr�rr�r�CheckRecursiveCursorUse"s


�z'RegressionTests.CheckRecursiveCursorUsec
Cs�tjdtjd�}|��}|�d�|�d�|�d�|�d�dd�|��D�}|�|t�d	d
d
ddd
d�t�d	d
d
ddd
d�g�dS)NrrzCREATE TABLE t (x TIMESTAMP)z4INSERT INTO t (x) VALUES ('2012-04-04 15:06:00.456')z:INSERT INTO t (x) VALUES ('2012-04-04 15:06:00.123456789')zSELECT * FROM tcSsg|]}|d�qS)rrrrrrrJszKRegressionTests.CheckConvertTimestampMicrosecondPadding.<locals>.<listcomp>i�rv��ri@�i@�)rrr>rrrlr)r?)r
rr�valuesrrr�'CheckConvertTimestampMicrosecondPadding7s



�z7RegressionTests.CheckConvertTimestampMicrosecondPaddingcCs|jttjddd�dS)Nr�{rW)rIrTrrr	rrr�CheckInvalidIsolationLevelTypeQs
�z.RegressionTests.CheckInvalidIsolationLevelTypecCsRt�d�}|�t|d�|�t|d�|��}|�t|jd�|�t|jd�dS)Nrz	select 1z	select 1z
 select 2z	select 2)rrrIrdrrrrrr�CheckNullCharacterWs
z"RegressionTests.CheckNullCharacterc
Cs�t�d�}|�d�|�|jd�d}t|�d��D]�\}}|j||d��p|�d|f�|��|dkr||�|dd�n2|dkr�|�|dd�n|d	kr�|�|dd	�|d7}W5QRXq4|�|d
d�dS)Nrz�
        create table t(c);
        create table t2(c);
        insert into t values(0);
        insert into t values(1);
        insert into t values(2);
        r;rzselect c from t)r'ryzinsert into t2(c) values (?)r]r1r0z'should have returned exactly three rows)	rrZ
executescriptr)rX�	enumeraterrar2)r
rZcounterr'ryrrr�CheckCommitCursorReset`s 

z&RegressionTests.CheckCommitCursorResetcCsBdd�}t�d�}t�|�}t�||�}|�|�~~t��dS)NcWsdSrr)�argsrrr�callback�sz/RegressionTests.CheckBpo31770.<locals>.callbackr)rrrj�weakref�refrhr�
gc_collect)r
r�rrr�rrr�
CheckBpo31770s


zRegressionTests.CheckBpo31770c	Cs |�t��|j`W5QRXdSr)rI�AttributeErrorrrXr	rrr�CheckDelIsolation_levelSegfault�sz/RegressionTests.CheckDelIsolation_levelSegfaultcCsfGdd�d�}|jjtj|jjdd�|jjfD]2}|�}||j�||j�|j�d�|d�q.dS)Nc@seZdZdd�ZdS)z.RegressionTests.CheckBpo37347.<locals>.PrintercWstjSr)rZ	SQLITE_OK)r
r�rrr�log�sz2RegressionTests.CheckBpo37347.<locals>.Printer.logN)rErFrGr�rrrr�Printer�sr�r])�nzselect 1)rZset_trace_callback�	functools�partialZset_progress_handlerZset_authorizerr�r)r
r��methodZprinter_instancerrr�
CheckBpo37347�s�

zRegressionTests.CheckBpo37347N)&rErFrGr
rrrr(r+r/�unittestZskipIfrZsqlite_version_infor5r9r<r@rKrSrUrgrnrprtrwrxrzr}r�r�r�r�r�r�r�r�r�rrrrr"s@

	
	
	rc@s8eZdZdZdd�Zdd�Zdd�Zdd	�Zd
d�ZdS)
�RecursiveUseOfCursorsz$Recursive use of cursors not allowedcCs@tjdtjd�|_|j��|_|j�d�|j�dddg�dS)Nrrzcreate table test(x foo)r!)r�)Zbar)rrrrrrrr$r	rrrr
�s��zRecursiveUseOfCursors.setUpcCs |j��|j��|`|`dSr)rrrr	rrrr�s

zRecursiveUseOfCursors.tearDownc
sV�fdd�}t�tjd|i��.��tj�j���j�d�W5QRXW5QRXdS)Ncs�j��j�Sr)rrhr�rr	rr�<lambda>�r^zBRecursiveUseOfCursors.test_recursive_cursor_init.<locals>.<lambda>ZINITz#select x as "x [INIT]", x from test�	r�dictr�
convertersrmrkrRrr�r
�convrr	r�test_recursive_cursor_init�sz0RecursiveUseOfCursors.test_recursive_cursor_initc
sV�fdd�}t�tjd|i��.��tj�j���j�d�W5QRXW5QRXdS)Ncs
�j��Sr)rrr�r	rrr��r^zCRecursiveUseOfCursors.test_recursive_cursor_close.<locals>.<lambda>ZCLOSEz$select x as "x [CLOSE]", x from testr�r�rr	r�test_recursive_cursor_close�sz1RecursiveUseOfCursors.test_recursive_cursor_closec
sdgf�fdd�	}t�tjd|i��8�j�d���tj�j���j�	�W5QRXW5QRXdS)Ncs|r�j��S|�d�Sr)rrOr-)r�lr	rrr��r^zCRecursiveUseOfCursors.test_recursive_cursor_fetch.<locals>.<lambda>ZITERz#select x as "x [ITER]", x from test)
rr�rr�rrrmrkrRrlr�rr	r�test_recursive_cursor_fetch�s
z1RecursiveUseOfCursors.test_recursive_cursor_fetchN)	rErFrGrRr
rr�r�r�rrrrr��sr�cCs$t�td�}t�t�}t�||f�S)NZCheck)r�Z	makeSuiterr�Z	TestSuite)Zregression_suiteZrecursive_cursorrrr�suite�s
�r�cCst��}|�t��dSr)r�ZTextTestRunner�runr�)Zrunnerrrr�test�sr��__main__)r?r�Zsqlite3rr�r�r�rZ
unittest.mockrZTestCaserr�r�rErrrr�<module>s&

F1le Man4ger