o
    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   sF   t j }tt jj|jj W d    d S 1 sw   Y  d S N)r   dbconnectr   dialectdo_ping
connectiondbapi_connection)selfconn r)   _/var/www/html/api-tag/env/lib/python3.10/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   sZ    t jD ]} | dstd|   qtg}|r+|d}||  |V  |sd S 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__r3   getattrr   r
   varkwr,   )r'   r@   r;   kmeth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@   rI   r)   r)   r)   r*   r0   2   s    
r0   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   (   t d|tdtdddtdtd d S )N	manual_pkidTFprimary_keyautoincrementdata2   r   r   r   r   r;   metadatar)   r)   r*   define_tablesk      zExceptionTest.define_tablesc                 C   sz   t j .}| }|| jj ddd tt	j
|j| jj ddd |  W d    d S 1 s6w   Y  d S )Nr   d1rQ   rU   )r   r!   r"   beginexecutetablesrP   insertr   r   IntegrityErrorrollback)r'   r(   transr)   r)   r*   test_integrity_errort   s   

"z"ExceptionTest.test_integrity_errorc                 C   s   t j >}z|ttd J  tjy3 } zt|}t|j	t|v s)J W Y d }~nd }~ww t
|ts;J W d    d S 1 sFw   Y  d S )Nu   méil)r   r!   r"   r_   r   r   r   
DBAPIErrorstrorig
isinstance)r'   r(   errerr_strr)   r)   r*   test_exception_with_non_ascii   s   ""z+ExceptionTest.test_exception_with_non_asciiN)r,   r-   r.   rJ   run_deletesr/   classmethodrZ   r   $duplicate_key_raises_integrity_errorre   rl   r)   r)   r)   r*   rM   _   s    

rM   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}|r| S td d S )Ndefault	supported
AUTOCOMMITz(no non-default isolation level available)r   get_isolation_levelsr   set
differencer6   	skip_test)r'   levelsrs   rt   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 )Nrs   )r   r   r!   r#   default_isolation_levelr   rv   )r'   r)   r)   r*   test_default_isolation_level   s   z/IsolationLevelTest.test_default_isolation_levelc                 C   s   |   }tj .}| }t|| |j|d t| | |j	|j
j t| | W d    d S 1 s:w   Y  d S )Nrq   )r|   r   r!   r"   get_isolation_levelr   execution_optionsr   r#   reset_isolation_levelr%   r&   )r'   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 ]Q}tj $}|j|d t|	 | |
 }|  t|	 | W d    n1 s?w   Y  tj }t|	 |d  W d    n1 s]w   Y  qd S )Nrt   ru   rq   rs   )r   rv   r   rw   rx   r!   r"   r   r   r   r^   rc   )r'   rz   
all_levelslevelr(   rd   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   dS 1 s)w   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, rt   rq   N)
r   r   ArgumentErrorr#   namejoinr   rv   r   r   )r'   connection_no_transr%   r)   r)   r*   #test_invalid_level_execution_option   s   "z6IsolationLevelTest.test_invalid_level_execution_optionc              
   C   sh   |t ddd}ttjdd|jjdtt	d f  |
  W d   dS 1 s-w   Y  dS )ztest for the new get_isolation_level_values() method
        and support for the dialect-level 'isolation_level' parameter.

        r   rq   optionsr   r   rt   N)dictr   r   r   r#   r   r   r   rv   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 s5w   Y  | }|j	|d t| | W d    n1 sVw   Y  | }t| | W d    d S 1 srw   Y  d S )Nrs   rt   ru   r   rr   r   rq   )
r   rv   r   sortedrw   rx   r"   r   r   r   )r'   r   rz   rs   rt   er(   r)   r)   r*   %test_dialect_user_setting_is_restored   s$   



"z8IsolationLevelTest.test_dialect_user_setting_is_restoredN)r,   r-   r.   r/   __requires__r|   r~   r   r   r   requiresget_isolation_level_valuesr   #dialect_level_isolation_level_paramr    independent_readonly_connectionsr   r)   r)   r)   r*   rp      s    
rp   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 )AutocommitIsolationTestrN   )
autocommitTc              	   C   s,   t d|tdtdddtdtddd d S )	N
some_tablerQ   TFrR   rU   rV   )test_needs_acidrW   rX   r)   r)   r*   rZ     s   
z%AutocommitIsolationTest.define_tablesc                 C   s   |  }|| jj ddd |  t|t| jjj	j
|r$dnd  |  |   || jj  W d    d S 1 sDw   Y  d S )Nr   z	some datar]   )r^   r_   r`   r   ra   rc   r   scalarr   crQ   delete)r'   r(   r   rd   r)   r)   r*   _test_conn_autocommits(  s   

"z.AutocommitIsolationTest._test_conn_autocommitsc                 C   s<   |}|j dd}| |d |j|jj | |d d S )Nru   rq   TF)r   r   r#   r   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 )Nru   rq   Trs   F)r   r   r   rv   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/w   Y  | }|j |d | |d W d   n1 sOw   Y  | }| |d W d   dS 1 sjw   Y  dS )	ztest #10147rr   ru   r   rq   rs   TNF)r   r   rv   r   r"   r   )r'   r   r   r   rz   rs   r(   r)   r)   r*   #test_dialect_autocommit_is_restoredS  s"   



"z;AutocommitIsolationTest.test_dialect_autocommit_is_restoredN)r,   r-   r.   rm   r   r/   rn   rZ   r   r   r   r   r   r   r   	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 I}||	 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	   d	S 1 sew   Y  d	S )
z|test that the DBAPI accommodates for escaped / nonescaped
        percent signs in a way that matches the compiler

        trU   rV   zsome % value)rU   zsome %% other valuez'some % value'z'some %% other value'N)rY   r   r   r   creater   r!   r^   r_   ra   r   r   r   r   r   rU   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)default_schema_name_switchc                 C   sL   t jjj}t }|  W d    n1 sw   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.w   Y  t
|jj| d S )Nr"   c                 S      t t| tj d S r    r   r   test_schemar&   connection_recordr)   r)   r*   
on_connect     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 s+w   Y  t|jj
tj	 d S )Nr"   Tra   c                 S   r   r    r   r   r)   r)   r*   r     r   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 }| (}| }|j|}t|t	j
 |  |j|}t|t	j
 W d    n1 s?w   Y  t|jjt	j
 d S )Nr"   Tr   c                 W   r   r    r   )r&   argr)   r)   r*   r     r   z\WeCanSetDefaultSchemaWEventsTest.test_schema_change_works_w_transactions.<locals>.on_connect)r   r   r   r   r"   r^   r#   r   r   r   r   rc   r   )r'   r   r   r(   rd   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)boring)zper cent)z
per % cent)z%percent)zpar(ens))zpercent%(ens)yah)zcol:ons)_starts_with_underscore)zdot.s)zmore :: %colons%)_name)___name)z[BracketsAndCase])	42numbers)zpercent%signs)z
has spaces)z	/slashes/)zmore/slashes)zq?marks)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   rQ   T)rS   rV   F)nullabler   z	some namezsome other_name)r   r   r   r   r   r_   ra   valuesr   r   r   r   r   r   first_mappingin_)r'   r   r%   rY   r   r   stmtrowr)   r)   r*   !test_round_trip_same_named_column  s$   
"z9DifficultParametersTest.test_round_trip_same_named_columnc              
   c   sx    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   rV   descr   aa_desc)r   r   r   r   bb_descr   r   c_desc   r9   d_desc)r   r   r   r   r   r_   ra   )r'   rY   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   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   r9   r   r   )r   r   r   r   r   r   r   order_byscalarsallr   r   r)   r)   r*   *test_standalone_bindparam_escape_expanding@  s   

zBDifficultParametersTest.test_standalone_bindparam_escape_expandingN)r,   r-   r.   r/   r   combinationstough_parametersr   r   unusual_column_name_charactersr   rK   r   r   r   r)   r)   r)   r*   r     sF    &


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   rO   )Nr   rQ   TFrR   rU   rV   rW   rX   r)   r)   r*   rZ   T  r[   z!ReturningGuardsTest.define_tablesc                    s   | j j fdd}|S )Nc              
      s8  |  jj} |rd|sDttjd jj d jj d  	| |dddi|dddi|d	dd
ig}W d    d S 1 s=w   Y  d S  	| |dddi|dddi|d	dd
ig}t
| g d d S |sttj  	| |dddi W d    d S 1 sw   Y  d S  	| |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   rU   r\   r   d2r   d3)r   )r   )r   r   )	returningr   rQ   r   r   StatementErrorr#   r   driverr_   r   r   r   rf   )r   executemanyid_param_nameexpect_successresultr%   r   r)   r*   goa  sF   


"


"z(ReturningGuardsTest.run_stmt.<locals>.go)r`   r   )r'   r%   r   r)   r   r*   run_stmt]  s   /zReturningGuardsTest.run_stmtc                 C   &   | j j}| }||dd|jj d S )NFrQ   )r`   r   ra   r#   insert_returningr'   r%   r   r   r   r)   r)   r*   test_insert_single  s   z&ReturningGuardsTest.test_insert_singlec                 C   r   )NTrQ   )r`   r   ra   r#   insert_executemany_returningr  r)   r)   r*   test_insert_many  s
   z$ReturningGuardsTest.test_insert_manyc                 C   `   | j j}|| dddddddddg | |jjtdk}||d	d|j	j
 d S 
Nr   r\   r]   r   r   r   r   b_idF)r`   r   r_   ra   updater   r   rQ   r   r#   update_returningr  r)   r)   r*   test_update_single     	z&ReturningGuardsTest.test_update_singlec                 C   r  
Nr   r\   r]   r   r   r   r   r  T)r`   r   r_   ra   r	  r   r   rQ   r   r#   update_executemany_returningr  r)   r)   r*   test_update_many     	z$ReturningGuardsTest.test_update_manyc                 C   r  r  )r`   r   r_   ra   r   r   r   rQ   r   r#   delete_returningr  r)   r)   r*   test_delete_single  r  z&ReturningGuardsTest.test_delete_singlec                 C   r  r  )r`   r   r_   ra   r   r   r   rQ   r   r#   delete_executemany_returningr  r)   r)   r*   test_delete_many  r  z$ReturningGuardsTest.test_delete_manyN)r,   r-   r.   rJ   r/   rn   rZ   r   rK   r   r  r  r  r  r  r  r)   r)   r)   r*   r   O  s    

4	r   ).r4    r   r   r   r   r   r	   r
   r   r   r   
assertionsr   r   r   	provisionr   schemar   r   r   r   r   r   r   r   r   r   sql.compilerr   utilr   TestBaser   r0   
TablesTestrM   rp   r   r   r   FutureEngineMixinr   r   r   r)   r)   r)   r*   <module>   sP   	
-8 Y!
Cu