a
    [gY                     @   s  d dl Z ddlmZ ddlmZ ddlmZ ddlmZ ddlmZ dd	lmZ dd
lmZ ddlm	Z	 ddlm
Z
 ddlmZ ddlmZ ddlmZ ddlmZ ddlmZ ddlmZ ddlmZ ddlmZ ddlmZ ddlmZ ddlmZ ddlmZ ddlmZ ddlmZ ddlmZ ddlmZ ddlm Z  G dd  d ej!Z"G d!d" d"ej!Z#G d#d$ d$ej$Z%G d%d& d&ej!Z&G d'd( d(ej$Z'G d)d* d*ej!Z(G d+d, d,ej!Z)G d-d. d.ej*e)Z+G d/d0 d0ej!Z,G d1d2 d2ej$Z-dS )3    N   )testing   )assert_raises)config)engines)eq_)fixtures)is_not_none)is_true)ne_)provide_metadata)expect_raises)expect_raises_message)requirements) set_default_schema_on_connection)Column)Table   )	bindparam)dialects)event)exc)Integer)literal_column)select)String)Compiled)inspect_getfullargspecc                   @   s   e Zd ZdZdd ZdS )PingTestTc                 C   sD   t j &}tt jj|jj W d    n1 s60    Y  d S N)r   dbconnectr   dialectZdo_ping
connectiondbapi_connection)selfconn r(   s/var/www/html/cobodadashboardai.evdpl.com/venv/lib/python3.9/site-packages/sqlalchemy/testing/suite/test_dialect.pytest_do_ping+   s    zPingTest.test_do_pingN)__name__
__module____qualname____backend__r*   r(   r(   r(   r)   r   (   s   r   c                   @   s:   e Zd ZdZdd Zejee ddd Zdd Z	d	S )
ArgSignatureTesta  test that all visit_XYZ() in :class:`_sql.Compiler` subclasses have
    ``**kw``, for #8988.

    This test uses runtime code inspection.   Does not need to be a
    ``__backend__`` test as it only needs to run once provided all target
    dialects have been imported.

    For third party dialects, the suite would be run with that third
    party as a "--dburi", which means its compiler classes will have been
    imported by the time this test runs.

    c                  c   sR   t jD ]} | dstd|   qtg}|rN|d}||  |V  q*d S )N_zsqlalchemy.dialects.%sr   )	r   __all__
startswith	importlibimport_moduler   popextend__subclasses__)dstackclsr(   r(   r)   _all_subclasses@   s    


z ArgSignatureTest._all_subclasses)paramsc                 c   s   |j V  d S r    )param)r&   requestr(   r(   r)   all_subclassesL   s    zArgSignatureTest.all_subclassesc                 C   sL   |}|j D ]<}|dr
t||}t|}t|jd|j d| d q
d S )Nvisit_zCompiler visit method .z:() does not accommodate for **kw in its argument signature)__dict__r2   getattrr   r
   varkwr+   )r&   r?   r:   kmethZinspr(   r(   r)    test_all_visit_methods_accept_kwP   s    


z1ArgSignatureTest.test_all_visit_methods_accept_kwN)
r+   r,   r-   __doc__r;   r   fixturelistr?   rG   r(   r(   r(   r)   r/   2   s
   
r/   c                   @   s:   e Zd ZdZdZdZedd Zej	dd Z
dd	 Zd
S )ExceptionTestzTest basic exception wrapping.

    DBAPIs vary a lot in exception behavior so to actually anticipate
    specific exceptions from real round trips, we need to be conservative.

    eachTc              	   C   s(   t d|tdtdddtdtd d S )N	manual_pkidTFprimary_keyZautoincrementdata2   r   r   r   r   r:   metadatar(   r(   r)   define_tablesk   s    zExceptionTest.define_tablesc                 C   sx   t j Z}| }|| jj ddd tt	j
|j| jj ddd |  W d    n1 sj0    Y  d S )Nr   d1rN   rQ   )r   r!   r"   beginexecutetablesrM   insertr   r   ZIntegrityErrorrollback)r&   r'   transr(   r(   r)   test_integrity_errort   s    
z"ExceptionTest.test_integrity_errorc                 C   s   t j }z|ttd ds(J W nD tjyn } z*t|}t|j	t|v sZJ W Y d }~n
d }~0 0 t
|ts~J W d    n1 s0    Y  d S )Nu   méilF)r   r!   r"   rZ   r   r   r   
DBAPIErrorstrorig
isinstance)r&   r'   errZerr_strr(   r(   r)   test_exception_with_non_ascii   s    ,z+ExceptionTest.test_exception_with_non_asciiN)r+   r,   r-   rH   run_deletesr.   classmethodrV   r   Z$duplicate_key_raises_integrity_errorr_   re   r(   r(   r(   r)   rK   _   s   

rK   c                   @   sl   e Zd ZdZdZdd Zdd Zdd Zd	d
 Ze	j
jdd Ze	j
je	j
jdd Ze	j
jdd ZdS )IsolationLevelTestTisolation_levelc                 C   sF   t t}|d }|d }t|d|g}|r8| S td d S )Ndefault	supported
AUTOCOMMITz(no non-default isolation level available)r   get_isolation_levelsr   set
differencer5   Z	skip_test)r&   levelsrk   rl   sr(   r(   r)    _get_non_default_isolation_level   s    
z3IsolationLevelTest._get_non_default_isolation_levelc                 C   s   t tjjjttd  d S )Nrk   )r   r   r!   r#   Zdefault_isolation_levelr   rn   )r&   r(   r(   r)   test_default_isolation_level   s    z/IsolationLevelTest.test_default_isolation_levelc                 C   s   |   }tj Z}| }t|| |j|d t| | |j	|j
j t| | W d    n1 sr0    Y  d S )Nri   )rs   r   r!   r"   get_isolation_levelr   execution_optionsr   r#   reset_isolation_levelr$   r%   )r&   Znon_defaultr'   existingr(   r(   r)    test_non_default_isolation_level   s    
z3IsolationLevelTest.test_non_default_isolation_levelc              	   C   s   t t}|d }t|dgD ]}tj H}|j|d t|	 | |
 }|  t|	 | W d    n1 s~0    Y  tj "}t|	 |d  W d    q"1 s0    Y  q"d S )Nrl   rm   ri   rk   )r   rn   r   ro   rp   r!   r"   rv   r   ru   rY   r]   )r&   rq   Z
all_levelslevelr'   r^   r(   r(   r)   test_all_levels   s    
,z"IsolationLevelTest.test_all_levelsc              
   C   s^   |}t tjdd|jjdttd f  |j	dd W d   n1 sP0    Y  dS )z4test for the new get_isolation_level_values() methodNInvalid value '%s' for isolation_level. Valid isolation levels for '%s' are %sFOO, rl   ri   N)
r   r   ArgumentErrorr#   namejoinr   rn   r   rv   )r&   connection_no_transr$   r(   r(   r)   #test_invalid_level_execution_option   s    z6IsolationLevelTest.test_invalid_level_execution_optionc              
   C   sf   |t ddd}ttjdd|jjdtt	d f  |
  W d   n1 sX0    Y  dS )ztest for the new get_isolation_level_values() method
        and support for the dialect-level 'isolation_level' parameter.

        r}   ri   optionsr|   r~   rl   N)dictr   r   r   r#   r   r   r   rn   r   r"   )r&   testing_engineengr(   r(   r)   test_invalid_level_engine_param   s    z2IsolationLevelTest.test_invalid_level_engine_paramc                 C   s   t t}|d }tt|d |dgd }|d|id}| }t| | W d    n1 sj0    Y  | *}|j	|d t| | W d    n1 s0    Y  | }t| | W d    n1 s0    Y  d S )Nrk   rl   rm   r   rj   r   ri   )
r   rn   r   sortedro   rp   r"   r   ru   rv   )r&   r   rq   rk   rl   er'   r(   r(   r)   %test_dialect_user_setting_is_restored   s    

,
,
z8IsolationLevelTest.test_dialect_user_setting_is_restoredN)r+   r,   r-   r.   __requires__rs   rt   ry   r{   r   requiresZget_isolation_level_valuesr   Z#dialect_level_isolation_level_paramr    independent_readonly_connectionsr   r(   r(   r(   r)   rh      s   
rh   c                   @   sd   e Zd ZdZdZdZedd Zdd Zdd	 Z	d
d Z
dd Zejjedddgdd ZdS )AutocommitIsolationTestrL   )
autocommitTc              	   C   s,   t d|tdtdddtdtddd d S )	N
some_tablerN   TFrO   rQ   rR   )Ztest_needs_acidrS   rT   r(   r(   r)   rV     s    z%AutocommitIsolationTest.define_tablesc                 C   s   |  }|| jj ddd |  t|t| jjj	j
|rHdnd  |  |  " || jj  W d    n1 s0    Y  d S )Nr   z	some datarX   )rY   rZ   r[   r   r\   r]   r   scalarr   crN   delete)r&   r'   r   r^   r(   r(   r)   _test_conn_autocommits(  s    

z.AutocommitIsolationTest._test_conn_autocommitsc                 C   s<   |}|j dd}| |d |j|jj | |d d S )Nrm   ri   TF)rv   r   r#   rw   r$   r%   )r&   r   r'   c2r(   r(   r)   test_autocommit_on8  s
    z*AutocommitIsolationTest.test_autocommit_onc                 C   s   |}|  |d d S )NF)r   r&   r   r'   r(   r(   r)   test_autocommit_offA  s    z+AutocommitIsolationTest.test_autocommit_offc                 C   sB   |}|j dd}| |d |j ttd d | |d d S )Nrm   ri   Trk   F)rv   r   r   rn   r   r   r(   r(   r)   .test_turn_autocommit_off_via_default_iso_levelE  s    zFAutocommitIsolationTest.test_turn_autocommit_off_via_default_iso_leveluse_dialect_settingFc                 C   s   |r|ddid}n| j dd}tt}|d }| }| |d W d   n1 s^0    Y  | (}|j |d | |d W d   n1 s0    Y  | }| |d W d   n1 s0    Y  dS )	ztest #10147rj   rm   r   ri   rk   TNF)rv   r   rn   r   r"   r   )r&   r   r   r   rq   rk   r'   r(   r(   r)   #test_dialect_autocommit_is_restoredS  s    

*
*
z;AutocommitIsolationTest.test_dialect_autocommit_is_restoredN)r+   r,   r-   rf   r   r.   rg   rV   r   r   r   r   r   r   r   Z	variationr   r(   r(   r(   r)   r     s   
		r   c                   @   s   e Zd Zedd ZdS )EscapingTestc              	   C   s   | j }td|tdtd}|tj tj }||	 t
dd ||	 t
dd t|t|jj|jjtdkd t|t|jj|jjtdkd W d	   n1 s0    Y  d	S )
z|test that the DBAPI accommodates for escaped / nonescaped
        percent signs in a way that matches the compiler

        trQ   rR   zsome % value)rQ   zsome %% other valuez'some % value'z'some %% other value'N)rU   r   r   r   creater   r!   rY   rZ   r\   r   r   r   r   r   rQ   wherer   )r&   mr   r'   r(   r(   r)   test_percent_sign_round_tripq  s,    	z)EscapingTest.test_percent_sign_round_tripN)r+   r,   r-   r   r   r(   r(   r(   r)   r   p  s   r   c                   @   s4   e Zd ZdZdZdd Zdd Zdd Zd	d
 ZdS ) WeCanSetDefaultSchemaWEventsTestT)Zdefault_schema_name_switchc                 C   sL   t jjj}t }|  W d    n1 s00    Y  t|jj| d S r    )r   r!   r#   default_schema_namer   r   r"   r   )r&   r   r   r(   r(   r)   test_control_case  s
    

z2WeCanSetDefaultSchemaWEventsTest.test_control_casec                 C   sx   t jjj}t }t|ddd }| (}|j	|}t
|t j W d    n1 s\0    Y  t
|jj| d S )Nr"   c                 S   s   t t| tj d S r    r   r   test_schemar%   Zconnection_recordr(   r(   r)   
on_connect  s    zMWeCanSetDefaultSchemaWEventsTest.test_wont_work_wo_insert.<locals>.on_connect)r   r!   r#   r   r   r   r   listens_forr"   _get_default_schema_namer   r   )r&   r   r   r   r'   what_it_should_ber(   r(   r)   test_wont_work_wo_insert  s    



*z9WeCanSetDefaultSchemaWEventsTest.test_wont_work_wo_insertc                 C   st   t  }tj|ddddd }| (}|j|}t|tj	 W d    n1 sV0    Y  t|jj
tj	 d S )Nr"   Tr\   c                 S   s   t t| tj d S r    r   r   r(   r(   r)   r     s    zRWeCanSetDefaultSchemaWEventsTest.test_schema_change_on_connect.<locals>.on_connect)r   r   r   r   r"   r#   r   r   r   r   r   )r&   r   r   r'   r   r(   r(   r)   test_schema_change_on_connect  s    

*z>WeCanSetDefaultSchemaWEventsTest.test_schema_change_on_connectc                 C   s   t  }tj|ddddd }| P}| }|j|}t|t	j
 |  |j|}t|t	j
 W d    n1 s~0    Y  t|jjt	j
 d S )Nr"   Tr   c                 W   s   t t| tj d S r    r   )r%   argr(   r(   r)   r     s    z\WeCanSetDefaultSchemaWEventsTest.test_schema_change_works_w_transactions.<locals>.on_connect)r   r   r   r   r"   rY   r#   r   r   r   r   r]   r   )r&   r   r   r'   r^   r   r(   r(   r)   'test_schema_change_works_w_transactions  s    

*zHWeCanSetDefaultSchemaWEventsTest.test_schema_change_works_w_transactionsN)	r+   r,   r-   r.   r   r   r   r   r   r(   r(   r(   r)   r     s   	r   c                   @   s   e Zd ZdS )&FutureWeCanSetDefaultSchemaWEventsTestN)r+   r,   r-   r(   r(   r(   r)   r     s   r   c                   @   s   e Zd ZdZejdddddddd	d
ddddddddddddddZeejj	dd Z
ejdd Zedd Zedd  Zd!S )"DifficultParametersTestT)Zboring)zper cent)z
per % cent)z%percent)zpar(ens))zpercent%(ens)yah)zcol:ons)Z_starts_with_underscore)zdot.s)zmore :: %colons%)_name)Z___name)z[BracketsAndCase])Z	42numbers)zpercent%signs)z
has spaces)z	/slashes/)zmore/slashes)zq?marks)Z1param)z1col:on	paramname)argnamesc              	   C   s   |}t d|tdtddt|tddd}|| || dd|d	i t|j	| 
|j	| d	k}t||d	 t|j	| 
|j	| t|k}|||d	i }t|j| d	 t|j	| 
|j	| d	d
g}|| }d S )Nr   rN   T)rP   rR   F)Znullabler   z	some namezsome other_name)r   r   r   r   r   rZ   r\   valuesr   r   r   r   r   r   first_mappingin_)r&   r   r$   rU   r   r   stmtrowr(   r(   r)   !test_round_trip_same_named_column  s$    
"z9DifficultParametersTest.test_round_trip_same_named_columnc              
   c   sv   t d|tdttdtdtdtd}|| || dddd	d
ddd	dddd	dddd	g |V  d S )Nmytablemyidr   rR   descr   aZa_desc)r   r   r   r   bZb_descr   r   Zc_desc   r8   Zd_desc)r   r   r   r   r   rZ   r\   )r&   rU   r$   r   r(   r(   r)   multirow_fixture  s"    




	z(DifficultParametersTest.multirow_fixturec                 C   sD   |}t |jj|jjt|ddk}|||di}t|d d S )Nxvaluer   r   )r   r   r   r   r   r   r   r   r&   r   r$   r   Ztbl1r   resr(   r(   r)    test_standalone_bindparam_escape5  s    z8DifficultParametersTest.test_standalone_bindparam_escapec                 C   s`   |}t |jj|jjt|ddgd|jj}|||ddgi	 }t
|ddg d S )Nr   r   r   r8   r   r   )r   r   r   r   r   r   r   Zorder_byZscalarsallr   r   r(   r(   r)   *test_standalone_bindparam_escape_expanding@  s    zBDifficultParametersTest.test_standalone_bindparam_escape_expandingN)r+   r,   r-   r.   r   combinationsZtough_parametersr   r   Zunusual_column_name_charactersr   rI   r   r   r   r(   r(   r(   r)   r     sD   &


r   c                   @   s^   e Zd ZdZdZedd Zejdd Z	dd Z
d	d
 Zdd Zdd Zdd Zdd ZdS )ReturningGuardsTestz=test that the various 'returning' flags are set appropriatelyTc              	   C   s(   t d|tdtdddtdtd d S )Nr   rN   TFrO   rQ   rR   rS   rT   r(   r(   r)   rV   T  s    z!ReturningGuardsTest.define_tablesc                    s   | j j fdd}|S )Nc              
      s0  |  jj} |r|sttjd jj d jj d:  	| |dddi|dddi|d	dd
ig}W d    q1 sx0    Y  n< 	| |dddi|dddi|d	dd
ig}t
| g d nj|sttj$  	| |dddi W d    n1 s0    Y  n$ 	| |dddi}t
| dg d S )NzDialect z\+zW with current server capabilities does not support .*RETURNING when executemany is usedr   rQ   rW   r   d2r   d3)r   )r   )r   r   )Z	returningr   rN   r   r   ZStatementErrorr#   r   ZdriverrZ   r   r   r   r`   )r   ZexecutemanyZid_param_nameZexpect_successresultr$   r   r(   r)   goa  sB    


$	


$z(ReturningGuardsTest.run_stmt.<locals>.go)r[   r   )r&   r$   r   r(   r   r)   run_stmt]  s    /zReturningGuardsTest.run_stmtc                 C   s&   | j j}| }||dd|jj d S )NFrN   )r[   r   r\   r#   Zinsert_returningr&   r$   r   r   r   r(   r(   r)   test_insert_single  s    z&ReturningGuardsTest.test_insert_singlec                 C   s&   | j j}| }||dd|jj d S )NTrN   )r[   r   r\   r#   Zinsert_executemany_returningr   r(   r(   r)   test_insert_many  s
    z$ReturningGuardsTest.test_insert_manyc                 C   s`   | j j}|| dddddddddg | |jjtdk}||d	d|j	j
 d S 
Nr   rW   rX   r   r   r   r   b_idF)r[   r   rZ   r\   updater   r   rN   r   r#   Zupdate_returningr   r(   r(   r)   test_update_single  s    	z&ReturningGuardsTest.test_update_singlec                 C   s`   | j j}|| dddddddddg | |jjtdk}||d	d|j	j
 d S 
Nr   rW   rX   r   r   r   r   r   T)r[   r   rZ   r\   r   r   r   rN   r   r#   Zupdate_executemany_returningr   r(   r(   r)   test_update_many  s    	z$ReturningGuardsTest.test_update_manyc                 C   s`   | j j}|| dddddddddg | |jjtdk}||d	d|j	j
 d S r   )r[   r   rZ   r\   r   r   r   rN   r   r#   Zdelete_returningr   r(   r(   r)   test_delete_single  s    	z&ReturningGuardsTest.test_delete_singlec                 C   s`   | j j}|| dddddddddg | |jjtdk}||d	d|j	j
 d S r   )r[   r   rZ   r\   r   r   r   rN   r   r#   Zdelete_executemany_returningr   r(   r(   r)   test_delete_many  s    	z$ReturningGuardsTest.test_delete_manyN)r+   r,   r-   rH   r.   rg   rV   r   rI   r   r   r   r   r   r   r   r(   r(   r(   r)   r   O  s   

4	r   ).r3    r   r   r   r   r   r	   r
   r   r   r   Z
assertionsr   r   r   Z	provisionr   Zschemar   r   r   r   r   r   r   r   r   r   Zsql.compilerr   utilr   ZTestBaser   r/   Z
TablesTestrK   rh   r   r   r   ZFutureEngineMixinr   r   r   r(   r(   r(   r)   <module>
   sN   
-8 Y!C
u