U
    襡c>                     @   s  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mZ ddlmZ ejrddlmZ G d	d
 d
Ze jeje ejd dddZG dd dejZejejeeejf  eejdddZ G dd dZ!G dd dZ"dS )    N)TracebackType   )
formatting)termui)utils)_find_binary_reader)BaseCommandc                   @   s   e Zd ZejejddddZeejdddZe	e	dd	d
Z
dee	dddZdee	dddZdee	dddZeje	 dddZeje	 dddZedddZdS )EchoingStdinN)inputoutputreturnc                 C   s   || _ || _d| _d S )NF)_input_output_paused)selfr
   r    r   1/tmp/pip-unpacked-wheel-3soeww7k/click/testing.py__init__   s    zEchoingStdin.__init__)xr   c                 C   s   t | j|S N)getattrr   )r   r   r   r   r   __getattr__   s    zEchoingStdin.__getattr__)rvr   c                 C   s   | j s| j| |S r   )r   r   write)r   r   r   r   r   _echo   s    zEchoingStdin._echo)nr   c                 C   s   |  | j|S r   )r   r   readr   r   r   r   r   r   #   s    zEchoingStdin.readc                 C   s   |  | j|S r   )r   r   read1r   r   r   r   r   &   s    zEchoingStdin.read1c                 C   s   |  | j|S r   )r   r   readliner   r   r   r   r    )   s    zEchoingStdin.readliner   c                    s    fdd j  D S )Nc                    s   g | ]}  |qS r   r   .0r   r   r   r   
<listcomp>-   s     z*EchoingStdin.readlines.<locals>.<listcomp>)r   	readlinesr%   r   r%   r   r'   ,   s    zEchoingStdin.readlinesc                    s   t  fdd jD S )Nc                 3   s   | ]}  |V  qd S r   r"   r#   r%   r   r   	<genexpr>0   s     z(EchoingStdin.__iter__.<locals>.<genexpr>)iterr   r%   r   r%   r   __iter__/   s    zEchoingStdin.__iter__c                 C   s
   t | jS r   )reprr   r%   r   r   r   __repr__2   s    zEchoingStdin.__repr__)r   )r   )r   )__name__
__module____qualname__tBinaryIOr   strAnyr   bytesr   intr   r   r    Listr'   Iteratorr*   r,   r   r   r   r   r	      s   r	   )streamr   c                 c   s&   | d krd V  nd| _ d V  d| _ d S )NTF)r   )r8   r   r   r   _pause_echo6   s
    r9   c                       sR   e Zd Zejeeejdd fddZeedddZ	eeddd	Z
  ZS )
_NamedTextIOWrapperN)buffernamemodekwargsr   c                    s    t  j|f| || _|| _d S r   )superr   _name_mode)r   r;   r<   r=   r>   	__class__r   r   r   A   s    z_NamedTextIOWrapper.__init__r!   c                 C   s   | j S r   )r@   r%   r   r   r   r<   H   s    z_NamedTextIOWrapper.namec                 C   s   | j S r   )rA   r%   r   r   r   r=   L   s    z_NamedTextIOWrapper.mode)r-   r.   r/   r0   r1   r2   r3   r   propertyr<   r=   __classcell__r   r   rB   r   r:   @   s      r:   )r
   charsetr   c                 C   sd   t | dr0tttj| }|d k	r(|S td| d kr>d} nt| trR| |} t	
tt| S )Nr   z.Could not find binary reader for input stream.    )hasattrr   r0   castIO	TypeError
isinstancer2   encodeioBytesIOr4   )r
   rF   r   r   r   r   make_input_streamQ   s    


rP   c                   @   s   e Zd ZdZddeeje ejeeje	 ejej
eje	 e	ef  dddZeeddd	Zeedd
dZeedddZedddZdS )Resultz3Holds the captured result of an invoked CLI script.N	CliRunnerrunnerstdout_bytesstderr_bytesreturn_value	exit_code	exceptionexc_infoc                 C   s.   || _ || _|| _|| _|| _|| _|| _d S r   rS   )r   rT   rU   rV   rW   rX   rY   rZ   r   r   r   r   h   s    zResult.__init__r!   c                 C   s   | j S )z(The (standard) output as unicode string.)stdoutr%   r   r   r   r      s    zResult.outputc                 C   s   | j | jjdddS )z&The standard output as unicode string.replace

)rU   decoderT   rF   r\   r%   r   r   r   r[      s     zResult.stdoutc                 C   s,   | j dkrtd| j | jjdddS )z%The standard error as unicode string.Nzstderr not separately capturedr\   r]   r^   )rV   
ValueErrorr_   rT   rF   r\   r%   r   r   r   stderr   s    
 zResult.stderrc                 C   s,   | j rt| j nd}dt| j d| dS )Nokay< >)rY   r+   typer-   )r   Zexc_strr   r   r   r,      s    zResult.__repr__)N)r-   r.   r/   __doc__r4   r0   Optionalr3   r5   BaseExceptionTupleTyper   r   rD   r2   r   r[   ra   r,   r   r   r   r   rQ   e   s(    rQ   c                
   @   sv  e Zd ZdZdeejejeeje f  eeddddZ	d	ed
ddZ
dejejeeje f  ejeeje f dddZejdejejeeejf  ejejeeje f  eejejejejej f  dddZdd	ejejeeje f  ejejeeejf  ejejeeje f  eeejedddZejdejejeejf  eje dddZdS )rR   a  The CLI runner provides functionality to invoke a Click command line
    script for unittesting purposes in a isolated environment.  This only
    works in single-threaded systems without any concurrency as it changes the
    global interpreter state.

    :param charset: the character set for the input and output data.
    :param env: a dictionary with environment variables for overriding.
    :param echo_stdin: if this is set to `True`, then reading from stdin writes
                       to stdout.  This is useful for showing examples in
                       some circumstances.  Note that regular prompts
                       will automatically echo the input.
    :param mix_stderr: if this is set to `False`, then stdout and stderr are
                       preserved as independent streams.  This is useful for
                       Unix-philosophy apps that have predictable stdout and
                       noisy stderr, such that each may be measured
                       independently
    utf-8NFT)rF   env
echo_stdin
mix_stderrr   c                 C   s    || _ |pi | _|| _|| _d S r   )rF   rm   rn   ro   )r   rF   rm   rn   ro   r   r   r   r      s    
zCliRunner.__init__r   )clir   c                 C   s
   |j pdS )zGiven a command object it will return the default program name
        for it.  The default is the `name` attribute or ``"root"`` if not
        set.
        root)r<   )r   rp   r   r   r   get_default_prog_name   s    zCliRunner.get_default_prog_name)	overridesr   c                 C   s   t | j}|r|| |S )z8Returns the environment overrides for invoking a script.)dictrm   update)r   rs   r   r   r   r   make_env   s    

zCliRunner.make_env)r
   rm   colorr   c                 #   sx  t || j}d}tj}tj}tj}tj}	dt_| |}t	
 }
| jr^ttjt||
 }}t|| jddd t_| jrd_t|
| jdddt_d}| jrtjt_nt	
 }t|| jd	dd
dt_t|dtjt tdfdd}t|dtjt tdfdd}t|ttddd}| dtjtj tjt td fdd}tj}tj}tj}tj}|t_|t_|t_|t_i }zl| D ]T\}}tj "|||< |dkrztj |= W n t!k
r   Y nX n
|tj |< q|
|fV  W 5 | D ]D\}}|dkr4ztj |= W n t!k
r0   Y nX n
|tj |< q|t_|t_|t_|t_|t_|t_|t_|	t_X dS )an  A context manager that sets up the isolation for invoking of a
        command line tool.  This sets up stdin with the given input data
        and `os.environ` with the overrides from the given dictionary.
        This also rebinds some internals in Click to be mocked (like the
        prompt functionality).

        This is automatically done in the :meth:`invoke` method.

        :param input: the input stream to put into sys.stdin.
        :param env: the environment overrides as dictionary.
        :param color: whether the output should contain color codes. The
                      application can still override this explicitly.

        .. versionchanged:: 8.0
            ``stderr`` is opened with ``errors="backslashreplace"``
            instead of the default ``"strict"``.

        .. versionchanged:: 4.0
            Added the ``color`` parameter.
        NP   z<stdin>r)encodingr<   r=   r   z<stdout>wz<stderr>backslashreplace)rz   r<   r=   errors)promptr   c                    s>   t j| pd   d}t j| d t j  |S )N r]   r^   )sysr[   r   r    rstripflush)r~   val
text_inputr   r   visible_input  s
    
z*CliRunner.isolation.<locals>.visible_inputc                    s.   t j| pd d t j    dS )Nr   r^   r]   )r   r[   r   r   r    r   )r~   r   r   r   hidden_input  s    
z)CliRunner.isolation.<locals>.hidden_input)echor   c                 S   s*   t jd}| rt j| t j  |S )Nr   )r   stdinr   r[   r   r   )r   charr   r   r   _getchar#  s
    
z%CliRunner.isolation.<locals>._getchar)r8   rw   r   c                    s   |d kr  S | S r   r   )r8   rw   )default_colorr   r   should_strip_ansi/  s    z.CliRunner.isolation.<locals>.should_strip_ansi)N)N)NN)#rP   rF   r   r   r[   ra   r   ZFORCED_WIDTHrv   rN   rO   rn   r0   rI   r1   r	   r:   _CHUNK_SIZEro   r9   rh   r2   boolrJ   r   Zvisible_prompt_funcZhidden_prompt_funcr   r   r   itemsosenviron	Exceptionget)r   r
   rm   rw   Zbytes_inputZ
echo_inputZ	old_stdinZ
old_stdoutZ
old_stderrZold_forced_widthZbytes_outputZbytes_errorr   r   r   r   Zold_visible_prompt_funcZold_hidden_prompt_funcZold__getchar_funcZold_should_strip_ansiZold_envkeyvaluer   )r   r   r   	isolation   s    
       
	   
 

zCliRunner.isolation)rp   argsr
   rm   catch_exceptionsrw   extrar   c                 K   s  d}| j |||dz}	d}
d}d}t|tr8t|}z|d}W n tk
rd   | |}Y nX zz|jf |pvd|d|}
W n tk
r } ztt }ttjtjttjf  |j}|dkrd}|dkr|}t|tstj	t| tj	d d}|}W 5 d}~X Y n< tk
rT } z|s4 |}d}t }W 5 d}~X Y nX W 5 tj	
  |	d  }| jr~d}n|	d  }X W 5 Q R X t| |||
|||d	S )
a  Invokes a command in an isolated environment.  The arguments are
        forwarded directly to the command line script, the `extra` keyword
        arguments are passed to the :meth:`~clickpkg.Command.main` function of
        the command.

        This returns a :class:`Result` object.

        :param cli: the command to invoke
        :param args: the arguments to invoke. It may be given as an iterable
                     or a string. When given as string it will be interpreted
                     as a Unix shell command. More details at
                     :func:`shlex.split`.
        :param input: the input data for `sys.stdin`.
        :param env: the environment overrides.
        :param catch_exceptions: Whether to catch any other exceptions than
                                 ``SystemExit``.
        :param extra: the keyword arguments to pass to :meth:`main`.
        :param color: whether the output should contain color codes. The
                      application can still override this explicitly.

        .. versionchanged:: 8.0
            The result object has the ``return_value`` attribute with
            the value returned from the invoked command.

        .. versionchanged:: 4.0
            Added the ``color`` parameter.

        .. versionchanged:: 3.0
            Added the ``catch_exceptions`` parameter.

        .. versionchanged:: 3.0
            The result object has the ``exc_info`` attribute with the
            traceback if available.
        N)r
   rm   rw   r   	prog_namer   r   )r   r   r^   rS   )r   rL   r2   shlexsplitpopKeyErrorrr   r   r[   r   getvaluero   main
SystemExitrZ   r0   rI   rh   Unionr5   r3   coder   r   rQ   )r   rp   r   r
   rm   r   rw   r   rZ   Z
outstreamsrW   rY   rX   r   r[   ra   eZe_coder   r   r   invoke]  sZ    ,

 
zCliRunner.invoke)temp_dirr   c                 c   sn   t  }tj|d}t | zt	t
|V  W 5 t | |dkrhzt| W n tk
rf   Y nX X dS )a  A context manager that creates a temporary directory and
        changes the current working directory to it. This isolates tests
        that affect the contents of the CWD to prevent them from
        interfering with each other.

        :param temp_dir: Create the temporary directory under this
            directory. If given, the created directory is not removed
            when exiting.

        .. versionchanged:: 8.0
            Added the ``temp_dir`` parameter.
        )dirN)r   getcwdtempfilemkdtempchdirshutilrmtreeOSErrorr0   rI   r2   )r   r   cwddtr   r   r   isolated_filesystem  s    

zCliRunner.isolated_filesystem)rl   NFT)N)NNF)NNNTF)N)r-   r.   r/   rg   r2   r0   rh   Mappingr   r   rr   rv   
contextlibcontextmanagerr   r4   rJ   r7   rj   rN   rO   r   Sequencer3   rQ   r   r   PathLiker   r   r   r   r   rR      sd        	         e rR   )#r   rN   r   r   r   r   r   typingr0   typesr   r   r   r   r   _compatr   TYPE_CHECKINGcorer   r	   r   rh   r7   r9   TextIOWrapperr:   r   r2   r4   rJ   r1   rP   rQ   rR   r   r   r   r   <module>   s0   "	 :