a
    6·`àà  ã                   @   s   d Z ddlm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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 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(m0Z0 e+rÔddl1Z1nddl2Z1zddl1m3Z3 W nP e4y<   e 5¡ " e 6d¡ ddl3Z3W d  ƒ n1 s.0    Y  Y n0 ej7dkrTddl8Z8ndZ8g d¢Z9dej:v Z;de
j<v Z=de
j<v pˆd e
j<v Z>e=p’e>Z?ej@d!kZAd"ZBd#ZCd$ZDd%ZEe?rÔeBd&9 ZBeEd&9 ZEeCd&9 ZCeDd&9 ZDe
jFd'krîd(e
 G¡  ZHnd)e
 G¡  ZHe.d*ƒZIe+rd+ Jd,d-¡ZKnd.ZKe L¡  M¡ d/v ZNe
jO Pe
jO Qe
jO ReS¡d0d0¡¡ZTe
jO QeTd1¡ZUe
jO Pe
jO ReS¡¡ZVe!ove" ZWeXejYd2ƒZZeXed3ƒZ[eXed4ƒZ\eXejYd5ƒZ]eXejYd6ƒZ^eXejYd7ƒZ_eXed8ƒZ`eXejYd9ƒZaeXejYd:ƒZbeXejYd;ƒZceXed<ƒZdzedoeee f¡ ƒZgW n ehy"   d=ZgY n0 eXed>ƒZieXed?ƒZjeXejYd@ƒZke sPeoZe
 l¡ dkZmdAdB„ Znenƒ Zoepe
jqdCƒZre serjt¡ dDdE„ eueƒD ƒZvewedFexƒ ƒZyezƒ Z{ezƒ Z|G dGdH„ dHej}ƒZ~dIdJ„ Zed«dKdL„ƒZ€edMdN„ ƒZdOdP„ Z‚edQdR„ ƒZƒedSdT„ ƒZ„ej…eEfdUdV„Z†d¬dWdX„Z‡dYdZ„ Zˆd[d\„ Z‰G d]d^„ d^exƒZŠeŠej‹deEd_d`dadb„ ƒZŒeŠe*efdeEd_d`d­ddde„ƒZŽeŠedeEd_d`dfdg„ ƒZdhdi„ Zdjdk„ Z‘ej’dldm„ ƒZ“d®dndo„Z”d¯dqdr„Z•G dsdt„ dte1j–ƒZ–e–e1_–G dudv„ dve–ƒZ—e1 ˜e;dw¡G dxdy„ dye—ƒƒZ™dzd{„ Zšd|d}„ Z›G d~d„ dƒZœG d€d„ dƒZd‚dƒ„ ZžeBfd„d…„ZŸd°d†d‡„Z d±dˆd‰„Z¡d²d‹dŒ„Z¢eedfddŽ„Z£ejfdd„Z¤d³d’d“„Z¥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­e!ræej’d´d¤d¥„ƒZ®nej’dµd¦d¥„ƒZ®ejsd§d¨„ ƒZ¯e!re ej…d©dª„ ¡ dS )¶z
Test utilities.
é    )Úprint_functionN)ÚAF_INET)ÚAF_INET6)ÚSOCK_STREAM)ÚAIX)ÚFREEBSD)ÚLINUX)ÚMACOS)ÚPOSIX)ÚSUNOS)ÚWINDOWS)Úbytes2human)Úprint_color)Úsupports_ipv6)ÚFileExistsError)ÚFileNotFoundError)ÚPY3)Úrange)Úsuper)Úu)Úunicode)Úwhich)ÚmockÚignore©é   é   )EÚAPPVEYORÚDEVNULLÚGLOBAL_TIMEOUTÚTOLERANCE_SYS_MEMÚ
NO_RETRIESÚPYPYÚ
PYTHON_EXEÚROOT_DIRÚSCRIPTS_DIRÚTESTFN_PREFIXÚUNICODE_SUFFIXÚINVALID_UNICODE_SUFFIXÚ
CI_TESTINGÚVALID_PROC_STATUSESÚTOLERANCE_DISK_USAGEÚIS_64BITÚHAS_CPU_AFFINITYÚHAS_CPU_FREQÚHAS_ENVIRONÚHAS_PROC_IO_COUNTERSÚ
HAS_IONICEÚHAS_MEMORY_MAPSÚHAS_PROC_CPU_NUMÚ
HAS_RLIMITÚHAS_SENSORS_BATTERYÚHAS_BATTERYÚHAS_SENSORS_FANSÚHAS_SENSORS_TEMPERATURESZHAS_MEMORY_FULL_INFOÚpyrunÚ	terminateÚreap_childrenÚspawn_testprocÚspawn_zombieÚspawn_children_pairZThreadTaskunittestÚskip_on_access_deniedÚskip_on_not_implementedÚretry_on_failureÚTestMemoryLeakÚPsutilTestCaseÚprocess_namespaceÚsystem_namespaceÚprint_sysinfoZinstall_pipZinstall_test_depsÚchdirÚsafe_rmpathÚ
create_exeZdecode_pathZencode_pathÚ
get_testfnÚ
get_winverÚkernel_versionÚ
call_untilÚwait_for_pidÚwait_for_fileÚcheck_net_addressÚget_free_portÚbind_socketÚbind_unix_socketÚtcp_socketpairÚunix_socketpairÚcreate_socketsÚreload_moduleÚimport_module_by_pathÚwarnÚcopyload_shared_libÚis_namedtupleZ__pypy__r   ÚGITHUB_ACTIONSZCIBUILDWHEELl        é
   i  P i    é   r   Újavaz$psutil-%s-z@psutil-%s-u   -Æ’Å‘Å‘s   fÀ€Úutf8Úsurrogateescapeu   fÃ€Â€)Úasciizus-asciiz..ZscriptsÚcpu_affinityÚcpu_freqÚ
getloadavgÚenvironÚioniceÚmemory_mapsÚnet_io_countersÚcpu_numÚio_countersÚrlimitÚsensors_batteryFÚsensors_fansÚsensors_temperaturesÚthreadsc                  C   sÄ   dd„ } t r@tr$trtdƒS tdƒS tr6tj tj	¡S tdƒS n€t
rš| tj	ƒpˆ| tj tj	¡ƒpˆ| tdtjd d…  ƒƒpˆ| t ¡  ¡ ƒ}|s–tdƒ‚|S tj tj	¡}tj |¡s¼J |ƒ‚|S d S )	Nc                 S   s:   zt j| dgt jt jd W n ty0   Y d S 0 | S d S )Nz-V)ÚstdoutÚstderr)Ú
subprocessÚ
check_callÚPIPEÚ	Exception)Úexe© rx   ú4lib/python3.9/site-packages/psutil/tests/__init__.pyÚattemptÄ   s    ÿ
z_get_py_exe.<locals>.attemptZpypy3ÚpypyÚpythonzpython%s.%sé   z"can't find python exe real abspath)r\   r"   r   r   r   ÚosÚpathÚrealpathÚsysÚ
executabler	   Úversion_infoÚpsutilÚProcessrw   Ú
ValueErrorÚexists)rz   rw   rx   rx   ry   Ú_get_py_exeÃ   s*    	

ÿþürˆ   zr+c                 C   s    g | ]}|  d ¡rtt|ƒ‘qS )ZSTATUS_©Ú
startswithÚgetattrr„   ©Ú.0Úxrx   rx   ry   Ú
<listcomp>ç   s   
ÿr   ÚAF_UNIXc                       sP   e Zd ZdZ‡ fdd„Zdd„ Zdd„ Zdd	„ Zd
d„ Zdd„ Z	dd„ Z
‡  ZS )Ú
ThreadTaskz6A thread task which does nothing expect staying alive.c                    s$   t ƒ  ¡  d| _d| _t ¡ | _d S )NFçü©ñÒMbP?)r   Ú__init__Ú_runningÚ	_intervalÚ	threadingZEventÚ_flag©Úself©Ú	__class__rx   ry   r“   ÷   s    
zThreadTask.__init__c                 C   s   | j j}d|| jt| ƒf S )Nz<%s running=%s at %#x>)r›   Ú__name__r”   Úid)r™   Únamerx   rx   ry   Ú__repr__ý   s    zThreadTask.__repr__c                 C   s   |   ¡  | S ©N)Ústartr˜   rx   rx   ry   Ú	__enter__  s    zThreadTask.__enter__c                 O   s   |   ¡  d S r    )Ústop)r™   ÚargsÚkwargsrx   rx   ry   Ú__exit__  s    zThreadTask.__exit__c                 C   s(   | j rtdƒ‚tj | ¡ | j ¡  dS )zStart thread and keep it running until an explicit
        stop() request. Polls for shutdown every 'timeout' seconds.
        zalready startedN)r”   r†   r–   ÚThreadr¡   r—   Úwaitr˜   rx   rx   ry   r¡     s    zThreadTask.startc                 C   s(   d| _ | j ¡  | j r$t | j¡ qd S )NT)r”   r—   ÚsetÚtimeÚsleepr•   r˜   rx   rx   ry   Úrun  s    
zThreadTask.runc                 C   s    | j stdƒ‚d| _ |  ¡  dS )z8Stop thread execution and and waits until it is stopped.zalready stoppedFN)r”   r†   Újoinr˜   rx   rx   ry   r£     s    zThreadTask.stop)rœ   Ú
__module__Ú__qualname__Ú__doc__r“   rŸ   r¢   r¦   r¡   r¬   r£   Ú__classcell__rx   rx   rš   ry   r‘   ô   s   	r‘   c                    s   t  ˆ ¡‡ fdd„ƒ}|S )Nc                     s0   zˆ | i |¤ŽW S  t y*   tƒ  ‚ Y n0 d S r    )rv   r;   ©r¤   r¥   ©Úfunrx   ry   Úwrapper%  s
    z&_reap_children_on_err.<locals>.wrapper©Ú	functoolsÚwraps©r´   rµ   rx   r³   ry   Ú_reap_children_on_err$  s    rº   c                 K   sà   |  dt¡ |  dt¡ |  dt ¡ ¡ |  dtj¡ trJd}|  d|¡ | du r¶tƒ }zPt|ƒ d| }td	|g} t	j
| fi |¤Ž}t |¡ t|d
d
d W t|ƒ qÜt|ƒ 0 n&t	j
| fi |¤Ž}t |¡ t|jƒ |S )a}  Creates a python subprocess which does nothing for 60 secs and
    return it as a subprocess.Popen instance.
    If "cmd" is specified that is used instead of python.
    By default stdin and stdout are redirected to /dev/null.
    It also attemps to make sure the process is in a reasonably
    initialized state.
    The process is registered for cleanup on reap_children().
    Ústdinrq   ÚcwdÚenvé   ÚcreationflagsNz:from time import sleep;open(r'%s', 'w').close();sleep(60);z-cT©ÚdeleteÚempty)Ú
setdefaultr   r~   Úgetcwdrf   r   rJ   rH   r#   rs   ÚPopenÚ_subprocesses_startedÚaddrO   rN   Úpid)ÚcmdÚkwdsZCREATE_NO_WINDOWÚtestfnZpylineÚsprocrx   rx   ry   r<   /  s.    
þ



r<   c                  C   sÄ   d} t t ¡ d}z’t dtj |¡tf ¡}trDt	|dd\}} nt	|ƒ\}} t
 |j¡}tt|dddƒ}t |¡ t
 |¡}||fW t|ƒ | dur¢t| ƒ S nt|ƒ | dur¾t| ƒ 0 dS )	a  Create a subprocess which creates another one as in:
    A (us) -> B (child) -> C (grandchild).
    Return a (child, grandchild) tuple.
    The 2 processes are fully initialized and will live for 60 secs
    and are registered for cleanup on reap_children().
    N©Údira;              import subprocess, os, sys, time
            s = "import os, time;"
            s += "f = open('%s', 'w');"
            s += "f.write(str(os.getpid()));"
            s += "f.close();"
            s += "time.sleep(60);"
            p = subprocess.Popen([r'%s', '-c', s])
            p.wait()
            r   )r¿   TFrÀ   )rJ   r~   rÄ   ÚtextwrapÚdedentr   Úbasenamer#   r   r9   r„   r…   rÈ   ÚintrO   Ú_pids_startedrÇ   rH   )ÚtfilerË   ÚsÚsubpÚchildZgrandchild_pidZ
grandchildrx   rx   ry   r>   W  s0    	÷

ü  þr>   c                     s&  t js
J ‚tƒ } t d|  ¡}d}t| ƒ}zÒ| t¡ t|ƒ\}}| 	¡ \}}z~t
 
| ¡ gg g t¡ t| d¡ƒ}t |¡ t  |¡‰ t‡ fdd„dƒ |ˆ fW | ¡  W | ¡  t| ƒ |durÌt|ƒ S | ¡  0 W | ¡  t| ƒ |dur"t|ƒ n$| ¡  t| ƒ |dur t|ƒ 0 dS )z±Create a zombie process and return a (parent, zombie) process tuple.
    In order to kill the zombie parent must be terminate()d first, then
    zombie must be wait()ed on.
    a          import os, sys, time, socket, contextlib
        child_pid = os.fork()
        if child_pid > 0:
            time.sleep(3000)
        else:
            # this is the zombie process
            s = socket.socket(socket.AF_UNIX)
            with contextlib.closing(s):
                s.connect('%s')
                if sys.version_info < (3, ):
                    pid = str(os.getpid())
                else:
                    pid = bytes(str(os.getpid()), 'ascii')
                s.sendall(pid)
        Né   c                      s   ˆ   ¡ S r    )Ústatusrx   ©Úzombierx   ry   Ú<lambda>   ó    zspawn_zombie.<locals>.<lambda>zret == psutil.STATUS_ZOMBIE)r„   r
   rJ   rÏ   rÐ   rS   Z
settimeoutr   r9   ÚacceptÚselectÚfilenorÒ   ZrecvrÓ   rÇ   r…   rM   ÚcloserH   )Z	unix_fileÚsrcrÔ   ÚsockÚparentÚconnÚ_Zzpidrx   rÚ   ry   r=   ~  sD    
ñ


þù

ý
r=   c                 K   sž   |  dd¡ |  dd¡ tƒ }z^t|dƒ}| | ¡ W d  ƒ n1 sJ0    Y  tt|jgfi |¤Ž}t|jƒ ||fW S  t	y˜   t
|ƒ ‚ Y n0 dS )zRun python 'src' code string in a separate interpreter.
    Returns a subprocess.Popen instance and the test file where the source
    code was written.
    rq   Nrr   Úwt)rÃ   rJ   ÚopenÚwriter<   r#   rž   rN   rÈ   rv   rH   )râ   rÊ   ÚsrcfileÚfrÖ   rx   rx   ry   r9   «  s    (

r9   c                 K   sÜ   t | ttfƒrdnd}tr"|r"dnd}| d|¡ | dtj¡ | dtj¡ | dd¡ | d	|¡ tj| fi |¤Ž}t 	|¡ t
r˜|jtd
\}}n| ¡ \}}|jdkr¶t|ƒ‚|rÂt|ƒ | d¡rØ|dd… }|S )zUrun cmd in a subprocess and return its output.
    raises RuntimeError on error.
    TFr¾   r   Úshellrq   rr   Zuniversal_newlinesr¿   ©ÚtimeoutÚ
Néÿÿÿÿ)Ú
isinstanceÚstrr   r   rÃ   rs   ru   rÅ   rÆ   rÇ   r   Zcommunicater   Ú
returncodeÚRuntimeErrorrY   Úendswith)rÉ   rÊ   rì   ÚflagsÚprq   rr   rx   rx   ry   Úsh¿  s&    


rø   c              
      s  t rddlm‰ dd„ ‰dd„ ‰ ‡ ‡‡fdd„}‡ ‡‡fd	d
„‰‡‡fdd„}dd„ }| }znt|tƒr´|||ƒW t|tjtjfƒrŒ||ƒ t|tƒrš|n|j}t 	|¡r²J |ƒ‚S t|tj
tjfƒrˆ||ƒW t|tjtjfƒrì||ƒ t|tƒrú|n|j}t 	|¡rJ |ƒ‚S t|tjƒrv|||ƒW t|tjtjfƒrJ||ƒ t|tƒrZ|n|j}t 	|¡rtJ |ƒ‚S td| ƒ‚W t|tjtjfƒr ||ƒ t|tƒr°|n|j}t 	|¡rJ |ƒ‚nHt|tjtjfƒrè||ƒ t|tƒrø|n|j}t 	|¡rJ |ƒ‚0 dS )a˜  Terminate a process and wait() for it.
    Process can be a PID or an instance of psutil.Process(),
    subprocess.Popen() or psutil.Popen().
    If it's a subprocess.Popen() or psutil.Popen() instance also closes
    its stdin / stdout / stderr fds.
    PID is wait()ed even if the process is already gone (kills zombies).
    Does nothing if the process does not exist.
    Return process exit status.
    r   )Úwait_pidc                 S   sb   t | tjƒrts|  ¡  n
|  |¡ tr^t | tjƒr^zt | j¡ |¡W S  tj	y\   Y n0 d S r    )
rñ   rs   rÅ   r   r¨   r   r„   r…   rÈ   ÚNoSuchProcess©Úprocrî   rx   rx   ry   r¨   è  s    

zterminate.<locals>.waitc                 S   s6   t rtrtj}tr(|tjkr(|  tj¡ |  |¡ d S r    )r	   r\   ÚsignalÚSIGKILLr
   Úsend_signalÚSIGCONT)rü   Úsigrx   rx   ry   Úsendsigô  s
    zterminate.<locals>.sendsigc              
      s\   zˆ | ˆƒ W nB t yP } z*tr.|jdkr.n|jtjkr<‚ W Y d }~n
d }~0 0 ˆ| |ƒS )Né   )ÚOSErrorr   ZwinerrorÚerrnoZESRCH)rü   rî   Úerr©r  r  r¨   rx   ry   Úterm_subprocþ  s    zterminate.<locals>.term_subprocc                    s.   zˆ | ˆƒ W n t jy"   Y n0 ˆ| |ƒS r    )r„   rú   rû   r  rx   ry   Úterm_psproc  s
    zterminate.<locals>.term_psprocc                    sD   zt  | ¡}W n& t jy4   tr0ˆ| |ƒ Y S Y n0 ˆ ||ƒS d S r    )r„   r…   rú   r
   )rÈ   rî   rü   )r	  rù   rx   ry   Úterm_pid  s    zterminate.<locals>.term_pidc                 S   s4   | j r| j  ¡  | jr | j ¡  | jr0| j ¡  d S r    )rq   rá   rr   r»   )rü   rx   rx   ry   Úflush_popen  s    

zterminate.<locals>.flush_popenzwrong type %rN)r
   Zpsutil._psposixrù   rñ   rÒ   rs   rÅ   r„   rÈ   Ú
pid_existsr…   Ú	TypeError)Zproc_or_pidr  Úwait_timeoutr  r
  r  r÷   rÈ   rx   )r  r  r	  r¨   rù   ry   r:   Û  sP    



	

õ
÷
ùýr:   c                 C   s   t  ¡ j| d}tr&t ¡ }t|ƒ qtr<t ¡ }t|ƒ q&|rŒ|D ]}t|dd qDt j|td\}}|D ]}t	d| ƒ t|t
jd qldS )a  Terminate and wait() any subprocess started by this test suite
    and any children currently running, ensuring that no processes stick
    around to hog resources.
    If resursive is True it also tries to terminate and wait()
    all grandchildren started by this process.
    ©Ú	recursiveN)r  rí   z0couldn't terminate process %r; attempting kill())r  )r„   r…   ÚchildrenrÆ   Úpopr:   rÓ   Ú
wait_procsr   rY   rý   rþ   )r  r  rÖ   rÈ   r÷   ZgoneÚaliverx   rx   ry   r;   3  s    


r;   c                  C   s¬   t stdƒ‚d} t ¡ d }|D ]"}| ¡ s4|dkr>| |7 } q  qDq | sTtd| ƒ‚d}d}|  d¡}t|d ƒ}t|ƒdkrŠt|d ƒ}t|ƒdkr¢t|d ƒ}|||fS )	z"Return a tuple such as (2, 6, 36).z	not POSIXÚ r}   Ú.zcan't parse %rr   é   r   )	r
   ÚNotImplementedErrorr~   ÚunameÚisdigitr†   ÚsplitrÒ   Úlen)rÕ   r  ÚcÚminorÚmicroZnumsÚmajorrx   rx   ry   rL   X  s&    

rL   c                  C   sd   t stdƒ‚t ¡ } t| dƒr*| jp&d}n(t d| d ¡}|rNt| 	d¡ƒ}nd}| d | d |fS )Nznot WINDOWSÚservice_pack_majorr   z\s\d$r   r  )
r   r  r   ZgetwindowsversionÚhasattrr!  ÚreÚsearchrÒ   Úgroup)ZwvZspÚrrx   rx   ry   rK   p  s    
rK   c                   @   s<   e Zd ZdZeddddfdd„Zdd„ Zdd	„ Zd
d„ ZdS )ÚretryzA retry decorator.Nr’   c                 C   s2   |r|rt dƒ‚|| _|| _|| _|| _|| _d S )Nz/timeout and retries args are mutually exclusive)r†   Ú	exceptionrî   ÚretriesÚintervalÚlogfun)r™   r(  rî   r)  r*  r+  rx   rx   ry   r“   ‡  s    zretry.__init__c                 c   sT   | j r*t ¡ | j  }t ¡ |k rPd V  qn&| jrHt| jƒD ]
}d V  q:nd V  qHd S r    )rî   rª   r)  r   )r™   Ústop_atræ   rx   rx   ry   Ú__iter__–  s    

zretry.__iter__c                 C   s   | j d urt | j ¡ d S r    )r*  rª   r«   r˜   rx   rx   ry   r«   ¢  s    
zretry.sleepc                    s"   t  ˆ ¡‡ ‡fdd„ƒ}ˆ|_|S )Nc                     s†   d }ˆD ]l}zˆ | i |¤ŽW   S  ˆj yr } z8|}ˆjd urJˆ |¡ ˆ ¡  W Y d }~qW Y d }~qd }~0 0 qtr€|‚n‚ d S r    )r(  r+  r«   r   )r¤   r¥   Úexcræ   ©r´   r™   rx   ry   rµ   §  s    

$zretry.__call__.<locals>.wrapper)r·   r¸   Ú	decorator)r™   r´   rµ   rx   r/  ry   Ú__call__¦  s    zretry.__call__)	rœ   r®   r¯   r°   rv   r“   r-  r«   r1  rx   rx   rx   ry   r'  „  s   û
r'  r’   )r(  r+  rî   r*  c                 C   s   t  | ¡ trt d¡ dS )z„Wait for pid to show up in the process list then return.
    Used in the test suite to give time the sub process to initialize.
    ç{®Gáz„?N)r„   r…   r   rª   r«   )rÈ   rx   rx   ry   rN   ¾  s    
rN   Tc                 C   sN   t | dƒ}| ¡ }W d  ƒ n1 s(0    Y  |s>|s>J ‚|rJt| ƒ |S )z8Wait for a file to be written on disk with some content.ÚrbN)rè   ÚreadrH   )ÚfnamerÁ   rÂ   rë   Údatarx   rx   ry   rO   Ê  s    &rO   c                 C   s   | ƒ }t |ƒsJ ‚|S )zVKeep calling function for timeout secs and exit if eval()
    expression is True.
    )Úeval)r´   ÚexprÚretrx   rx   ry   rM   ×  s    rM   c                 C   sl   dd„ }zLt  | ¡}t |j¡r0t tj| ¡}nt t j| ¡}t	rJ|ƒ  n||ƒ W n t
yf   Y n0 dS )z>Convenience function for removing temporary test files or dirsc              
   S   s~   t   ¡ t }t   ¡ |k rvz| ƒ W S  ty2   Y n8 tyh } z |}tdt|ƒ ƒ W Y d }~n
d }~0 0 t  d¡ q|‚d S )Nzignoring %sr2  )rª   r   r   ZWindowsErrorrY   rò   r«   )r´   r,  ræ   r  rx   rx   ry   Ú	retry_funé  s    &zsafe_rmpath.<locals>.retry_funN)r~   ÚstatÚS_ISDIRÚst_moder·   ÚpartialÚshutilZrmtreeÚremover
   r   )r   r:  Ústr´   rx   rx   ry   rH   ç  s    
rH   c                 C   s&   zt  | ¡ W n ty    Y n0 dS )z-Convenience function for creating a directoryN)r~   Úmkdirr   rÍ   rx   rx   ry   Ú
safe_mkdir  s    rC  c              	   c   s8   t  ¡ }zt  | ¡ dV  W t  |¡ nt  |¡ 0 dS )z@Context manager which temporarily changes the current directory.N)r~   rÄ   rG   )ÚdirnameÚcurdirrx   rx   ry   rG     s
    
rG   c                 C   sì   t j | ¡rJ | ƒ‚|rºtdƒs(tdƒ‚t|tƒr<t d¡}t|t	ƒsNJ |ƒ‚t
tdddƒ}| |¡ W d  ƒ n1 s~0    Y  z"t d|jd| g¡ W t|jƒ qèt|jƒ 0 n.t t| ¡ trèt  | ¡}t  | |jtjB ¡ dS )	z1Creates an executable file in the given location.Úgcczgcc is not installedzŸ
                #include <unistd.h>
                int main() {
                    pause();
                    return 1;
                }
                z.c©Úsuffixrç   Nz-o)r~   r   r‡   r   r†   rñ   ÚboolrÏ   rÐ   rò   rè   rJ   ré   rs   rt   rž   rH   r?  Úcopyfiler#   r
   r;  Úchmodr=  ÚS_IEXEC)ZoutpathZc_coderë   rA  rx   rx   ry   rI     s$    
ÿ(
rI   r  c                 C   s.   t jt| |d}tj |¡s tj |¡S q dS )zîReturn an absolute pathname of a file or dir that did not
    exist at the time this call is made. Also schedule it for safe
    deletion at interpreter exit. It's technically racy but probably
    not really due to the time variant.
    )ÚprefixrH  rÎ   N)ÚtempfileZmktempr&   r~   r   r‡   r€   )rH  rÎ   rž   rx   rx   ry   rJ   9  s    rJ   c                   @   s4   e Zd Zdd„ Zeejdƒs$ejjZe	s0dd„ Z
dS )ÚTestCasec                 C   s.   | j j}| d¡sd| }d|| j j| jf S )Nzpsutil.zpsutil.tests.z%s.%s.%s)r›   r®   rŠ   rœ   Z_testMethodName)r™   Zfqmodrx   rx   ry   Ú__str__N  s    
ÿzTestCase.__str__ÚassertRaisesRegexc                 C   s   d S r    rx   r˜   rx   rx   ry   ÚrunTest\  s    zTestCase.runTestN)rœ   r®   r¯   rP  r"  ÚunittestrO  ZassertRaisesRegexprQ  r   rR  rx   rx   rx   ry   rO  J  s
   	rO  c                   @   sB   e Zd ZdZddd„Zdd„ Zdd	„ Zd
d„ Zdd„ Zdd„ Z	dS )rC   zUTest class providing auto-cleanup wrappers on top of process
    test utilities.
    r  Nc                 C   s   t ||d}|  t|¡ |S )N)rH  rÎ   )rJ   Ú
addCleanuprH   )r™   rH  rÎ   r5  rx   rx   ry   rJ   i  s    zPsutilTestCase.get_testfnc                 O   s   t |i |¤Ž}|  t|¡ |S r    )r<   rT  r:   )r™   r¤   rÊ   rÌ   rx   rx   ry   r<   n  s    zPsutilTestCase.spawn_testprocc                 C   s*   t ƒ \}}|  t|¡ |  t|¡ ||fS r    )r>   rT  r:   )r™   Zchild1Zchild2rx   rx   ry   r>   s  s    
z"PsutilTestCase.spawn_children_pairc                 C   s*   t ƒ \}}|  t|¡ |  t|¡ ||fS r    )r=   rT  r:   )r™   rä   rÛ   rx   rx   ry   r=   y  s    
zPsutilTestCase.spawn_zombiec                 O   s.   t |i |¤Ž\}}|  t|¡ |  t|¡ |S r    )r9   rT  rH   r:   )r™   r¤   rÊ   rÌ   rê   rx   rx   ry   r9     s    zPsutilTestCase.pyrunc                 C   s˜   |   tjtj|j¡ t|tjtjfƒrl| ¡ r2J ‚z| ¡ }W n tjyR   Y n0 t	d| ƒ‚|j
dd t |j¡r‚J |jƒ‚|  |jt ¡ ¡ d S )Nz3Process.status() didn't raise exception (status=%s)r   rí   )ÚassertRaisesr„   rú   r…   rÈ   rñ   rÅ   Ú
is_runningrÙ   ÚAssertionErrorr¨   r  ZassertNotInÚpids)r™   rü   rÙ   rx   rx   ry   ÚassertProcessGone…  s    ÿz PsutilTestCase.assertProcessGone)r  N)
rœ   r®   r¯   r°   rJ   r<   r>   r=   r9   rY  rx   rx   rx   ry   rC   d  s   
rC   zunreliable on PYPYc                   @   s~   e Zd ZdZdZdZdZer dndZdZ	e
 ¡ Zdd„ Zd	d
„ Zdd„ Zdd„ Zdd„ Zdd„ Zdd„ Zddd„Zdd„ ZdS )rB   aç  Test framework class for detecting function memory leaks,
    typically functions implemented in C which forgot to free() memory
    from the heap. It does so by checking whether the process memory
    usage increased before and after calling the function many times.

    Note that this is hard (probably impossible) to do reliably, due
    to how the OS handles memory, the GC and so on (memory can even
    decrease!). In order to avoid false positives, in case of failure
    (mem > 0) we retry the test for up to 5 times, increasing call
    repetitions each time. If the memory keeps increasing then it's a
    failure.

    If available (Linux, OSX, Windows), USS memory is used for comparison,
    since it's supposed to be more precise, see:
    https://gmpy.dev/blog/2016/real-process-memory-and-environ-in-python
    If not, RSS memory is used. mallinfo() on Linux and _heapwalk() on
    Windows may give even more precision, but at the moment are not
    implemented.

    PyPy appears to be completely unstable for this framework, probably
    because of its JIT, so tests on PYPY are skipped.

    Usage:

        class TestLeaks(psutil.tests.TestMemoryLeak):

            def test_fun(self):
                self.execute(some_function)
    éÈ   r]   r   r^   Tc                 C   s   | j  ¡ }t|d|jƒS )NZuss)Ú	_thisprocÚmemory_full_infor‹   Zrss)r™   Úmemrx   rx   ry   Ú_get_mem¼  s    
zTestMemoryLeak._get_memc                 C   s   t r| j ¡ S | j ¡ S d S r    )r
   r[  Únum_fdsÚnum_handlesr˜   rx   rx   ry   Ú_get_num_fdsÂ  s    
zTestMemoryLeak._get_num_fdsc                 C   s   | j rt|dtjd d S )NZyellow)ZcolorÚfile)Úverboser   r   rr   )r™   Úmsgrx   rx   ry   Ú_logÈ  s    zTestMemoryLeak._logc                 C   sx   |   ¡ }|  |¡ |   ¡ }|| }|dk r8|  d| ¡‚|dkrttrHdnd}|dkr\|d7 }d|||f }|  |¡‚dS )	z»Makes sure num_fds() (POSIX) or num_handles() (Windows) does
        not increase after calling a function.  Used to discover forgotten
        close(2) and CloseHandle syscalls.
        r   zHnegative diff %r (gc probably collected a resource from a previous test)ÚfdZhandler  rÕ   z%s unclosed %s after calling %rN)ra  ÚcallÚfailr
   )r™   r´   ZbeforeZafterÚdiffÚtype_rd  rx   rx   ry   Ú
_check_fdsÌ  s    
ÿzTestMemoryLeak._check_fdsc                 C   s^   t jdd |  ¡ }t|ƒD ]}|  |¡}~~qt jdd |  ¡ }|  t jg ¡ || }|S )z€Get 2 distinct memory samples, before and after having
        called fun repeadetly, and return the memory difference.
        r  )Z
generation)ÚgcZcollectr^  r   rg  ZassertEqualZgarbage)r™   r´   ÚtimesZmem1rŽ   r9  Zmem2ri  rx   rx   ry   Ú_call_ntimesß  s    
zTestMemoryLeak._call_ntimesc                 C   s¶   g }d}|}t d|d ƒD ]†}	|  ||¡}
d|	t|
ƒt|
| ƒ|f }| |¡ |
|kp^|
|k}|r||	dkrv|  |¡  d S |	dkrŠtƒ  |  |¡ ||7 }|
}q|  d |¡¡‚d S )Nr   r  z,Run #%s: extra-mem=%s, per-call=%s, calls=%sz. )r   rn  r   Úappendre  Úprintrh  r­   )r™   r´   rm  Úwarmup_timesr)  Ú	toleranceZmessagesZprev_memZincreaseÚidxr]  rd  Zsuccessrx   rx   ry   Ú
_check_memî  s(    ÿ


zTestMemoryLeak._check_memc                 C   s   |ƒ S r    rx   )r™   r´   rx   rx   ry   rg    s    zTestMemoryLeak.callNc              
   C   sì   |dur|n| j }|dur|n| j}|dur0|n| j}|durB|n| j}zD|dksZJ dƒ‚|dksjJ dƒ‚|dkszJ dƒ‚|dksŠJ dƒ‚W n0 ty¼ } ztt|ƒƒ‚W Y d}~n
d}~0 0 |  ||¡ |  |¡ | j	|||||d dS )	zTest a callable.Nr  ztimes must be >= 1r   zwarmup_times must be >= 0zretries must be >= 0ztolerance must be >= 0)rm  rq  r)  rr  )
rm  rq  r)  rr  rW  r†   rò   rn  rk  rt  )r™   r´   rm  rq  r)  rr  r  rx   rx   ry   Úexecute	  s$    ÿ"

ÿzTestMemoryLeak.executec                    s&   ‡ ‡‡fdd„}ˆj |fi |¤Ž dS )znConvenience method to test a callable while making sure it
        raises an exception on every call.
        c                      s   ˆ  ˆ ˆ¡ d S r    )rU  rx   ©r.  r´   r™   rx   ry   rg  "  s    z*TestMemoryLeak.execute_w_exc.<locals>.callN)ru  )r™   r.  r´   r¥   rg  rx   rv  ry   Úexecute_w_exc  s    zTestMemoryLeak.execute_w_exc)NNNN)rœ   r®   r¯   r°   rm  rq  rr  r)   r)  rc  r„   r…   r[  r^  ra  re  rk  rn  rt  rg  ru  rw  rx   rx   rx   ry   rB   •  s$     ÿ
rB   c                  C   s¨  dd l } dd l}dd l}dd l}dd l}dd l}zdd l}W n tyR   d }Y n0 zdd l}W n tyv   d }Y n0 |  	¡ }t
jrœtdƒrœtdƒ|d< nzt
jr¸d| ¡ d  |d< n^t
jrþdd tt| ¡ ƒ¡ |d< t|dƒrü|d  d	| ¡  7  < nd
| ¡ | ¡ f |d< d	 t| ¡ ƒ| ¡ g ¡|d< t
jrN| ¡ d |d< d	 | ¡ | ¡ |  ¡ g¡|d< t!|ddƒ|d< |d urž|d  d|j" 7  < t
jrötdƒrÔtddgƒ}	t|	ƒ #d¡d |d< nd|d< | $¡ d }
|
rö|
|d< t% &¡ |d< | '¡ }d|d |d f |d< |j (t
 )¡ ¡ *d¡|d< |j +¡  *d¡|d< | ,¡ |d< t-j. /d¡|d < t- 0¡ |d!< t1|d"< | 2¡ |d#< t- 3¡ |d$< t
 4¡ |d%< d&t5d'd(„ t
 6¡ D ƒƒ |d)< t
 7¡ }d*t8|j9ƒt:|j;ƒt:|j<ƒf |d+< t
 =¡ }d*t8|j9ƒt:|j;ƒt:|j<ƒf |d,< t>t
 ?¡ ƒ|d-< t
 @¡  A¡ }| Bd.d ¡ | C|¡|d/< tDd0t%jEd1 | F¡ D ]$\}}tDd2|d3 |f t%jEd1 qftDd0t%jEd1 t%jG H¡  d S )4Nr   Zlsb_releasezlsb_release -d -sZOSz	Darwin %szWindows ú Úwin32_editionz, z%s %sZarchr}   Zkernelr|   Ú__version__znot installedÚpipz (wheel=%s)rF  z	--versionrï   r  Zglibczfs-encodingz%s, %sÚlangz%Y-%m-%d %H:%M:%Sz	boot-timerª   Úuserú~Úhomer¼   ZpyexeZhostnameZPIDZcpusz%.1f%%, %.1f%%, %.1f%%c                 S   s   g | ]}|t  ¡  d  ‘qS )éd   )r„   Ú	cpu_countrŒ   rx   rx   ry   r   p  rÝ   z!print_sysinfo.<locals>.<listcomp>Zloadavgz%s%%, used=%s, total=%sZmemoryÚswaprX  rh   rü   zF======================================================================©rb  z%-17s %sú:)IÚcollectionsÚdatetimeÚgetpassÚlocaleÚplatformÚpprintr{  ÚImportErrorÚwheelÚOrderedDictr„   r   r   rø   ZOSXZmac_verr   r­   Úmaprò   Z	win32_verr"  ry  ÚsystemÚversionÚlistZarchitectureÚmachiner
   r  Zpython_implementationZpython_versionZpython_compilerr‹   rz  r  Zlibc_verr   ÚgetfilesystemencodingZ	getlocaleZfromtimestampÚ	boot_timeÚstrftimeZnowZgetuserr~   r   Ú
expanduserrÄ   r#   ZnodeÚgetpidr  Útuplere   Úvirtual_memoryrÒ   Zpercentr   ZusedÚtotalÚswap_memoryr  rX  r…   Úas_dictr  Zpformatrp  rr   Úitemsrq   Úflush)r…  r†  r‡  rˆ  r‰  rŠ  r{  rŒ  ÚinfoÚoutrÕ   r|  r]  r‚  ZpinfoÚkÚvrx   rx   ry   rF   (  s¦    

ÿ

ÿý


ÿÿÿÿ
ÿ
rF   c                  C   s6   t  ¡ } t| dƒr|  ¡ S t| dƒr2t |  ¡ ¡S dS )Nrj   rc   r   )r„   r…   r"  rj   ÚrandomÚchoicerc   )r÷   rx   rx   ry   Ú_get_eligible_cpuƒ  s    

r¥  c                   @   sB  e Zd ZdZddi fddi fgZddi fddddifd	di fd
di fddi fddi fddi fddi fddi fg	Zddi fddddifddi fddi fddi fddi fddi fddi fddi fddi fddi fddi fddi fd di fd!di fd"di fd#di fgZerFed$di fg7 Zed%di fg7 Zed&di fg7 Zed'di fg7 Zer\ed(di fg7 Ze	rred)di fg7 Ze
rŒed*ejfi fg7 Zer¢ed+di fg7 Zer¸ed,di fg7 ZerÎed-di fg7 Zeräed.di fg7 Zerþed/dd0d1ifg7 Zg Zereddi fg7 Znedejfi fg7 Ze
rJed*ejd2fi fg7 Ze	r‚erned)ejd3fi fg7 Zned)ejfi fg7 Zeržed+eƒ gfi fg7 Zd4ejfi fd5di fd6di fd7di fd8di fgZerüed4ejfi fg7 Zed4ejfi fg7 Zee e e Zd9d:„ ZdDd;d<„Zd=d>„ Z e!d?d@„ ƒZ"e!dAdB„ ƒZ#dCS )ErD   a  A container that lists all Process class method names + some
    reasonable parameters to be called with. Utility methods (parent(),
    children(), ...) are excluded.

    >>> ns = process_namespace(psutil.Process())
    >>> for fun, name in ns.iter(ns.getters):
    ...    fun()
    Úcpu_percentrx   Zmemory_percentrœ  r  r  TrV  Zmemory_info_exZoneshoträ   ÚparentsrÈ   r¨   ©r   ZcmdlineZconnectionsÚkindÚallÚ	cpu_timesZcreate_timer¼   rw   r\  Zmemory_inforž   ÚniceZnum_ctx_switchesZnum_threadsZ
open_filesZppidrÙ   rp   ZusernameZuidsZgidsZterminalr_  rk   rg   rl   rc   rj   rf   r`  rh   ZgroupedF)rØ   i   r   rÿ   ZsuspendZresumer:   Úkillc                 C   s
   || _ d S r    )Ú_proc)r™   rü   rx   rx   ry   r“   ë  s    zprocess_namespace.__init__c                 c   s`   t |ƒ}t |¡ |D ]D\}}}|r,|  ¡  t| j|ƒ}tj|g|¢R i |¤Ž}||fV  qdS ©z_Given a list of tuples yields a set of (fun, fun_name) tuples
        in random order.
        N)r‘  r£  ÚshuffleÚclear_cacher‹   r®  r·   r>  )r™   Úlsr±  Úfun_namer¤   rÊ   r´   rx   rx   ry   Úiterî  s    
zprocess_namespace.iterc                 C   s   | j j| j jdd dS )z&Clear the cache of a Process instance.T)Z_ignore_nspN)r®  Z_initrÈ   r˜   rx   rx   ry   r±  û  s    zprocess_namespace.clear_cachec                 C   s>   |D ]4\}}}d| }t ||ƒsd|jj|f }t|ƒ‚qdS )z}Given a TestCase instance and a list of tuples checks that
        the class defines the required test method names.
        Ztest_z$%r class should define a '%s' methodN)r"  r›   rœ   ÚAttributeError)ÚclsZ
test_classr²  r³  ræ   Z	meth_namerd  rx   rx   ry   Útest_class_coverageÿ  s    
ÿz%process_namespace.test_class_coveragec                 C   s`   t dd„ | jD ƒƒ}t dd„ | jD ƒƒ}t dd„ ttjƒD ƒƒ}||B |A }|r\td| ƒ‚d S )Nc                 S   s   g | ]}|d  ‘qS r¨  rx   rŒ   rx   rx   ry   r     rÝ   z*process_namespace.test.<locals>.<listcomp>c                 S   s   g | ]}|d  ‘qS r¨  rx   rŒ   rx   rx   ry   r     rÝ   c                 S   s   g | ]}|d  dkr|‘qS )r   ræ   rx   rŒ   rx   rx   ry   r     rÝ   z!uncovered Process class names: %r)r©   rª  ÚignoredrÎ   r„   r…   r†   )r¶  Úthisr¸  ÚklassZleftoutrx   rx   ry   Útest  s    zprocess_namespace.testN)T)$rœ   r®   r¯   r°   Zutilsr¸  Úgettersr
   r0   r1   r4   r„   ZRLIMIT_NOFILEr-   r3   r/   r   r2   ZsettersZNORMAL_PRIORITY_CLASSr   ZIOPRIO_CLASS_NONEZIOPRIO_NORMALr¥  rý   ÚSIGTERMZkillersZCTRL_C_EVENTZCTRL_BREAK_EVENTrª  r“   r´  r±  Úclassmethodr·  r»  rx   rx   rx   ry   rD   Œ  s¤   	þ÷ïû

rD   c                   @   s¦  e Zd ZdZddi fddddifddddifddi fd	dd
difd	dd
difddddifddddifde ¡ fi fddddifddi fddi fddddifde ¡ fi fddi fddi fddi fddi fgZeräeddd
difg7 Ze	røeddi fg7 Ze
reddi fg7 Zer$eddi fg7 Zer:eddi fg7 Zer`ed di fg7 Zed!d"i fg7 Zd#di fd$e ¡ gfi fd%di fd&di fgZeZed'd(„ ƒZejZd)S )*rE   zÝA container that lists all the module-level, system-related APIs.
    Utilities such as cpu_percent() are excluded. Usage:

    >>> ns = system_namespace
    >>> for fun, name in ns.iter(ns.getters):
    ...    fun()
    r”  rx   r  ZlogicalFTZ	cpu_statsr«  ZpercpuZdisk_io_countersZperdiskZdisk_partitionsrª  Z
disk_usageZnet_connectionsr©  Znet_if_addrsZnet_if_statsri   Zpernicr  rX  r›  Zusersr™  rd   re   ro   rn   rm   Zwin_service_iterZwin_service_get)ZalgZprocess_iterr  r¦  Zcpu_times_percentc                 c   sR   t | ƒ} t | ¡ | D ]6\}}}tt|ƒ}tj|g|¢R i |¤Ž}||fV  qdS r¯  )r‘  r£  r°  r‹   r„   r·   r>  )r²  r³  r¤   rÊ   r´   rx   rx   ry   r´  H  s    

zsystem_namespace.iterN)rœ   r®   r¯   r°   r~   rÄ   r—  r¼  r.   ÚHAS_GETLOADAVGr8   r7   r5   r   r„   r…   r¸  rª  Ústaticmethodr´  rD   r·  rx   rx   rx   ry   rE     sT   îü
rE   c                 C   s   t  | ¡sJ | ƒ‚d| _| S )zA decorator to mark a TestCase class. When running parallel tests,
    class' unit tests will be run serially (1 process).
    T)ÚinspectZisclassZ
_serialrun)rº  rx   rx   ry   Ú	serialrunW  s    rÂ  c                 C   s   dd„ }t td| |dS )zZDecorator which runs a test function and retries N times before
    actually failing.
    c                 S   s   t d|  tjd d S )Nz%r, retryingrƒ  )rp  r   rr   )r.  rx   rx   ry   r+  e  s    z retry_on_failure.<locals>.logfunN)r(  rî   r)  r+  )r'  rW  )r)  r+  rx   rx   ry   rA   a  s    ÿrA   c                    s   ‡ fdd„}|S )z,Decorator to Ignore AccessDenied exceptions.c                    s   t  ˆ ¡‡ ‡fdd„ƒ}|S )Nc                     sB   zˆ | i |¤ŽW S  t jy<   ˆd ur.ˆs.‚ t d¡‚Y n0 d S )Nzraises AccessDenied)r„   ZAccessDeniedrS  ÚSkipTestr²   ©r´   Úonly_ifrx   ry   rµ   o  s    z9skip_on_access_denied.<locals>.decorator.<locals>.wrapperr¶   r¹   ©rÅ  r³   ry   r0  n  s    z(skip_on_access_denied.<locals>.decoratorrx   ©rÅ  r0  rx   rÆ  ry   r?   l  s    r?   c                    s   ‡ fdd„}|S )z3Decorator to Ignore NotImplementedError exceptions.c                    s   t  ˆ ¡‡ ‡fdd„ƒ}|S )Nc                     sJ   zˆ | i |¤ŽW S  t yD   ˆd ur,ˆs,‚ dˆ j }t |¡‚Y n0 d S )Nz4%r was skipped because it raised NotImplementedError)r  rœ   rS  rÃ  )r¤   r¥   rd  rÄ  rx   ry   rµ     s    ÿz;skip_on_not_implemented.<locals>.decorator.<locals>.wrapperr¶   r¹   rÆ  r³   ry   r0  ~  s    
z*skip_on_not_implemented.<locals>.decoratorrx   rÇ  rx   rÆ  ry   r@   |  s    r@   ú	127.0.0.1c                 C   sL   t  t ¡ ¡*}| | df¡ | ¡ d W  d  ƒ S 1 s>0    Y  dS )z6Return an unused TCP port. Subject to race conditions.r   r  N)Ú
contextlibÚclosingÚsocketÚbindÚgetsockname)Zhostrã   rx   rx   ry   rQ   ”  s    rQ   c                 C   s†   |du r| t tfv rd}t | |¡}z@tjdvrB| tjtjd¡ | |¡ |tj	kr`| 
d¡ |W S  ty€   | ¡  ‚ Y n0 dS )zBinds a generic socket.N©r  r   )ÚntÚcygwinr  r^   )r   r   rË  r~   rž   Z
setsockoptZ
SOL_SOCKETZSO_REUSEADDRrÌ  r   Úlistenrv   rá   )ÚfamilyÚtypeÚaddrrã   rx   rx   ry   rR   ›  s    



rR   c                 C   sp   t js
J ‚tj | ¡rJ | ƒ‚t tj|¡}z"| | ¡ |tjkrL| 	d¡ W n t
yj   | ¡  ‚ Y n0 |S )zBind a UNIX socket.r^   )r„   r
   r~   r   r‡   rË  r   rÌ  r   rÑ  rv   rá   )rž   rÓ  rã   rx   rx   ry   rS   ¬  s    


rS   rÎ  c              	   C   sÈ   t  t | t¡¡¢}| |¡ | d¡ | ¡ }t | t¡}zL| |¡ | ¡ }| ¡ \}}||kr|||fW W  d  ƒ S | 	¡  qPW n t
y¤   | 	¡  ‚ Y n0 W d  ƒ n1 sº0    Y  dS )z^Build a pair of TCP sockets connected to each other.
    Return a (server, client) tuple.
    r^   N)rÉ  rÊ  rË  r   rÌ  rÑ  rÍ  ÚconnectrÞ   rá   r  )rÒ  rÔ  Zllr  ZcaddrÚarx   rx   ry   rT   »  s    


rT   c                 C   s   t js
J ‚d }}z@t| tjd}| d¡ t tjtj¡}| d¡ | | ¡ W n4 ty†   |durp| 	¡  |dur€| 	¡  ‚ Y n0 ||fS )zƒBuild a pair of UNIX sockets connected to each other through
    the same UNIX file name.
    Return a (server, client) tuple.
    N©rÓ  r   )
r„   r
   rS   rË  r   Zsetblockingr   rÕ  rv   rá   )rž   ZserverZclientrx   rx   ry   rU   Ò  s    


rU   c               	   c   s   g } d }}zØ|   ttjtjƒ¡ |   ttjtjƒ¡ tƒ rd|   ttjtjƒ¡ |   ttjtjƒ¡ tr¬t	r¬t
ƒ }t
ƒ }t|ƒ\}}t|tjd}|||fD ]}|   |¡ qœ| V  W | D ]}| ¡  q¸||fD ]}|durÎt|ƒ qÎn6| D ]}| ¡  qê||fD ]}|dur t|ƒ q 0 dS )z1Open as many socket families / types as possible.Nr×  )ro  rR   rË  r   r   Ú
SOCK_DGRAMr   r   r
   ÚHAS_CONNECTIONS_UNIXrJ   rU   rS   rá   rH   )ZsocksZfname1Zfname2Ús1Ús2Zs3rÕ   r5  rx   rx   ry   rV   é  s4    
ü

rV   c                 C   s   ddl }tr(tr(ts(t|tjƒs(J |ƒ‚|tjkršdd„ |  d¡D ƒ}t	|ƒdksZJ | ƒ‚|D ]"}d|  krvdks^n J | ƒ‚q^tsŽt
| ƒ} | | ¡ nb|tjkrÎt| tƒs¶J | ƒ‚tsÂt
| ƒ} | | ¡ n.|tjkròt d| ¡dusüJ | ƒ‚n
td	|ƒ‚dS )
z[Check a net address validity. Supported families are IPv4,
    IPv6 and MAC addresses.
    r   Nc                 S   s   g | ]}t |ƒ‘qS rx   )rÒ   rŒ   rx   rx   ry   r     rÝ   z%check_net_address.<locals>.<listcomp>r  r   éÿ   z([a-fA-F0-9]{2}[:|\-]?){6}zunknown family %r)Ú	ipaddressÚenumr   r"   rñ   ÚIntEnumrË  r   r  r  r   ZIPv4Addressr   rò   ZIPv6Addressr„   ZAF_LINKr#  Úmatchr†   )rÔ  rÒ  rÝ  ZoctsZnumrx   rx   ry   rP     s&    
 

rP   c                 C   sT   dd„ }dd„ }dd„ }dd„ }d	d
„ }|| ƒ || ƒ || ƒ || ƒ || ƒ dS )z*Check validity of a connection namedtuple.c                 S   sÔ   t | ƒdk}t | ƒdv s$J t | ƒƒ‚| d | jks<J | jƒ‚| d | jksTJ | jƒ‚| d | jkslJ | jƒ‚| d | jks„J | jƒ‚| d | jksœJ | jƒ‚| d | jks´J | jƒ‚|rÐ| d	 | jksÐJ | jƒ‚d S )
Né   )r  rá  r   r  r}   r   r   r^   r  )r  rf  rÒ  rÓ  ÚladdrÚraddrrÙ   rÈ   )rå   Zhas_pidrx   rx   ry   Úcheck_ntuple   s    z-check_connection_ntuple.<locals>.check_ntuplec                 S   s
  | j tttfv sJ | j ƒ‚td ur:t| j tjƒsNJ | ƒ‚nt| j tƒsNJ | ƒ‚| j tkrât | j | j	¡}t
 |¡^ z| | jd df¡ W n4 tjyÀ } z|jtjkr¬‚ W Y d }~n
d }~0 0 W d   ƒ n1 sÖ0    Y  n$| j tkr| jtjksJ | jƒ‚d S )Nr   )rÒ  r   r   r   rÞ  rñ   rß  rÒ   rË  rÓ  rÉ  rÊ  rÌ  râ  Úerrorr  ZEADDRNOTAVAILrÙ   r„   Ú	CONN_NONE)rå   rÕ   r  rx   rx   ry   Úcheck_family,  s    
8z-check_connection_ntuple.<locals>.check_familyc                 S   s†   t tdtƒ ƒ}| jtjtj|fv s,J | jƒ‚td urLt| jtjƒs`J | ƒ‚nt| jt	ƒs`J | ƒ‚| jtjkr‚| j
tjks‚J | j
ƒ‚d S )NÚSOCK_SEQPACKET)r‹   rË  ÚobjectrÓ  r   rØ  rÞ  rñ   rß  rÒ   rÙ   r„   ræ  )rå   rè  rx   rx   ry   Ú
check_typeA  s    ÿÿz+check_connection_ntuple.<locals>.check_typec                 S   s¬   | j | jfD ]š}| jttfv r†t|tƒs4J t|ƒƒ‚|s:qt|jt	ƒsTJ t|jƒƒ‚d|j  krjdksvn J |jƒ‚t
|j| jƒ q| jtkrt|tƒsJ t|ƒƒ‚qd S )Nr   iÿÿ  )râ  rã  rÒ  r   r   rñ   r˜  rÓ  ZportrÒ   rP   Zipr   rò   )rå   rÔ  rx   rx   ry   Úcheck_addrsM  s    "
z,check_connection_ntuple.<locals>.check_addrsc                 S   s†   t | jtƒsJ | jƒ‚dd„ ttƒD ƒ}| j|v s<J | jƒ‚| jttfv rl| jt	krl| jtj
ks‚J | jƒ‚n| jtj
ks‚J | jƒ‚d S )Nc                 S   s    g | ]}|  d ¡rtt|ƒ‘qS )ZCONN_r‰   rŒ   rx   rx   ry   r   \  s   
ÿzAcheck_connection_ntuple.<locals>.check_status.<locals>.<listcomp>)rñ   rÙ   rò   rÎ   r„   rÒ  r   r   rÓ  r   ræ  )rå   Zvalidsrx   rx   ry   Úcheck_statusZ  s    z-check_connection_ntuple.<locals>.check_statusNrx   )rå   rä  rç  rê  rë  rì  rx   rx   ry   Úcheck_connection_ntuple  s    
rí  c                 C   sN   zddl }t|dƒst‚W n$ ty>   ddl}| | ¡ Y S 0 | | ¡S dS )z,Backport of importlib.reload of Python 3.3+.r   NÚreload)Ú	importlibr"  r‹  Úimprî  )Úmodulerï  rð  rx   rx   ry   rW   p  s    
rW   c                 C   sœ   t j t j | ¡¡d }tjd dkr:dd l}| || ¡S tjd d… dkrfddlm	} ||| ƒ 
¡ S dd l}|j || ¡}|j |¡}|j |¡ |S d S )Nr   r}   r   )ÚSourceFileLoader)r~   r   ÚsplitextrÑ   r   rƒ   rð  Zload_sourceÚimportlib.machineryrò  Úload_moduleÚimportlib.utilÚutilÚspec_from_file_locationÚmodule_from_specÚloaderÚexec_module)r   rž   rð  rò  rï  ÚspecÚmodrx   rx   ry   rX   }  s    rX   c                 C   s   t  | t¡ dS )zRaise a warning msg.N)ÚwarningsrY   ÚUserWarning)rd  rx   rx   ry   rY   ’  s    rY   c                 C   sV   t | ƒ}|j}t|ƒdks&|d tkr*dS t|ddƒ}t|tƒsDdS tdd„ |D ƒƒS )z-Check if object is an instance of namedtuple.r  r   FÚ_fieldsNc                 s   s   | ]}t |ƒtkV  qd S r    )rÓ  rò   )r   Únrx   rx   ry   Ú	<genexpr>   rÝ   z is_namedtuple.<locals>.<genexpr>)rÓ  Ú	__bases__r  r˜  r‹   rñ   rª  )rŽ   ÚtÚbrë   rx   rx   ry   r[   —  s    
r[   c                 #   s|   t rdnd‰ d‰t| ˆ d}‡ ‡fdd„t ¡  ¡ D ƒ}t |¡}t ||¡ zt	 
|¡ |V  W t|ƒ n
t|ƒ 0 dS )zÂCtx manager which picks up a random shared CO lib used
        by this process, copies it in another location and loads it
        in memory via ctypes. Return the new absolutized path.
        r{   r|   z.sorG  c                    s6   g | ].}t j |j¡d  ˆkrˆ |j ¡ v r|j‘qS )r  )r~   r   ró  ÚlowerrŒ   ©rw   Úextrx   ry   r   ­  s   þú'copyload_shared_lib.<locals>.<listcomp>N)r"   rJ   r„   r…   rh   r£  r¤  r?  rJ  ÚctypesZCDLLrH   )rH  ÚdstÚlibsrâ   rx   r  ry   rZ   ¤  s    

rZ   c           	      #   s  ddl m} ddl m} d‰ t| ˆ  d}‡ fdd„t ¡  ¡ D ƒ}trb|sbdd„ t ¡  ¡ D ƒ}t 	|¡}t
 ||¡ d	}zPt  |¡}|V  W |d	urÄt jjj}|jg|_||jƒ}|dkrÄ|ƒ  t|ƒ nB|d	urt jjj}|jg|_||jƒ}|dkr|ƒ  t|ƒ 0 d	S )
zÖCtx manager which picks up a random shared DLL lib used
        by this process, copies it in another location and loads it
        in memory via ctypes.
        Return the new absolutized, normcased path.
        r   )Úwintypes)ÚWinErrorz.dllrG  c                    sF   g | ]>}|j  ¡  ˆ ¡rd tj  |j ¡ ¡ v rd|j  ¡ vr|j ‘qS )r|   Zwow64)r   r  rõ   r~   rÑ   rŒ   ©r  rx   ry   r   Ã  s   ýr	  c                 S   s(   g | ] }d t j |j¡ ¡ v r|j‘qS )r{   )r~   r   rÑ   r  rŒ   rx   rx   ry   r   È  s   ÿN)r
  r  r  rJ   r„   r…   rh   r"   r£  r¤  r?  rJ  ZWinDLLZwindllZkernel32ÚFreeLibraryZHMODULEÚargtypesZ_handlerH   )	rH  r  r  r  r  râ   Úcfiler  r9  rx   r  ry   rZ   ¸  s6    





ú




c                   C   s   t dd d S )NTr  )r;   rx   rx   rx   ry   Úcleanup_test_procså  s    r  c                 C   s
   t  | ¡S r    )r   Úexit)r  Úframerx   rx   ry   rÜ   ï  rÝ   rÜ   )N)F)TF)N)r  N)N)N)rÈ  )rÎ  )r  )r  )°r°   Z
__future__r   ÚatexitrÉ  r
  r  r·   rl  rÁ  r~   r£  r#  rß   r?  rý   rË  r;  rs   r   rN  rÏ   r–   rª   rþ  r   r   r   r„   r   r   r   r	   r
   r   r   Zpsutil._commonr   r   r   Zpsutil._compatr   r   r   r   r   r   r   r   rS  Z	unittest2r   r‹  Úcatch_warningsÚsimplefilterrƒ   rÞ  Ú__all__Úbuiltin_module_namesr"   rf   r   r\   r)   Úmaxsizer,   r!   r    r+   r   rž   r—  r&   r'   Údecoder(   r“  r  ZASCII_FSr   r€   r­   rD  Ú__file__r$   r%   ZHERErÙ  r"  r…   r-   r.   r¿  r/   r1   r2   ZHAS_NET_IO_COUNTERSr3   r0   r4   r5   rI  rm   r6   rv   r7   r8   ZHAS_THREADSÚgetuidZSKIP_SYSCONSrˆ   r#   rè   Údevnullr   Úregisterrá   rÎ   r*   r‹   ré  r   r©   rÆ   rÓ   r§   r‘   rº   r<   r>   r=   r9   rø   r½  r:   r;   rL   rK   r'  rú   rN   rW  rO   rM   rH   rC  ÚcontextmanagerrG   rI   rJ   rO  rC   ZskipIfrB   rF   r¥  rD   rE   rÂ  rA   r?   r@   rQ   rR   rS   rT   rU   rV   rP   rí  rW   rX   rY   r[   rZ   r  rx   rx   rx   ry   Ú<module>   sp  


.
-



ÿ






 0'
&-

X
%:
ÿ


ÿÿ
!



1
 [	 
B





R,
