???<!-- GIF89;a -->
123123123123
.....................................................................................................................................???<!-- GIF89;a -->
123123123123
.....................................................................................................................................3

  \:                 @   s   d Z ddlZddlZddlZddlZddlZddlZddlZddlZddl	Z	ddl
Z
ddlZddlZddlZddlZddlmZ ddlmZ ddlmZmZ yddlZW n ek
r   dZY nX 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# e	j$dkrHddl%m&Z& nddlm&Z& dd Z'e'dZ(e'dZ)dd Z*dd Z+dRddZ,dd Z-G dd  d eZ.G d!d" d"eZ/G d#d$ d$Z0G d%d& d&e0e/Z1d'd(d)d*Z2e3ed+rZG d,d- d-ej4eZ5G d.d/ d/e5eZ6G d0d1 d1e6Z7G d2d3 d3e0e7Z8d4d5 Z9ej:d6d7 Z;ej:d'd(d8d9Z<ej:d:dd'd;d<d=Z=d>d? Z>G d@dA dAej?Z@G dBdC dCejAZBdDdE ZCG dFdG dGeDZEdHdI ZFG dJdK dKejGZGej:dLdM ZHejIejJejKfdNdOZLdPdQ ZMdS )SzUtilities shared by tests.    N)mock)
HTTPServer)WSGIRequestHandler
WSGIServer   )base_events)compat)events)futures)	selectors)tasks)	coroutine)logger)supportZwin32)
socketpairc             C   s`   t tdr*tjjtj| }tjj|r*|S tjjtjjtjd| }tjj|rT|S t	| d S )NTEST_HOME_DIRtest)
hasattrr   ospathjoinr   isfiledirname__file__FileNotFoundError)filenamefullname r   */usr/lib64/python3.6/asyncio/test_utils.py	data_file-   s    
r   zssl_cert.pemzssl_key.pemc               C   s   t d krd S t jt jS d S )N)ssl
SSLContextZPROTOCOL_SSLv23r   r   r   r   dummy_ssl_context<   s    r"   c          
   C   s@   t dd }| }| j|}d|_z| j| W d |j  X d S )Nc               S   s   d S )Nr   r   r   r   r   onceD   s    zrun_briefly.<locals>.onceF)r   Zcreate_taskZ_log_destroy_pendingrun_until_completeclose)loopr#   gentr   r   r   run_brieflyC   s    
r)      c             C   sT   t j  | }xB| sN|d k	r8|t j   }|dkr8tj | jtjd| d qW d S )Nr   gMbP?)r&   )timer
   TimeoutErrorr$   r   Zsleep)r&   ZpredtimeoutZdeadliner   r   r   	run_untilR   s    r.   c             C   s   | j | j | j  dS )zLegacy API to run once through the event loop.

    This is the recommended pattern for test code.  It will poll the
    selector once and run all callbacks scheduled in response to I/O
    events.
    N)Z	call_soonstopZrun_forever)r&   r   r   r   run_once\   s    r0   c               @   s   e Zd Zdd Zdd ZdS )SilentWSGIRequestHandlerc             C   s   t j S )N)ioStringIO)selfr   r   r   
get_stderri   s    z#SilentWSGIRequestHandler.get_stderrc             G   s   d S )Nr   )r4   formatargsr   r   r   log_messagel   s    z$SilentWSGIRequestHandler.log_messageN)__name__
__module____qualname__r5   r8   r   r   r   r   r1   g   s   r1   c                   s(   e Zd ZdZ fddZdd Z  ZS )SilentWSGIServer   c                s"   t  j \}}|j| j ||fS )N)superget_request
settimeoutrequest_timeout)r4   requestclient_addr)	__class__r   r   r?   t   s    zSilentWSGIServer.get_requestc             C   s   d S )Nr   )r4   rB   client_addressr   r   r   handle_errory   s    zSilentWSGIServer.handle_error)r9   r:   r;   rA   r?   rF   __classcell__r   r   )rD   r   r<   p   s   r<   c               @   s   e Zd Zdd ZdS )SSLWSGIServerMixinc             C   s^   t }t}tj }|j|| |j|dd}y| j|||  |j  W n tk
rX   Y nX d S )NT)Zserver_side)	ONLYKEYONLYCERTr    r!   Zload_cert_chainZwrap_socketZRequestHandlerClassr%   OSError)r4   rB   rE   ZkeyfileZcertfilecontextZssockr   r   r   finish_request   s    z!SSLWSGIServerMixin.finish_requestN)r9   r:   r;   rM   r   r   r   r   rH   }   s   rH   c               @   s   e Zd ZdS )SSLWSGIServerN)r9   r:   r;   r   r   r   r   rN      s   rN   F)use_sslc          
   #   sv   dd }|r|n|}|| t   j|  j _tj fddd}|j  z
 V  W d  j   j  |j	  X d S )Nc             S   s   d}dg}||| dgS )Nz200 OKContent-type
text/plains   Test message)rP   rQ   r   )environZstart_responseZstatusZheadersr   r   r   app   s    
z_run_test_server.<locals>.appc                  s    j ddS )Ng?)Zpoll_interval)Zserve_foreverr   )httpdr   r   <lambda>   s    z"_run_test_server.<locals>.<lambda>)target)
r1   Zset_appZserver_addressaddress	threadingZThreadstartshutdownZserver_closer   )rW   rO   
server_clsserver_ssl_clsrS   Zserver_classZserver_threadr   )rT   r   _run_test_server   s    


r]   ZAF_UNIXc               @   s   e Zd Zdd ZdS )UnixHTTPServerc             C   s   t jj|  d| _d| _d S )Nz	127.0.0.1P   )socketserverUnixStreamServerserver_bindZserver_nameZserver_port)r4   r   r   r   rb      s    zUnixHTTPServer.server_bindN)r9   r:   r;   rb   r   r   r   r   r^      s   r^   c                   s(   e Zd ZdZdd Z fddZ  ZS )UnixWSGIServerr=   c             C   s   t j|  | j  d S )N)r^   rb   Zsetup_environ)r4   r   r   r   rb      s    
zUnixWSGIServer.server_bindc                s"   t  j \}}|j| j |dfS )N	127.0.0.1 )rd   re   )r>   r?   r@   rA   )r4   rB   rC   )rD   r   r   r?      s    zUnixWSGIServer.get_request)r9   r:   r;   rA   rb   r?   rG   r   r   )rD   r   rc      s   rc   c               @   s   e Zd Zdd ZdS )SilentUnixWSGIServerc             C   s   d S )Nr   )r4   rB   rE   r   r   r   rF      s    z!SilentUnixWSGIServer.handle_errorN)r9   r:   r;   rF   r   r   r   r   rf      s   rf   c               @   s   e Zd ZdS )UnixSSLWSGIServerN)r9   r:   r;   r   r   r   r   rg      s   rg   c           	   C   s   t j } | jS Q R X d S )N)tempfileZNamedTemporaryFilename)filer   r   r   gen_unix_socket_path   s    
rk   c              c   s<   t  } z
| V  W d ytj|  W n tk
r4   Y nX X d S )N)rk   r   unlinkrK   )r   r   r   r   unix_socket_path   s    
rm   c             c   s,   t  }t|| ttdE d H  W d Q R X d S )N)rW   rO   r[   r\   )rm   r]   rf   rg   )rO   r   r   r   r   run_test_unix_server   s    rn   z	127.0.0.1)hostportrO   c             c   s   t | |f|ttdE d H  d S )N)rW   rO   r[   r\   )r]   r<   rN   )ro   rp   rO   r   r   r   run_test_server   s    
rq   c             C   sP   i }x4t | D ](}|jdr(|jdr(qtd d||< qW td| f| j | S )N__)return_valueZTestProtocol)dir
startswithendswithMockCallbacktype	__bases__)baseZdctri   r   r   r   make_test_protocol   s    r{   c               @   s6   e Zd Zdd ZdddZdd Zdd	 Zd
d ZdS )TestSelectorc             C   s
   i | _ d S )N)keys)r4   r   r   r   __init__  s    zTestSelector.__init__Nc             C   s   t j|d||}|| j|< |S )Nr   )r   ZSelectorKeyr}   )r4   fileobjr	   datakeyr   r   r   register  s    
zTestSelector.registerc             C   s   | j j|S )N)r}   pop)r4   r   r   r   r   
unregister  s    zTestSelector.unregisterc             C   s   g S )Nr   )r4   r-   r   r   r   select  s    zTestSelector.selectc             C   s   | j S )N)r}   )r4   r   r   r   get_map  s    zTestSelector.get_map)N)r9   r:   r;   r~   r   r   r   r   r   r   r   r   r|     s
   
r|   c                   s   e Zd ZdZd- fdd	Zdd Zdd Z fd	d
Zdd Zdd Z	dd Z
dd Zdd Zdd Zdd Zdd Zdd Zdd Zdd  Zd!d" Zd#d$ Z fd%d&Z fd'd(Zd)d* Zd+d, Z  ZS ).TestLoopa  Loop for unittests.

    It manages self time directly.
    If something scheduled to be executed later then
    on next loop iteration after all ready handlers done
    generator passed to __init__ is calling.

    Generator should be like this:

        def gen():
            ...
            when = yield ...
            ... = yield time_advance

    Value returned by yield is absolute time of next scheduled handler.
    Value passed to yield is time advance to move loop's time forward.
    Nc                sv   t  j  |d kr"dd }d| _nd| _| | _t| j d| _d| _g | _t | _	i | _
i | _| j  tj | _d S )Nc               s   s
   d V  d S )Nr   r   r   r   r   r'   ,  s    zTestLoop.__init__.<locals>.genFTr   g&.>)r>   r~   _check_on_close_gennext_timeZ_clock_resolution_timersr|   Z	_selectorreaderswritersreset_countersweakrefWeakValueDictionary_transports)r4   r'   )rD   r   r   r~   (  s    

zTestLoop.__init__c             C   s   | j S )N)r   )r4   r   r   r   r+   ?  s    zTestLoop.timec             C   s   |r|  j |7  _ dS )zMove test time forward.N)r   )r4   advancer   r   r   advance_timeB  s    zTestLoop.advance_timec                sB   t  j  | jr>y| jjd W n tk
r4   Y n
X tdd S )Nr   zTime generator is not finished)r>   r%   r   r   sendStopIterationAssertionError)r4   )rD   r   r   r%   G  s    
zTestLoop.closec             G   s   t j||| | j|< d S )N)r	   Handler   )r4   fdcallbackr7   r   r   r   _add_readerQ  s    zTestLoop._add_readerc             C   s0   | j |  d7  < || jkr(| j|= dS dS d S )Nr   TF)remove_reader_countr   )r4   r   r   r   r   _remove_readerT  s
    
zTestLoop._remove_readerc             G   sh   || j krtd| d| j | }|j|krDtd|j d| |j|krdtd|j d| d S )Nzfd z is not registeredzunexpected callback: z != zunexpected callback args: )r   r   Z	_callbackZ_args)r4   r   r   r7   handler   r   r   assert_reader\  s    



zTestLoop.assert_readerc             C   s   || j krtd| dd S )Nzfd z is registered)r   r   )r4   r   r   r   r   assert_no_readerg  s    
zTestLoop.assert_no_readerc             G   s   t j||| | j|< d S )N)r	   r   r   )r4   r   r   r7   r   r   r   _add_writerk  s    zTestLoop._add_writerc             C   s0   | j |  d7  < || jkr(| j|= dS dS d S )Nr   TF)remove_writer_countr   )r4   r   r   r   r   _remove_writern  s
    
zTestLoop._remove_writerc             G   s   | j | }d S )N)r   )r4   r   r   r7   r   r   r   r   assert_writerv  s    
zTestLoop.assert_writerc             C   s8   y| j | }W n tk
r"   Y nX tdj||d S )Nz.File descriptor {!r} is used by transport {!r})r   KeyErrorRuntimeErrorr6   )r4   r   Z	transportr   r   r   _ensure_fd_no_transport~  s    z TestLoop._ensure_fd_no_transportc             G   s   | j | | j||f| S )zAdd a reader callback.)r   r   )r4   r   r   r7   r   r   r   
add_reader  s    
zTestLoop.add_readerc             C   s   | j | | j|S )zRemove a reader callback.)r   r   )r4   r   r   r   r   remove_reader  s    
zTestLoop.remove_readerc             G   s   | j | | j||f| S )zAdd a writer callback..)r   r   )r4   r   r   r7   r   r   r   
add_writer  s    
zTestLoop.add_writerc             C   s   | j | | j|S )zRemove a writer callback.)r   r   )r4   r   r   r   r   remove_writer  s    
zTestLoop.remove_writerc             C   s   t jt| _t jt| _d S )N)collectionsdefaultdictintr   r   )r4   r   r   r   r     s    zTestLoop.reset_countersc                s:   t  j  x$| jD ]}| jj|}| j| qW g | _d S )N)r>   	_run_oncer   r   r   r   )r4   whenr   )rD   r   r   r     s
    
zTestLoop._run_oncec                s    | j j| t j||f| S )N)r   appendr>   call_at)r4   r   r   r7   )rD   r   r   r     s    zTestLoop.call_atc             C   s   d S )Nr   )r4   Z
event_listr   r   r   _process_events  s    zTestLoop._process_eventsc             C   s   d S )Nr   )r4   r   r   r   _write_to_self  s    zTestLoop._write_to_self)N)r9   r:   r;   __doc__r~   r+   r   r%   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   rG   r   r   )rD   r   r     s,   

r   c              K   s   t jf ddgi| S )Nspec__call__)r   ZMock)kwargsr   r   r   rw     s    rw   c               @   s   e Zd ZdZdd ZdS )MockPatternzA regex based str with a fuzzy __eq__.

    Use this helper with 'mock.assert_called_with', or anywhere
    where a regex comparison between strings is needed.

    For instance:
       mock_call.assert_called_with(MockPattern('spam.*ham'))
    c             C   s   t tjt| |tjS )N)boolresearchstrS)r4   otherr   r   r   __eq__  s    zMockPattern.__eq__N)r9   r:   r;   r   r   r   r   r   r   r     s   r   c             C   s$   t j| }|d kr td| f |S )Nzunable to get the source of %r)r	   Z_get_function_source
ValueError)funcsourcer   r   r   get_function_source  s    
r   c               @   sV   e Zd Zedd ZddddZddd	Zd
d Zdd Zdd Z	e
jsRdd ZdS )TestCasec             C   s&   | j }|d k	r|jdd | j  d S )NT)wait)Z_default_executorrZ   r%   )r&   Zexecutorr   r   r   
close_loop  s    zTestCase.close_loopT)cleanupc            C   s    t jd  |r| j| j| d S )N)r	   set_event_loopZ
addCleanupr   )r4   r&   r   r   r   r   r     s    
zTestCase.set_event_loopNc             C   s   t |}| j| |S )N)r   r   )r4   r'   r&   r   r   r   new_test_loop  s    
zTestCase.new_test_loopc             C   s   | j t_ d S )N)_get_running_loopr	   )r4   r   r   r   unpatch_get_running_loop  s    z!TestCase.unpatch_get_running_loopc             C   s    t j| _dd t _tj | _d S )Nc               S   s   d S )Nr   r   r   r   r   rU     s    z TestCase.setUp.<locals>.<lambda>)r	   r   r   Zthreading_setup_thread_cleanup)r4   r   r   r   setUp  s    
zTestCase.setUpc             C   sB   | j   tjd  | jtj d | j  tj| j	  tj
  d S )N)NNN)r   r	   r   ZassertEqualsysexc_infoZ
doCleanupsr   Zthreading_cleanupr   Zreap_children)r4   r   r   r   tearDown  s    
zTestCase.tearDownc             O   s   G dd d}| S )Nc               @   s   e Zd Zdd Zdd ZdS )z!TestCase.subTest.<locals>.EmptyCMc             S   s   d S )Nr   )r4   r   r   r   	__enter__  s    z+TestCase.subTest.<locals>.EmptyCM.__enter__c             W   s   d S )Nr   )r4   excr   r   r   __exit__  s    z*TestCase.subTest.<locals>.EmptyCM.__exit__N)r9   r:   r;   r   r   r   r   r   r   EmptyCM  s   r   r   )r4   r7   r   r   r   r   r   subTest  s    zTestCase.subTest)N)r9   r:   r;   staticmethodr   r   r   r   r   r   r   ZPY34r   r   r   r   r   r     s   
r   c              c   s2   t j} zt jtjd  dV  W dt j|  X dS )zrContext manager to disable asyncio logger.

    For example, it can be used to ignore warnings in debug mode.
    r   N)r   levelZsetLevelloggingZCRITICAL)Z	old_levelr   r   r   disable_logger  s
    
r   c             C   s*   t jtj}| |_||_||_d|j_|S )z'Create a mock of a non-blocking socket.g        )r   Z	MagicMocksocketprotorx   familyZ
gettimeoutrs   )r   rx   r   Zsockr   r   r   mock_nonblocking_socket  s    r   c               C   s   t jdddS )Nz'asyncio.sslproto._is_sslproto_availableF)rs   )r   Zpatchr   r   r   r   force_legacy_ssl_support  s    r   )r*   )Nr   r   
contextlibr2   r   r   r   r   r`   r   rh   rX   r+   Zunittestr   r   Zhttp.serverr   Zwsgiref.simple_serverr   r   r    ImportErrorre   r   r   r	   r
   r   r   Z
coroutinesr   logr   r   r   platformZwindows_utilsr   r   rJ   rI   r"   r)   r.   r0   r1   r<   rH   rN   r]   r   ra   r^   rc   rf   rg   rk   contextmanagerrm   rn   rq   r{   ZBaseSelectorr|   ZBaseEventLoopr   rw   r   r   r   r   r   ZIPPROTO_TCPZSOCK_STREAMZAF_INETr   r   r   r   r   r   <module>   s   


	
 4
