Sindbad~EG File Manager

Current Path : /usr/local/lib/python3.9/sqlite3/test/__pycache__/
Upload File :
Current File : //usr/local/lib/python3.9/sqlite3/test/__pycache__/regression.cpython-39.opt-2.pyc

a

��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�3/usr/local/lib/python3.9/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.CheckPragmaUserVersioncCsPtjdtjd�}z(|j��}|�d�W|��|��n|��|��0dS)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>=�z7RegressionTests.CheckStatementReset.<locals>.<listcomp>rzcreate table test(x)�
�insert into test(x) values (?)cSsg|]
}|f�qSrrrrrrr@r � 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)��r2zneeds sqlite 3.2.2 or newercCs|t�d�}|�d�|�d�z|�d�Wntjy@Yn0|�d�z|��Wntjyv|�d�Yn0dS)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�r9r	rrr�CheckEmptyStatementusz#RegressionTests.CheckEmptyStatementcCspd}tjdtjd�}|�d�|�dtj��f�|�|���|�d�|�d�|�d�|�|���dS)	Nzselect * from foorrzcreate table foo(bar timestamp)zinsert into foo(bar) values (?)r8zcreate table foo(bar integer)�insert into foo(bar) values (5))rr�PARSE_DECLTYPESr�datetimeZnowr)r
ZSELECTrrrr�CheckTypeMapUsage|s



z!RegressionTests.CheckTypeMapUsagecspG�fdd�d�}|�dg�tjdtjd�}|�d�|�t��|�d��Wd�n1sb0YdS)NcseZdZ�fdd�ZdS)z0RegressionTests.CheckBindMutatingList.<locals>.Xcs���dS)Nz...)�clear)r
�protocol��
parametersrr�__conform__�sz<RegressionTests.CheckBindMutatingList.<locals>.X.__conform__N)�__name__�
__module__�__qualname__rFrrDrr�X�srJrrrz$create table foo(bar X, baz integer)z'insert into foo(bar, baz) values (?, ?))rrr?r�assertRaises�
IndexError)r
rJrrrDr�CheckBindMutatingList�s

z%RegressionTests.CheckBindMutatingListcCsd|�tj��.}|j�dttdg��f���Wd�n1s@0Yd}|�|t	|j
��dS)Nz"select 'xxx' || ? || 'yyy' colname�z9Could not decode to UTF-8 column 'colname' with text 'xxx)rKrr4rr�bytes�	bytearray�fetchoneZassertInr/�	exception)r
�cm�msgrrr�CheckErrorMsgDecodeError�s�&z(RegressionTests.CheckErrorMsgDecodeErrorcCs|�ttjid�dSr)rK�	TypeErrorrZregister_adapterr	rrr�CheckRegisterAdapter�sz$RegressionTests.CheckRegisterAdapterc
s*G�fdd�dt�}t�d��d�_dD]T}|j|d��4|�_|���_|���_||��_Wd�q(1sr0Yq(d�_d�_dtfdtfd	tfd
tfdtfg}|D]t\}}|j|d��N|�	|��|�_Wd�n1s�0Y|�
�jd�Wd�q�1�s0Yq�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)rGrHrIrXr[rrrr�	CustomStr�sr\r)r<�DEFERREDZ	IMMEDIATEZ	EXCLUSIVE)�levelr]�r �abczIMMEDIATEEXCLUSIVE�é)r/rrrZ�subTest�lower�
capitalizerV�
ValueErrorrKr*)r
r\r^�pairs�value�excrrr�CheckSetIsolationLevel�s&


*�$z&RegressionTests.CheckSetIsolationLevelcCs�Gdd�dtj�}t�d�}||�}|�tj��|�d���Wd�n1sT0Y|�tjd��|��Wd�n1s�0YdS)Nc@seZdZdd�ZdS)z?RegressionTests.CheckCursorConstructorCallCheck.<locals>.CursorcSsdSrrr5rrr�__init__�szHRegressionTests.CheckCursorConstructorCallCheck.<locals>.Cursor.__init__N�rGrHrIrjrrrr�Cursor�srlrz
select 4+5z$^Base Cursor\.__init__ not called\.$)	rrlrrK�ProgrammingErrorr�fetchall�assertRaisesRegexr)r
rlrrrrr�CheckCursorConstructorCallCheck�s
,�z/RegressionTests.CheckCursorConstructorCallCheckcCs(Gdd�dt�}|j�d|d�f�dS)Nc@seZdZdS)z/RegressionTests.CheckStrSubclass.<locals>.MyStrN)rGrHrIrrrr�MyStr�r rqzselect ?r`)r/rr)r
rqrrr�CheckStrSubclass�sz RegressionTests.CheckStrSubclasscCsRGdd�dtj�}|d�}|�tj��|��}Wd�n1sD0YdS)Nc@seZdZdd�ZdS)zGRegressionTests.CheckConnectionConstructorCallCheck.<locals>.ConnectioncSsdSrr)r
�namerrrrj�szPRegressionTests.CheckConnectionConstructorCallCheck.<locals>.Connection.__init__Nrkrrrr�
Connection�srtr)rrtrKrmr�r
rtrrrrr�#CheckConnectionConstructorCallCheck�sz3RegressionTests.CheckConnectionConstructorCallCheckcs�G�fdd�dtj�}Gdd�dtj��|d�}|��}|�d�|�dgd��|�d	�|��|�tj��|�	�Wd�n1s�0YdS)
NcseZdZ�fdd�ZdS)z;RegressionTests.CheckCursorRegistration.<locals>.Connectioncs�|�Srrr	�rlrrr�szBRegressionTests.CheckCursorRegistration.<locals>.Connection.cursorN)rGrHrIrrrwrrrt�srtc@seZdZdd�ZdS)z7RegressionTests.CheckCursorRegistration.<locals>.CursorcSstj�||�dSr)rrlrjr5rrrrj�sz@RegressionTests.CheckCursorRegistration.<locals>.Cursor.__init__Nrkrrrrrl�srlrzcreate table foo(x)zinsert into foo(x) values (?)))r1)�)rzselect x from foo)
rrtrlrrr%r&rKZInterfaceErrorrnrurrwr�CheckCursorRegistration�s

z'RegressionTests.CheckCursorRegistrationcCstjddd�}dS)NrrY)rrr5rrr�CheckAutoCommitszRegressionTests.CheckAutoCommitcCs4|j��}|�d�|�d�|�d�|��}dS)Nr7r>zpragma page_size)rrrrQ)r
r�rowrrr�CheckPragmaAutocommits




z%RegressionTests.CheckPragmaAutocommitcCs|�t|jd�dS�Nr_)rKrVrr	rrr�CheckConnectionCallsz#RegressionTests.CheckConnectionCallcCs"dd�}|�tj|jjd|�dS)NcSsdSr}r)�a�brrr�collation_cbsz4RegressionTests.CheckCollation.<locals>.collation_cbu�)rKrrmrZcreate_collation)r
r�rrr�CheckCollations�zRegressionTests.CheckCollationcszt�d�}|�����d���d��fdd�}|�tj��(��ddd�|�D��Wd�n1sl0YdS)	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>5r z:RegressionTests.CheckRecursiveCursorUse.<locals>.<genexpr>)rrrrrKrmr%)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rJr zKRegressionTests.CheckConvertTimestampMicrosecondPadding.<locals>.<listcomp>i�rx��ri@�i@�)rrr?rrrnr*r@)r
rr�valuesrrr�'CheckConvertTimestampMicrosecondPadding7s



�z7RegressionTests.CheckConvertTimestampMicrosecondPaddingcCs|jttjddd�dS)Nr�{rY)rKrVrrr	rrr�CheckInvalidIsolationLevelTypeQs�z.RegressionTests.CheckInvalidIsolationLevelTypecCsRt�d�}|�t|d�|�t|d�|��}|�t|jd�|�t|jd�dS)Nrz	select 1z	select 1z
 select 2z	select 2)rrrKrerrrrrr�CheckNullCharacterWs
z"RegressionTests.CheckNullCharacterc	Cs�t�d�}|�d�|�|jd�d}t|�d��D]�\}}|j||d��z|�d|f�|��|dkr||�|dd�n2|dkr�|�|dd�n|d	kr�|�|dd	�|d7}Wd�q41s�0Yq4|�|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(r{zinsert into t2(c) values (?)r_r2r1z'should have returned exactly three rows)	rrZ
executescriptr*rZ�	enumeraterrbr3)r
rZcounterr(r{rrr�CheckCommitCursorReset`s 

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


zRegressionTests.CheckBpo31770cCs4|�t��|j`Wd�n1s&0YdSr)rK�AttributeErrorrrZr	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)rGrHrIr�rrrr�Printer�sr�r_)�nzselect 1)rZset_trace_callback�	functools�partialZset_progress_handlerZset_authorizerr�r)r
r��methodZprinter_instancerrr�
CheckBpo37347�s�

zRegressionTests.CheckBpo37347N)&rGrHrIr
rrrr)r,r0�unittestZskipIfrZsqlite_version_infor6r:r=rArMrUrWrirprrrvryrzr|r~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	s~�fdd�}t�tjd|i��L��tj�j���j�d�Wd�n1sR0YWd�n1sp0YdS)Ncs�j��j�Sr)rrjr�rr	rr�<lambda>�r zBRecursiveUseOfCursors.test_recursive_cursor_init.<locals>.<lambda>ZINITz#select x as "x [INIT]", x from test�	r�dictr�
convertersrormrTrr�r
�convrr	r�test_recursive_cursor_init�sz0RecursiveUseOfCursors.test_recursive_cursor_initc	s~�fdd�}t�tjd|i��L��tj�j���j�d�Wd�n1sR0YWd�n1sp0YdS)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	s�gf�fdd�	}t�tjd|i��V�j�d���tj�j���j�	�Wd�n1s`0YWd�n1s~0YdS)Ncs|r�j��S|�d�Sr)rrQr.)r�lr	rrr��r zCRecursiveUseOfCursors.test_recursive_cursor_fetch.<locals>.<lambda>ZITERz#select x as "x [ITER]", x from test)
rr�rr�rrrormrTrnr�rr	r�test_recursive_cursor_fetch�s
z1RecursiveUseOfCursors.test_recursive_cursor_fetchN)	rGrHrIrTr
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�rGrrrr�<module>s&

Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists