
    9[g1                    F   d Z ddlmZ ddlZddlmZ ddlZddlZddlm	Z	 ddl
Z
ddlm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 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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)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 ddl1m2Z2 ddl3m4Z4 ddl3m5Z5 dd l6m7Z7 dd!l6m8Z8 dd"l9m:Z: dd#l9m;Z; dd$l9m<Z< erdd%l=m>Z> d&Z?d'Z@d(ZA G d) d*ej                        ZC G d+ d,e      ZDdCd-ZEdDd.ZFdEd/ZG e0d01      dFd2       ZHej                   G d3 d4             ZJe G d5 d6             ZKdGd7ZLdHd8ZM	 	 	 	 	 	 	 	 	 	 dId9ZN	 	 	 	 	 	 dJd:ZOd;d;d<d=d>ZPd<ZQdKd?ZRdLd@ZSdMdAZTdNdBZUy)OzsTerminal reporting of the full testing process.

This is a good source for looking at the various reporting hooks.
    )annotationsN)Counter)partial)Path)Any)Callable)ClassVar)final)	Generator)Literal)Mapping)
NamedTuple)Sequence)TextIO)TYPE_CHECKING)nodes)timing)ExceptionInfo)ExceptionRepr)TerminalWriter)wcswidth)running_on_ci)_PluggyPlugin)Config)ExitCode)hookimpl)Parser)Item)Node)absolutepath)bestrelpath)
BaseReport)CollectReport)
TestReport)Sessiong      ?)failedpassedskipped
deselectedxfailedxpassedwarningserrorfEc                  `     e Zd ZdZ	 	 	 d	 	 	 	 	 	 	 	 	 	 	 d fdZ	 d	 	 	 	 	 	 	 	 	 ddZ xZS )MoreQuietActionzA modified copy of the argparse count action which counts down and updates
    the legacy quiet attribute at the same time.

    Used to unify verbosity handling.
    c                0    t         |   ||d|||       y )Nr   )option_stringsdestnargsdefaultrequiredhelp)super__init__)selfr2   r3   r5   r6   r7   	__class__s         K/var/www/html/bid-api/venv/lib/python3.12/site-packages/_pytest/terminal.pyr9   zMoreQuietAction.__init__S   s)     	) 	 	
    c                    t        || j                  d      dz
  }t        || j                  |       t        |dd      dz   |_        y )Nr      quiet)getattrr3   setattrr@   )r:   parser	namespacevaluesoption_string	new_counts         r<   __call__zMoreQuietAction.__call__d   s@     Ityy!4q8		499i0!)Wa81<	r=   )NFN)r2   zSequence[str]r3   strr5   objectr6   boolr7   
str | NonereturnNoneN)
rC   zargparse.ArgumentParserrD   zargparse.NamespacerE   zstr | Sequence[object] | NonerF   rL   rM   rN   )__name__
__module____qualname____doc__r9   rH   __classcell__)r;   s   @r<   r0   r0   L   s     
%
 
 	

 
 
 

, %)
='
= &
= .	
=
 "
= 

=r=   r0   c                  0    e Zd ZU dZded<   ded<   ded<   y)TestShortLogReportuG  Used to store the test status result category, shortletter and verbose word.
    For example ``"rerun", "R", ("RERUN", {"yellow": True})``.

    :ivar category:
        The class of result, for example ``“passed”``, ``“skipped”``, ``“error”``, or the empty string.

    :ivar letter:
        The short letter shown as testing progresses, for example ``"."``, ``"s"``, ``"E"``, or the empty string.

    :ivar word:
        Verbose word is shown as testing progresses in verbose mode, for example ``"PASSED"``, ``"SKIPPED"``,
        ``"ERROR"``, or the empty string.
    rI   categoryletterz$str | tuple[str, Mapping[str, bool]]wordN)rP   rQ   rR   rS   __annotations__ r=   r<   rV   rV   q   s     MK
..r=   rV   c           	        | j                  ddd      }|j                  ddddd	d
       |j                  ddddd       |j                  ddddd       |j                  ddddd       |j                  ddt        dd	d       |j                  dd	t        dd       |j                  d d!d"t        d#d$%       |j                  d&d'dd(dd)*       |j                  d+d,dd-dd.       |j                  d/dd-d01       |j                  d2d3d!d4d5g d6d78       |j                  d9dd:dd;       |j                  d<d!d=g d>d?d@A       |j                  dBdCdddDE       |j                  dFdGd!dGd5g dHdI8       |j                  dJdKdKdLgdMN       | j                  dOdPdQR       t        j                  | t        j                  dST       y )UNzterminal reporting	Reportinggeneral)afterz-vz	--verbosecountr   verbosezIncrease verbosity)actionr5   r3   r7   z--no-header
store_trueF	no_headerzDisable headerz--no-summary
no_summaryzDisable summaryz--no-fold-skippedstore_falsefold_skippedTz+Do not fold skipped tests in short summary.)rb   r3   r5   r7   z-qz--quietzDecrease verbosityz--verbosityzSet verbosity. Default: 0.)r3   typer5   r7   z-rstorereportcharscharsa  Show extra test summary info as specified by chars: (f)ailed, (E)rror, (s)kipped, (x)failed, (X)passed, (p)assed, (P)assed with output, (a)ll except passed (p/P), or (A)ll. (w)arnings are enabled by default (see --disable-warnings), 'N' can be used to reset the list. (default: 'fE').)rb   r3   r5   metavarr7   z--disable-warningsz--disable-pytest-warningsdisable_warningszDisable warnings summary)r5   r3   rb   r7   z-lz--showlocals
showlocalsz/Show locals in tracebacks (disabled by default)z--no-showlocalszFHide locals in tracebacks (negate --showlocals passed through addopts))rb   r3   r7   z--tbstyletbstyleauto)rq   longshortnolinenativez5Traceback print mode (auto/long/short/line/native/no))rl   rb   r3   r5   choicesr7   z
--xfail-tbxfail_tbz1Show tracebacks for xfail (as long as --tb != no)z--show-captureshowcapture)rt   stdoutstderrlogallr}   zOControls how captured stdout/stderr/log is shown on failed tests. Default: all.)rb   r3   rw   r5   r7   z--fulltracez--full-tracez,Don't cut any tracebacks (default is to cut))rb   r5   r7   z--colorcolor)yesrt   rq   z#Color terminal output (yes/no/auto)z--code-highlightr   rt   zSWhether code should be highlighted (only if --color is also enabled). Default: yes.)r5   rw   r7   console_output_stylezConsole output: "classic", or with additional progress information ("progress" (percentage) | "count" | "progress-even-when-capture-no" (forces progress even when capture=no)progress)r7   r5   zSpecify a verbosity level for test case execution, overriding the main level. Higher levels will provide more detailed information about each test case executed.)r7   )	getgroup
_addoptionr0   int_REPORTCHARS_DEFAULTaddinir   _add_verbosity_iniVERBOSITY_TEST_CASES)rC   groups     r<   pytest_addoptionr      s   OO0+YOOE	!   
   
   
:   
!   
)   
$>   
#'   
>   
U	   
AD   
@   
8   
;   
%2   
	   MM)    ##b	r=   c                "   t        | t        j                        | j                  j	                  d       | j
                  j                  s| j
                  j                  r,fd}| j                  j                  j                  d|       y y )Nterminalreporterc                l    dj                  t        t        |            }j                  d|z          y )N z[traceconfig] )joinmaprI   
write_line)tagsargsmsgreporters      r<   mywriterz"pytest_configure.<locals>.mywriter  s+    ((3sD>*C 03 67r=   zpytest:config)TerminalReportersysrz   pluginmanagerregisteroptiondebugtraceconfigtracerootsetprocessor)configr   r   s     @r<   pytest_configurer     si    

3H
!!(,>?}}fmm77	8 	&&A 8r=   c                R   | j                   j                  }ddh}d}|D ]8  }||v r|j                         }|dk(  rd}|dk(  rd}'|dk(  rd}/||vs4||z  }: | j                   j                  sd	|vrd	|z   }|S | j                   j                  rd	|v r|j	                  d	d      }|S )
NFS asxXEfAPpsxXEfNw)r   rj   lowerrm   replace)r   rj   old_aliases
reportoptschars        r<   getreportoptr   #  s    }}00K*KJ;::<D3; JS["JS[J#$J  ==))c.C:%
  
	'	'C:,=''R0
r=   Ttrylastc                    d}| j                   rd}n| j                  rd}| j                  }| j                  dv r	|dk(  rd}d}|||j	                         fS )Nr   .s)collectsetupteardownr&   r-   E)r'   r(   outcomewhenupper)reportrX   r   s      r<   pytest_report_teststatusr   <  sY    F}}	>>G{{667h;NFGMMO++r=   c                  N    e Zd ZU dZded<   dZded<   dZded<   d	Zd
ed<   ddZy)WarningReportao  Simple structure to hold warnings information captured by ``pytest_warning_recorded``.

    :ivar str message:
        User friendly message about the warning.
    :ivar str|None nodeid:
        nodeid that generated the warning (see ``get_location``).
    :ivar tuple fslocation:
        File system location of the source of the warning (see ``get_location``).
    rI   messageNrL   nodeidztuple[str, int] | None
fslocationTr	   count_towards_summaryc                    | j                   r| j                   S | j                  r?| j                  \  }}t        |j                  j                  t        |            }| d| S y)zSReturn the more user-friendly information about the location of a warning, or None.:N)r   r   r!   invocation_paramsdirr    )r:   r   filenamelinenumrelpaths        r<   get_locationzWarningReport.get_location^  sY    ;;;;?? $Hg!&":":">">X@VWGYay))r=   )r   r   rM   rL   )	rP   rQ   rR   rS   rZ   r   r   r   r   r[   r=   r<   r   r   L  s3     LFJ)-J&-&*8*r=   r   c                     e Zd ZdSdTdZdUdZedVd       ZedWd       ZedWd       ZedWd       Z	edWd       Z
e
j                  dXd	       Z
edWd
       ZdYdZdZdZd[d\dZd]dZdddd	 	 	 	 	 	 	 	 	 	 	 d^dZddd_dZd]dZd`dZdadZ	 	 db	 	 	 	 	 	 	 	 	 dcdZdddedZdfdZdgdZdhdZ	 	 	 	 	 	 didZdjdZdkd Z	 	 	 	 	 	 dld!Zdmd"ZedWd#       Z  e!d$%      dnd&       Z"dod'Z#d]d(Z$d]d)Z%edVd*       Z&d]d+Z'dpd,Z(dqdrd-Z) e!d$.      dsd/       Z*	 	 	 	 dtd0Z+dud1Z,dsd2Z-dkd3Z. e!d$%      	 	 	 	 	 	 dvd4       Z/ e!d$%      dwd5       Z0dxd6Z1d]d7Z2d]d8Z3	 	 	 	 	 	 	 	 	 	 dyd9Z4d: Z5d; Z6dzd<Z7d]d=Z8d]d>Z9d]d?Z:	 	 	 	 	 	 	 	 d{d@Z;d|dAZ<d}dBZ=d~dCZ>d]dDZ?d]dEZ@ddF	 	 	 	 	 	 	 	 	 ddGZAd]dHZBddIZCd]dJZDd]dKZEddLZFddMZGd]dNZHddOZIddPZJ	 	 ddQZK	 	 ddRZLy)r   Nc                v   dd l }|| _        d| _        d | _        d | _        i | _        d | _        d | _        |j                  j                  | _
        |t        j                  }|j                  j                  ||      | _        | j                  j                  | _        d | _        t%        |      | _        |j(                  j*                  | _        | j                  j.                  | _        |j1                         | _        t3               | _        | j7                         | _        d | _        d | _        d | _        y Nr   ) _pytest.configr   _numcollected_session_showfspathstats_main_color_known_typesr   r   	startpathr   rz   create_terminal_writer_tw	fullwidth_screen_widthcurrentfspathr   rj   r   rg   foldskipped	hasmarkupisattyset_progress_nodeids_reported_determine_show_progress_info_show_progress_info_collect_report_last_write_already_displayed_warnings_keyboardinterrupt_memo)r:   r   file_pytests       r<   r9   zTerminalReporter.__init__k  s    (,(,+-
'+.21155<::D>>88F!XX//6:'/!==55++kkm47E'#'#E#E#G 8<'7;(=A$r=   c                   | j                   j                  dd      dk(  r| j                   j                  d      dk7  ry| j                   j                  dd      ry| j                   j                  d      }|dv ry|d	k(  ry	y)
zRReturn whether we should display progress information based on the current config.capturert   r   progress-even-when-capture-noF	setupshow>   r   r   r   r`   )r   	getoptiongetini)r:   cfgs     r<   r   z.TerminalReporter._determine_show_progress_info  s    
 KK!!)T2d:""#9:./ ;;  e4;;%%&<=??G^r=   c                F    | j                   j                  j                  }|S rO   )r   r   ra   )r:   	verbositys     r<   r   zTerminalReporter.verbosity  s    ++33	r=   c                     | j                   dk\  S r   )r   r:   s    r<   
showheaderzTerminalReporter.showheader  s    ~~""r=   c                T    t        | j                  j                  j                        S rO   )rK   r   r   rd   r   s    r<   rd   zTerminalReporter.no_header  s    DKK&&0011r=   c                T    t        | j                  j                  j                        S rO   )rK   r   r   re   r   s    r<   re   zTerminalReporter.no_summary  s    DKK&&1122r=   c                    | j                   ,| j                  j                  t        j                        dk\  S | j                   S r   )r   r   get_verbosityr   r   r   s    r<   
showfspathzTerminalReporter.showfspath  s:    #;;,,V-H-HIQNNr=   c                    || _         y rO   )r   )r:   values     r<   r   zTerminalReporter.showfspath  s
     r=   c                Z    | j                   j                  t        j                        dkD  S r   )r   r   r   r   r   s    r<   showlongtestinfoz!TerminalReporter.showlongtestinfo  s"    {{(()D)DEIIr=   c                H    dddj                  ||      }|| j                  v S )Nxr   )r*   r(   )getrj   )r:   r   s     r<   hasoptzTerminalReporter.hasopt  s*    3/33D$?t''''r=   c                   | j                   j                  |j                  d      d   z  }| j                  || j                  k7  r}| j                  | j                  r| j                          || _        t        | j                  |      }| j                  j                          | j                  j                  |dz           | j                  j                  |fddi| y )N::r   r   flushT)r   rootpathsplitr   r   )_write_progress_information_filling_spacer!   r   r   ru   write)r:   r   resmarkupfspath	relfspaths         r<   write_fspath_resultz$TerminalReporter.write_fspath_result  s    %%T(:1(==%43E3E)E!!-$2J2J>>@!'D#DNNF;IHHMMOHHNN9s?+s1$1&1r=   c                    | j                   |k7  r<| j                  j                          || _         | j                  j                  |       |r% | j                  j                  |fi | d| _         y y )N)r   r   ru   r
  )r:   prefixextrakwargss       r<   write_ensure_prefixz$TerminalReporter.write_ensure_prefix  s\    'HHMMO!'DHHNN6"DHHNN5+F+!#D r=   c                `    | j                   r"| j                  j                          d | _         y y rO   )r   r   ru   r   s    r<   ensure_newlinezTerminalReporter.ensure_newline  s%    HHMMO!%D r=   F   
)r  marginline_sepc                   | j                   j                  }|j                  t        j                  d|z  |z   | j
                  |z
  dd            }||d } | j                   j                  |fd|i| y)z+Wrap message with margin for progress info.r   TF)widthdrop_whitespacereplace_whitespaceNr  )r   width_of_current_liner   textwrapwrapr   r
  )r:   contentr  r  r  r  r   wrappeds           r<   
wrap_writezTerminalReporter.wrap_write  s|     !% > >--MM++g5((61 $#(	
 /01w6e6v6r=   )r  c               B     | j                   j                  |fd|i| y )Nr  )r   r
  )r:   r#  r  r  s       r<   r
  zTerminalReporter.write  s    w6e6v6r=   c                8    | j                   j                          y rO   )r   r  r   s    r<   r  zTerminalReporter.flush  s    r=   c                    t        |t              st        |d      }| j                           | j                  j                  |fi | y )Nr   )errors)
isinstancerI   r  r   ru   )r:   ru   r  s      r<   r   zTerminalReporter.write_line  s;    $$tI.Dd%f%r=   c                    |j                  dd      }|r+| j                  j                  t        |      z
  dz
  }d|z  }nd}t	        |      } | j                  j
                  d|z   |z   fi | y)a-  Rewinds the terminal cursor to the beginning and writes the given line.

        :param erase:
            If True, will also add spaces until the full terminal width to ensure
            previous lines are properly erased.

        The rest of the keyword arguments are markup instructions.
        eraseFr?   r   r   N)popr   r   lenrI   r
  )r:   ru   r  r,  
fill_countfills         r<   rewritezTerminalReporter.rewrite  sl     

7E*++c$i7!;J#DD4ytd{T)4V4r=   c                b    | j                           | j                  j                  |||fi | y rO   )r  r   sep)r:   r4  titler   r  s        r<   	write_sepzTerminalReporter.write_sep  s+     	S%5f5r=   c                @     | j                   j                  ||fi | y rO   )r   r4  )r:   r5  r4  kws       r<   sectionzTerminalReporter.section  s    S%&2&r=   c                >     | j                   j                  |fi | y rO   )r   ru   )r:   r   r8  s      r<   ru   zTerminalReporter.line  s    c R r=   c                    || j                   v}| j                   j                  |g       j                  |       |r| j                          y y rO   )r   
setdefaultextend_set_main_color)r:   rW   itemsset_main_colors       r<   
_add_statszTerminalReporter._add_stats  sC    !3

h+2259  " r=   c                j    t        |      j                  d      D ]  }| j                  d|z           y)Nr  zINTERNALERROR> T)rI   r  r   )r:   excreprru   s      r<   pytest_internalerrorz%TerminalReporter.pytest_internalerror!  s0    L&&t,DOO-45 -r=   c                    ddl m} |j                  |j                  f} ||      }t	        |||      }| j                  d|g       y )Nr   )warning_record_to_str)r   r   r   r,   )_pytest.warningsrF  r   linenor   rA  )r:   warning_messager   rF  r   r   warning_reports          r<   pytest_warning_recordedz(TerminalReporter.pytest_warning_recorded&  sK    
 	;$--/E/EE
'8&!76
 	
^$45r=   c                r    | j                   j                  j                  rd| }| j                  |       y y )NzPLUGIN registered: )r   r   r   r   )r:   pluginr   s      r<   pytest_plugin_registeredz)TerminalReporter.pytest_plugin_registered5  s4    ;;))'x0C OOC  *r=   c                (    | j                  d|       y )Nr)   )rA  )r:   r?  s     r<   pytest_deselectedz"TerminalReporter.pytest_deselected=  s    e,r=   c                    |\  }}}| j                   r7| j                  ||||      }| j                  |d       | j                          y | j                  r#| j                  |d       | j                          y y )Nr   )r   _locationliner  r  r   r  )r:   r   locationr  rH  domainru   s          r<   pytest_runtest_logstartz(TerminalReporter.pytest_runtest_logstart@  so     "*   %%ffffED$$T2.JJL__$$VR0JJL r=   c                .   d| _         |}t        | j                  j                  j	                  || j                         }|j
                  |j                  |j                  }}}t        |t              sd }n|\  }}| j                  ||g       |s|sy |Vt        |d      }|j                  r|sddi}n7|j                  r|rddi}n$|j                  rddi}n|j                  rddi}ni }| j                  j!                  |j"                         | j                  j%                  t&        j(                        dk  rI | j*                  j,                  |fi | | j.                  r| j0                  s| j3                          n | j4                  |j"                  g|j6                   }	t        |d      }
|
s | j8                  |	|fi | |j                  st        |d      rt;        |      }| j                  j%                  t&        j(                        d	k  rJ| j*                  j<                  | j*                  j>                  z
  tA        d
      z
  dz
  }tC        d||      }nd| d}|r|| jE                  |       | j.                  r| jG                          n| jI                          | j*                  j-                  d|jJ                  jL                  jN                   d       | j.                  r/| j*                  j-                  | jQ                         dz   d       n| j*                  j-                  d        | j*                  j,                  |fi | | j*                  j-                  d|	z          d| _)        | jU                          y )NT)r   r   wasxfailgreenyellowredr   node    [100%]r?   z ({})z ()[]r   )cyanr  )+
_tests_ranrV   r   hookr   rW   rX   rY   r*  tuplerA  hasattrr'   r&   r(   r   addr   r   r   r   r   r
  r   _is_last_item(_write_progress_information_if_past_edgerR  rS  r  _get_raw_skip_reasonr   r   r/  _format_trimmedr%  r	  r  r[  gatewayid!_get_progress_information_messager   r  )r:   r   repr  rW   rX   rY   r  	was_xfailru   running_xdistreasonavailable_widthformatted_reasons                 r<   pytest_runtest_logreportz)TerminalReporter.pytest_runtest_logreportN  s    [[66c$++6V
 "%szz388$&$&FLD&3%(d>
3Izz)!4	"D)"D)''++CJJ7;;$$V%@%@AQFDHHNN6,V, ''0B0B==?%4%%cjj@3<<@D#C0M (((t>v>;;'&*"=1#6F{{001L1LMPQQ!XX//$((2P2PP!)n-  (
 ,;#V_,( .0xq>("2">(89++BBD##%388#3#3#6#6"7q9:++HHNN>>@3FT #  HHNN3't.v.sTz*%'"

r=   c                v    | j                   J t        | j                        | j                   j                  k(  S rO   )r   r/  r   testscollectedr   s    r<   rg  zTerminalReporter._is_last_item  s2    }}(((4223t}}7S7SSSr=   T)wrapperc              #     K   d }| j                   j                  t        j                        dk  r(| j                  r| j
                  r| j                          |S wr   )r   r   r   r   r   r   r	  )r:   results     r<   pytest_runtestloopz#TerminalReporter.pytest_runtestloop  sM      KK%%f&A&ABaG((//::<s   AAc                N   | j                   sJ | j                   j                  }| j                  dk(  rP|rEt        | j                        }dt        t        |             d}d| d}|j                  ||      S d| d| dS |r dt        | j                        d	z  |z  d
dS y)Nr`   z{:zd} [z/{}]z [ z / z ]d   3dz%]r]  )r   rv  r   r/  r   rI   format)r:   	collectedr   counter_formatformat_strings        r<   rm  z2TerminalReporter._get_progress_information_message  s    }}}MM00	##w.t>>?#&s3y>':&;3!?"$^$4F ;$++Hi@@3yk44T<<=CyPQSTTVW r=   c                x   | j                   }| j                  dk(  r7| j                  sJ | j                  j                  }t	        d| d| d      }nt	        d      }||z   dz   | j
                  k\  }|rF| j                         \  }}| j                         } | j                  j                  |dz   fi |di y y )	Nr`   r|  /r`  r]  r?   r  T)
_width_of_current_liner   r   rv  r/  r   _get_main_colorrm  r   r
  )r:   r   	num_testsprogress_length	past_edge
main_color_r   s           r<   rh  z9TerminalReporter._write_progress_information_if_past_edge  s    ''##w.== =44I!Byk9+Q"?@O!)nO'!+t/A/AA	 002MJ88:CDHHNN3:<*d);< r=   c                    | j                         \  }}| j                         }| j                  }| j                  j                  |z
  dz
  } | j
                  |j                  |      fddi|di y )Nr?   r  T)r  rm  r  r   r   r
  rjust)r:   r~   r  r   r   r1  s         r<   r	  z:TerminalReporter._write_progress_information_filling_space  sj    '')q446''xx!!A%)

399T?@$@5$-@r=   c                .    | j                   j                  S )z%Return the width of the current line.)r   r   r   s    r<   r  z'TerminalReporter._width_of_current_line  s     xx---r=   c                0   | j                   rR| j                  j                  j                  dk\  r.| j	                  ddd       t        j                         | _        y y | j                  j                  j                  dk\  r| j	                  ddd       y y )Nr   zcollecting ... T)r  boldr?   )r   r   r   ra   r
  r   timer   r   s    r<   pytest_collectionz"TerminalReporter.pytest_collection  sy    ;;{{!!))Q.

,Dt
D28++-/ / [[''1,JJ(4J@ -r=   c                V   |j                   r| j                  d|g       n|j                  r| j                  d|g       |j                  D cg c]  }t	        |t
              s| }}| xj                  t        |      z  c_        | j                  r| j                          y y c c}w )Nr-   r(   )
r&   rA  r(   ry  r*  r   r   r/  r   report_collect)r:   r   r  r?  s       r<   pytest_collectreportz%TerminalReporter.pytest_collectreport  s    ==OOGfX.^^OOIx0"MMAMqZ4-@MAc%j(;;!  Bs   B&$B&c                :   | j                   j                  j                  dk  ry |s>t        j                         }| j
                  | j
                  |t        z
  kD  ry || _        t        | j                  j                  dg             }t        | j                  j                  dg             }t        | j                  j                  dg             }| j                  |z
  }|rdnd}|t        | j                        dz   | j                  dk(  rd	nd
z   z  }|r|d||dk7  rd
nd	fz  z  }|r|d|z  z  }|r|d|z  z  }| j                  |kD  r|d|z  z  }| j                  r)| j                  |dd       |r| j                  d       y y | j                  |       y )Nr   r-   r(   r)   z
collected zcollecting z itemr?   r   r   z / %d error%sz / %d deselectedz / %d skippedz / %d selectedT)r  r,  r  )r   r   ra   r   r  r   REPORT_COLLECTING_RESOLUTIONr/  r   r  r   rI   r   r2  r
  r   )r:   r
   tr)  r(   r)   selectedru   s           r<   r  zTerminalReporter.report_collect  s   ;;%%)A//;33a:V6VV./D+TZZ^^GR01djjnnY34b9:
%%
2$|-""#g-t7I7IQ7NTWX	
 Ovfksr&JJJD&33DOg--D($x//D;;LLDL5

4   OOD!r=   r   c                x   || _         t        j                         | _        | j                  sy | j                  ddd       t        j                         }| j                  sXdt        j                   d| }t        t        dd       }|r1dj                  t        t        |d d	             }|d
| d|d	    dz  }|dt        j                  j                    dt"        j$                   z  }| j&                  dkD  sA| j(                  j*                  j,                  s!t        | j(                  j*                  dd       r|dt        t        j.                        z   z  }| j1                  |       | j(                  j2                  j5                  | j(                  | j6                        }| j9                  |       y y )N=ztest session startsTr  z	platform z -- Python pypy_version_infor      z[pypy--r`  z	, pytest-z	, pluggy-r   pastebinz -- )r   
start_path)r   r   r  _sessionstarttimer   r6  platformpython_versionrd   r   rA   r   r   rI   r   _versionversionpluggy__version__r   r   r   r   
executabler   rc  pytest_report_headerr   _write_report_lines_from_hooks)r:   sessionverinfor   r  liness         r<   pytest_sessionstartz$TerminalReporter.pytest_sessionstart  st   !'s1=))+~~cll^;wi@C '-@$ G ((3s,=bq,A#BCy*;A*>)?qAAYw//778	&BTBTAUVVC";;%%++4;;--z4@vCNN 333OOC KK$$99{{t~~ : E //6# r=   c                    t        |      D ]<  }t        |t              r| j                  |       %|D ]  }| j                  |        > y rO   )reversedr*  rI   r   )r:   r  line_or_linesru   s       r<   r  z/TerminalReporter._write_report_lines_from_hooks*  s>     &e_M--.)DOOD) *	 -r=   c           	        d|j                    g}|j                  r2|j                  dt        |j                   |j                        z          |j                  t
        j                  j                  k(  r@|j                  d      }|j                  dj                  dj                  |                   |j                  j                         }|r8|j                  dj                  dj                  t        |                         |S )Nz	rootdir: zconfigfile: 	testpathsztestpaths: {}, zplugins: {})r  inipathappendr!   args_sourcer   
ArgsSource	TESTPATHSr   r  r   r   list_plugin_distinfo_plugin_nameversions)r:   r   ry  r  
plugininfos        r<   r  z%TerminalReporter.pytest_report_header4  s    foo./0>>MM.;v+WWX!2!2!<!<<#)==#=IMM/0091EFG))>>@
MM$$TYY/CJ/O%PQ r=   c                   | j                  d       | j                  j                  j                  | j                  | j                  |j
                        }| j                  |       | j                  j                  d      r|j
                  rY| j                  j                  j                  dkD  r| j                  j                  d       | j                  |j
                         | j                  j                  d      }|r?| j                  j                  dd       |D ]  }|j!                  | j                          y y y )	NT)r   r  r?  collectonlyr   r&   !zcollection failures)r  r   rc  pytest_report_collectionfinishr   r?  r  r   r   ra   r   ru   _printcollecteditemsr   r  r4  
toterminal)r:   r  r  r&   rn  s        r<   pytest_collection_finishz)TerminalReporter.pytest_collection_finishE  s    D!  ??;;~~-- @ 

 	++E2;;  /}};;%%--2HHMM"%))'--8ZZ^^H-FS"78!CNN488, "  0r=   c           	        | j                   j                  t        j                        }|dk  r|dk  rTt	        d |D              }t        |j                               D ]%  \  }}| j                  j                  d||fz         ' y |D ]'  }| j                  j                  |j                         ) y g }d}|D ]  }|j                         dd  }	|r%||	d t        |       k(  rn|j                          |r%|	t        |      d  D ]  }
|j                  |
       t        |      dz
  dz  }| j                  j                  | |
        |dk\  sJt        |
dd       }|rt        j                   |      nd }|ss|j#                         D ]0  }| j                  j                  d	j%                  |dz   |             2   y )
Nr   r  c              3  Z   K   | ]#  }|j                   j                  d d      d    % ywr  r?   r   N)r   r  ).0items     r<   	<genexpr>z8TerminalReporter._printcollecteditems.<locals>.<genexpr>_  s'      Q54!2!24!;A!>5s   )+z%s: %dr   r?     objz{}{})r   r   r   r   r   sortedr?  r   ru   r   	listchainr/  r.  r  rA   inspectgetdoc
splitlinesr  )r:   r?  test_cases_verbositycountsnamer`   r  stackindentneeded_collectorscolr  docru   s                 r<   r  z%TerminalReporter._printcollecteditems[  s   #{{889T9TU!##b(  Q5 QQ#)&,,.#9KD%HHMM(dE]":; $:
  "DHHMM$++. "D $ 0 4-lE
;;		  )U6S!e*q.D0./'1,!#ud3C14'..-$C$'NN$4D HHMM&--t*LM %5 7 r=   c              #    K   d }| j                   j                  d       t        j                  t        j                  t        j
                  t        j                  t        j                  f}||v r>| j                  s2| j                  j                  j                  | || j                         |j                  r'| j                  dt        |j                        d       |t        j
                  k(  r| j                          d | _        n3|j"                  r'| j                  dt        |j"                        d       | j%                          |S w)Nr   )r   
exitstatusr   r  T)rZ  )r   ru   r   OKTESTS_FAILEDINTERRUPTEDUSAGE_ERRORNO_TESTS_COLLECTEDre   r   rc  pytest_terminal_summary
shouldfailr6  rI   _report_keyboardinterruptr   
shouldstopsummary_stats)r:   r  r  ry  summary_exit_codess        r<   pytest_sessionfinishz%TerminalReporter.pytest_sessionfinishy  s
     bKK!!    ''
 ++DOOKK44!%*T[[ 5  NN3G$6$6 7TNB---**,+/D(NN3G$6$6 7TNBs   EEc              #  ^  K   | j                          | j                          | j                          | j                          | j	                          | j                          	 d | j                          | j                          S # | j                          | j                          w xY wwrO   )summary_errorssummary_failuressummary_xfailuressummary_warningssummary_passessummary_xpassesshort_test_summaryr   s    r<   r  z(TerminalReporter.pytest_terminal_summary  s      	$##%!!# ##%!!#s   A!B-$B '!B-"B**B-c                2    |j                  d      | _        y )NT)funcargs)getreprr   )r:   excinfos     r<   pytest_keyboard_interruptz*TerminalReporter.pytest_keyboard_interrupt  s    '.'E$r=   c                >    | j                   | j                          y y rO   )r   r  r   s    r<   pytest_unconfigurez#TerminalReporter.pytest_unconfigure  s    ''3**, 4r=   c                   | j                   }|J |j                  J |j                  j                  }| j                  d|       d|v r| j                  j
                  j                  r|j                  | j                         y |j                  j                  | j                         | j                  j                  dd       y y )Nr  KeyboardInterruptz@(to show a full traceback on KeyboardInterrupt use --full-trace)T)rY  )
r   	reprcrashr   r6  r   r   	fulltracer  r   ru   )r:   rC  r   s      r<   r  z*TerminalReporter._report_keyboardinterrupt  s    .."""  ,,,''sC #%{{!!++""488,!!,,TXX6V   &r=   c                    d	 fd}|rv ||      } j                   dk\  rZ|j                  d      d   |j                  dt        j                        k7  r%|dt         j                  t        |            z   z  }|dz   S d}|dz   S )
Nc                    j                   j                  |       }r]|j                        rL|d t                }j	                  d      }|d   j                  dd      |d<   |dj                  |      z  }|S )Nr_  r   r   r  )r   cwd_relative_nodeidendswithr/  r  r   r   )r   ru   rE   rT  r:   s      r<   mkrelz-TerminalReporter._locationline.<locals>.mkrel  sw    ;;226:D$--/Ns6{l+c*"1I--c48q	((Kr=   r\  r  r   \z <- z
[location]r   )r   rI   rM   rI   )r   r  r   r   SEPr!   r   r   )r:   r   r  rH  rT  r   r  s   `   `  r<   rR  zTerminalReporter._locationline  s    	 -C~~"v||D'9!'<eiiA ( vDNNDL III Sy CSyr=   c                $    |j                   }|r|S y)Nztest session)	head_line)r:   rn  r  s      r<   _getfailureheadlinez$TerminalReporter._getfailureheadline  s    MM	r=   c                    	 t        |j                  j                        S # t        $ r, 	 t        |j                        d d cY S # t        $ r Y Y yw xY ww xY w)N2   r   )rI   longreprr  AttributeError)r:   rn  s     r<   _getcrashlinezTerminalReporter._getcrashline  sX    	s||--.. 	3<<("--! 	s,   ! 	AAA	AAAAc                z    | j                   j                  |d      D cg c]  }t        |d      r| c}S c c}w )Nr[   	_pdbshown)r   r  re  )r:   r  r  s      r<   
getreportszTerminalReporter.getreports  s4    ::>>$3S3a71k;R3SSSs   88c                (     j                  d      r j                  j                  d      }|sy  j                  d u}|r| j                  d  }n|}t	        |       _        |sy i }|D ]-  }|j                  |j                  g       j                  |       / d fd}|rdnd} j                  d|dd	       |j                         D ]  \  }}	 ||	      }
|
rT j                  j                  |
       |j                         }d
j                  d |D              }|j                         }n|j                         } j                  j                  |        j                  j                            j                  j                  d       y y )Nr   r,   c                >   g }| D ]1  }|j                  j                        }|s!|j                  |       3 t        |      dk  rdj	                  t        t        |            S t        d |D              }dj	                  d |j                         D              S )N
   r  c              3  X   K   | ]"  }t        |      j                  d d      d    $ ywr  )rI   r  )r  locs     r<   r  zWTerminalReporter.summary_warnings.<locals>.collapsed_location_report.<locals>.<genexpr>  s(      -:C3CHNN4+A.)s   (*c              3  V   K   | ]!  \  }}d j                  |||dkD  rdnd       # yw)z{}: {} warning{}r?   r   r   N)r  )r  kvs      r<   r  zWTerminalReporter.summary_warnings.<locals>.collapsed_location_report.<locals>.<genexpr>  s3      ! :1 '--a1q5CbI :s   '))	r   r   r  r/  r   r   rI   r   r?  )reports	locationsr   rS  counts_by_filenamer:   s        r<   collapsed_location_reportzDTerminalReporter.summary_warnings.<locals>.collapsed_location_report  s    	 A ~~dkk:H!((2 !
 y>B&99Si%899%, -:C- &" yy ! 2 8 8 :!  r=   zwarnings summary (final)zwarnings summaryr  TF)rY  r  r  c              3  &   K   | ]	  }d |z     yw)r  Nr[   )r  r  s     r<   r  z4TerminalReporter.summary_warnings.<locals>.<genexpr>  s     (A5a5s   zG-- Docs: https://docs.pytest.org/en/stable/how-to/capture-warnings.html)r  zlist[WarningReport]rM   rI   )r  r   r  r   r/  r<  r   r  r6  r?  r   ru   r  r   rstrip)r:   all_warningsr
   warning_reportsreports_grouped_by_messagewrr  r5  r   message_reportsmaybe_locationr  indenteds   `            r<   r  z!TerminalReporter.summary_warnings  sb   ;;s7;zz~~j7QL44D@E".t/O/O/Q"R"./2?/CD,"IK&%*55bjj"ELLRP &$ 38.=OENN3dN?,F,L,L,N(!:?!K!HHMM.1#..0E#yy(A5(AAH&oo/G%nn.Gg& -O HHMMYc r=   c                *    | j                  ddd       y )Nr'   PASSESPsummary_passes_combinedr   s    r<   r  zTerminalReporter.summary_passes  s    $$Xx=r=   c                *    | j                  ddd       y )Nr+   XPASSESXr&  r   s    r<   r  z TerminalReporter.summary_xpasses  s    $$Y	3?r=   c                   | j                   j                  j                  dk7  r| j                  |      r| j	                  |      }|sy | j                  d|       |D ]`  }|j                  r7| j                  |      }| j                  d|dd       | j                  |       | j                  |j                         b y y y )Nrt   r  r  T)rX  r  )r   r   rp   r  r  r6  sectionsr  _outrep_summary_handle_teardown_sectionsr   )r:   which_reports	sep_title
needed_optr  rn  r   s          r<   r'  z(TerminalReporter.summary_passes_combined"  s     ;;%%-{{:&,0OOM,JsI."C||"66s;sCt$G,,S1223::> # ' .r=   c                    | j                  d      }|D cg c]"  }|j                  dk(  r|j                  |k(  r|$ c}S c c}w )Nr   r   )r  r   r   )r:   r   r  r   s       r<   _get_teardown_reportsz&TerminalReporter._get_teardown_reports2  sN    //"% "
!{{j(V]]f-D !
 	
 
s   'A c                R    | j                  |      D ]  }| j                  |        y rO   )r3  print_teardown_sections)r:   r   r   s      r<   r.  z*TerminalReporter._handle_teardown_sections:  s%    008F((0 9r=   c                   | j                   j                  j                  }|dk(  ry |j                  D ]X  \  }}|dk7  r||vrd|v s| j                  j                  d|       |dd  dk(  r|d d }| j                  j                  |       Z y )Nrt   r}   r   r  r  r  )r   r   ry   r,  r   r4  ru   r:   rn  ry   secnamer#  s        r<   r5  z(TerminalReporter.print_teardown_sections>  s    kk((44$ #GWe#7(BW$S'*23<4'%crlGg& !-r=   c                l    | j                   j                  j                  }| j                  dd|       y )Nr&   FAILURESro   )r   r   rp   summary_failures_combined)r:   ro   s     r<   r  z!TerminalReporter.summary_failuresK  s,    ""**&&x5&Ir=   c                    | j                   j                  j                  }|r | j                   j                  j                  nd}| j	                  dd|       y )Nrt   r*   	XFAILURESr;  )r   r   rx   rp   r<  )r:   show_tbro   s      r<   r  z"TerminalReporter.summary_xfailuresO  sE    ++$$--.5""**4&&y+U&Kr=   )r1  c                  |dk7  r|r| j                  |      r| j                  |      }|sy | j                  d|       |dk(  r*|D ]$  }| j                  |      }| j	                  |       & y |D ]T  }| j                  |      }| j                  d|dd       | j                  |       | j                  |j                         V y y y )Nrt   r  ru   r  TrZ  r  )	r  r  r6  r
  r   r  r-  r.  r   )	r:   r/  r0  ro   r1  r  rn  ru   r   s	            r<   r<  z*TerminalReporter.summary_failures_combinedT  s     D=Z!8,0OOM,JsI.F?&#11#6-  '  '"66s;sCTE,,S166szzB	  ' "9 r=   c                |   | j                   j                  j                  dk7  r| j                  d      }|sy | j	                  dd       | j
                  d   D ]`  }| j                  |      }|j                  dk(  rd|z   }nd|j                   d| }| j	                  d	|d
d
       | j                  |       b y y )Nrt   r-   r  ERRORSr   zERROR collecting z	ERROR at z of r  TrA  )	r   r   rp   r  r6  r   r  r   r-  )r:   r  rn  r   s       r<   r  zTerminalReporter.summary_errorsm  s    ;;%%-(,(@GNN3)zz'*..s388y(-3C%chhZtC59CsCT=$$S) + .r=   c                J   |j                  | j                         | j                  j                  j                  }|dk(  ry |j
                  D ]S  \  }}|dk7  r||vr| j                  j                  d|       |dd  dk(  r|d d }| j                  j                  |       U y )Nrt   r}   r  r  r  )r  r   r   r   ry   r,  r4  ru   r7  s        r<   r-  z TerminalReporter._outrep_summary|  s    txx kk((44$ #GWe#7(BHHLLg&rs|t#!#2,HHMM'" !-r=   c                .   | j                   dk  ry t        j                         | j                  z
  }| j	                         \  }}g }| j                   dk\  }|r| j
                  j                  }|D ]O  \  }} | j
                  j                  |fi |}	|rt        |	      t        |      z
  z  }|j                  |	       Q dj                  |      }
|di}dt        |       } | j
                  j                  |fi |}|rt        |      t        |      z
  z  }|
|z  }
|rE | j
                  j                  d
i |}|j                  d      r|d d }t        |      z  }|
|z  }
|r | j                  d|
fd	i| y  | j                  |
fi | y )Nr  r   r  Tz in z[0mr  r   r   )r   r   r  r  build_summary_stats_liner   r   r  r/  r  r   format_session_durationr  r6  r   )r:   session_durationpartsr  
line_partsdisplay_sepr   textr  with_markupr   main_markupdurationduration_with_markupmarkup_for_end_seps                  r<   r  zTerminalReporter.summary_stats  s   >>B!;;=4+A+AA";;=

nn)**I!LD&)$((//$9&9KS-D	99	k*	 "
 ii
#!4(12BCDE.txxxG;G12S]BBI##!0!C{!C!**95%7%<"/00I%%CDNN3HyHKHDOOC/;/r=   c           	        
  j                   sy d fd}d fd}d fd}d fd
d fdd 
fd}||t        |d      |t        |d	      t        |d
      d}g } j                   D ]  }|j                  |      }|s ||         |r. j                  dddd       |D ]  }	 j	                  |	        y y )Nc                   j                   j                  |g       }|sy j                  }|D ]G  }t        j                  |t              }t        ||j                  |di      }| j                  |       I y )NT)r   r  r   _color_for_type_color_for_type_default _get_line_with_reprcrash_messager   r  )r  statr&   r   rn  r~   ru   r:   s          r<   show_simplez8TerminalReporter.short_test_summary.<locals>.show_simple  sl    ZZ^^D"-F[[F'++D2IJ7CE4= T" r=   c                   	j                   j                  dg       }|D ]  }|j                  	j                  t        d   di      \  }} 	j
                  j                  |fi |}t        	j
                  	j                  |      }| d| }|j                  }|r|dt        |      z   z  }| j                  |        y )Nr*   r,   Tr    - r   r  _get_verbose_word_with_markupr   rV  r   r  _get_node_id_with_markuprW  rI   r  )
r  r*   rn  verbose_wordverbose_markupmarkup_wordr   ru   rq  r:   s
            r<   show_xfailedz9TerminalReporter.short_test_summary.<locals>.show_xfailed  s    jjnnY3G/2/P/PKK/*"=t!D0,n .dhhoolMnM1$((DKKM%ax0ECK//DT" r=   c                   	j                   j                  dg       }|D ]  }|j                  	j                  t        d   di      \  }} 	j
                  j                  |fi |}t        	j
                  	j                  |      }| d| }|j                  }|r|dt        |      z   z  }| j                  |        y )Nr+   r,   Tr   r\  r]  )
r  r+   rn  r`  ra  rb  r   ru   rq  r:   s
            r<   show_xpassedz9TerminalReporter.short_test_summary.<locals>.show_xpassed  s    jjnnY3G/2/P/PKK/*"=t!D0,n .dhhoolMnM1$((DKKM%ax0ECK//DT" r=   c           	        j                   j                  dg       }|rt        j                  |      ng }|sy |d   j	                  j
                  t        d   di      \  }} j                  j                  |fi |}d}|D ]Z  \  }}}	}
|
j                  |      r|
t        |      d  }
|	| j                  d||||	|
fz         C| j                  d||||
fz         \ y )Nr(   r   r,   T	Skipped: z%s [%d] %s:%d: %sz%s [%d] %s: %s)r   r  _folded_skipsr   r^  r   rV  r   r  
startswithr/  r  )r  r(   fskipsr`  ra  rb  r  numr  rH  rq  r:   s              r<   show_skipped_foldedz@TerminalReporter.short_test_summary.<locals>.show_skipped_folded  s    +/::>>)R+HG?F]4>>7;BF+21:+S+Soj94@,(L. *$((//,I.IK F/5+VVV$$V,#CKM2F%LL+{CQW.XX LL!1[#vv4V!VW 06r=   c                \   	j                   j                  dg       }|D ]	  }|j                  J t        |j                  t              sJ ||j                  f       t        |j                        dk(  sJ ||j                  f       |j                  	j                  t        d   di      \  }} 	j                  j                  |fi |}t        	j                  	j                  |      }| d| }|j                  d   }|r|dt        |      z   z  }| j                  |        y )Nr(   r  r,   Tr   r\  r\  )r   r  r  r*  rd  r/  r^  r   rV  r   r  r_  rI   r  )
r  r(   rn  r`  ra  rb  r   ru   rq  r:   s
            r<   show_skipped_unfoldedzBTerminalReporter.short_test_summary.<locals>.show_skipped_unfolded  s   +/::>>)R+HG||///!#,,6Kcll8KK63<<(A-BS\\/BB-/2/P/PKK/*"=t!D0,n .dhhoolMnM1$((DKKM%ax0aECK//DT" r=   c                @    j                   r	 |        y  |        y rO   )r   )r  r:   rl  rn  s    r<   show_skippedz9TerminalReporter.short_test_summary.<locals>.show_skipped  s    #E*%e,r=   r&   )rY  r'   r-   )r  r*  fr   pr   r  zshort test summary infoT)ra  r  )r  	list[str]rY  rI   rM   rN   )r  rs  rM   rN   )rj   r   r  r6  r   )r:   rZ  rc  re  rp  REPORTCHAR_ACTIONSr  r   rb   ru   rl  rn  s   `         @@r<   r  z#TerminalReporter.short_test_summary  s    
	#	#	#	X(	#&	- 848473I
 $$D'++D1Fu %
 NN3 94NP%  r=   c                    | j                   | j                  | j                  r,| j                          | j                   sJ | j                  sJ | j                   | j                  fS rO   )r   r   rg  r>  r   s    r<   r  z TerminalReporter._get_main_color  sb    #t'8'8'@DDVDV  "####$$$$!2!222r=   c                ~    | j                   }d|v sd|v rd}|S d|v sd|v s|rd}|S d|v s| j                  sd}|S d}|S )	Nr&   r-   rZ  r,   r+   rY  r'   rX  )r   rg  )r:   unknown_type_seenr   r  s       r<   _determine_main_colorz&TerminalReporter._determine_main_color#  st    

u5 0J  5 I$6:K!J
 	 d&8&8 J  "Jr=   c                    g }| j                   D ]$  }|s|t        vs||vs|j                  |       & t        t              |z   | _        | j                  t        |            | _        y rO   )r   KNOWN_TYPESr  listr   rx  rK   r   )r:   unknown_types
found_types      r<   r>  z TerminalReporter._set_main_color/  sa    #%**J[0Z}5T!((4 % !-=55d=6IJr=   c                x    | j                   j                  d      r| j                         S | j                         S )a  
        Build the parts used in the last summary stats line.

        The summary stats line is the line shown at the end, "=== 12 passed, 2 errors in Xs===".

        This function builds a list of the "parts" that make up for the text in that line, in
        the example above it would be:

            [
                ("12 passed", {"green": True}),
                ("2 errors", {"red": True}
            ]

        That last dict for each line is a "markup dictionary", used by TerminalWriter to
        color output.

        The final color of the line is also determined by this function, and is the second
        element of the returned tuple.
        r  )r   r   &_build_collect_only_summary_stats_line _build_normal_summary_stats_liner   s    r<   rH  z)TerminalReporter.build_summary_stats_line8  s4    ( ;;  />>@@88::r=   c                    | j                   j                  |g       }|D cg c]  }t        |dd      s| c}S c c}w )zRGet test/collection reports for the given status key, such as `passed` or `error`.r   T)r   r  rA   )r:   keyr  r  s       r<   _get_reports_to_displayz(TerminalReporter._get_reports_to_displayQ  s:    **..b)"P7aga1H$&O7PPPs   ;;c                    | j                         \  }}g }|D ]d  }| j                  |      }|st        |      }t        j	                  |t
              }|dd||k(  i}|j                  dt        ||      z  |f       f |sdt
        difg}||fS )NTr  %d %szno tests ran)r  r  r/  rV  r  rW  r  	pluralize)	r:   r  known_typesrK  r  r  r`   r~   r  s	            r<   r  z1TerminalReporter._build_normal_summary_stats_lineV  s     #'"6"6"8
KC2237GG'++C1HIvu
/BCg	%(==vFG  $'>&EFGEj  r=   c                   t        | j                  d            }t        | j                  d            }| j                  dk(  r
dddifg}d}no|dk(  r#d}dt        | j                  d	      z  }||difg}nG| j                  |k(  }|r	d}d
| d}n&d}| j                  |z
  }| d| j                   d| d}||difg}|r t        d   }|dt        |d      z  |difgz  }||fS )Nr)   r-   r   zno tests collectedrY  TrX  z%d %s collectedtestzno tests collected (z deselected)r  z tests collected (r  )r/  r  r   r  rV  )r:   r)   r)  rK  r  collected_outputall_tests_were_deselectedr  s           r<   r  z7TerminalReporter._build_collect_only_summary_stats_linei  s8    55lCD
T11':;"*Xt,<=>E!J1_ J09T=O=OQW3XX&T(:;<E(,(:(:j(H%(%
%9*\#R $
--
:&.Zq1C1C0DDVWaVbbn#o &T(:;<E(1Jw67!;;j$=OPQQEj  r=   rO   )r   r   r   zTextIO | NonerM   rN   )rM   z#Literal['progress', 'count', False])rM   r   )rM   rK   )r   zbool | NonerM   rN   )r   rI   rM   rK   )r   rI   r  rI   r  rK   rM   rN   rG  )r  rI   r  rI   rM   rN   )rM   rN   )r#  rI   r  rK   r  r   r  rI   r  rK   rM   rN   )r#  rI   r  rK   r  rK   rM   rN   )ru   zstr | bytesr  rK   rM   rN   )ru   rI   r  rK   rM   rN   )NN)
r4  rI   r5  rL   r   
int | Noner  rK   rM   rN   )r  )r5  rI   r4  rI   r8  rK   rM   rN   )r   rI   r8  rK   rM   rN   )rW   rI   r?  zSequence[Any]rM   rN   )rC  r   rM   rK   )rI  zwarnings.WarningMessager   rI   rM   rN   )rM  r   rM   rN   )r?  zSequence[Item]rM   rN   )r   rI   rS  ztuple[str, int | None, str]rM   rN   )r   r$   rM   rN   )rM   zGenerator[None, object, object])rM   rI   )r   r#   rM   rN   )F)r
   rK   rM   rN   )r  r%   rM   rN   )r  zSequence[str | Sequence[str]]rM   rN   )r   r   rM   rs  )r  r%   r  zint | ExitCoderM   Generator[None])rM   r  )r  zExceptionInfo[BaseException]rM   rN   )
r   rI   r  rI   rH  r  rT  rI   rM   rI   )r  rI   )r/  rI   r0  rI   r1  rI   rM   rN   )r   rI   rM   zlist[TestReport])r   rI   rM   rN   )rn  r$   rM   rN   )
r/  rI   r0  rI   ro   rI   r1  rL   rM   rN   )rn  r"   rM   rN   )rM   ztuple[str, list[str]])rw  rK   rM   rI   )rM   z-tuple[list[tuple[str, dict[str, bool]]], str])r  rI   rM   z	list[Any])MrP   rQ   rR   r9   r   propertyr   r   rd   re   r   setterr   r  r  r  r  r%  r
  r  r   r2  r6  r9  ru   rA  rD  rK  rN  rP  rU  rt  rg  r   rz  rm  rh  r	  r  r  r  r  r  r  r  r  r  r  r  r  r  r  rR  r  r
  r  r  r  r  r'  r3  r.  r5  r  r  r<  r  r-  r  r  r  rx  r>  rH  r  r  r  r[   r=   r<   r   r   i  s   B6*   # # 2 2 3 3    
 ! ! J J(	2$& 77 	7
 7 7 7 
7, 49 7&5* ! $	66 6 	6
 6 
6'!#
606 6 
	6!-%@	JX T T d "=A . .A"#"J d7 74*2*	*"-,N< d,:	 4 d$ $F- #&0:DG	.T4l>@? ?-0?>A?	? 
1'JL "&CC C
 C C 
C2*##0Jl&\3
K;2Q
!	6!&!	6!r=   r   c                    |j                  |j                        }|j                  d      ^}}|r*| j                  dj	                  |      d      }|dz   |z   S |S )Nr  Tr  )r  r   r  r  r   )twr   rn  r   pathrK  parts_markups          r<   r_  r_    sZ    ''

3F<<%LD5yy5!1y=d{\))r=   c                X   |j                  d      }|dk7  r|d| }d}t        | j                  d            }|t        |      z   |kD  ry|t        |      z   |kD  r@|t        |      z  }|d| }|t        |      z   |kD  r|dd }|t        |      z   |kD  r||z  }| j                  |      S )zFormat msg into format, ellipsizing it if doesn't fit in available_width.

    Returns None if even the ellipsis can't fit.
    r  r  Nz...r   )findr   r  r/  )r  r   rr  iellipsisformat_widths         r<   rj  rj    s     	ABw"1gHFMM"-.Lc(m#o5hsm#o53x=("?#Xc]*_<cr(C Xc]*_<x==r=   c                   |j                  | |      \  }} |j                  |fi |}t        || |      }| d| }t        |      }		 |j                  j
                  j                  }
t               s| j                  j                  dk\  rd|
 }
n|j                  |	z
  }t        d|
|      }
|
||
z  }|S # t        $ r Y |S w xY w)z?Get summary line for a report, trying to add reprcrash message.r   r\  r\  z - {})r^  r  r_  r   r  r  r   r   r   ra   r   rj  r	  )r   rn  r  word_markupr`  ra  rY   r[  ru   
line_widthr   rr  s               r<   rX  rX    s     $'#D#D$ L. 299\4^4D#B4DV1TFD$Jll$$,, ?fmm33q8u+C llZ7O!'3@C?CKDK   Ks   	 B7 7	CCc                >   i }|D ]  }|j                   J t        |j                   t              sJ ||j                   f       t        |j                         dk(  sJ ||j                   f       |j                   \  }}}t	        | t        |            }t        |di       }|j                  dk(  rd|v r
d|vr|d |f}n|||f}|j                  |g       j                  |        g }	|j                         D ]#  \  }}
|	j                  t        |
      g|       % |	S )Nr  keywordsr   skip
pytestmark)r  r*  rd  r/  r!   r   rA   r   r<  r  r?  )r   r(   deventr  rH  rq  r  r  rE   eventss              r<   rh  rh    s!    ACA~~)))%..%0I5%..2II05>>"a'@%)@@'!&YV55*b1
 JJ'!("H,06f/EC66*C	S"$$U+' ( 68FwwyVs6{)S)* !Mr=   rZ  rY  rX  )r&   r-   r,   r'   c                T    |dvr| |fS |j                  dd      }| | dk7  r|dz   fS |fS )N)r-   r,   r  r,   warningr?   r   )r   )r`   nouns     r<   r  r    sD    00d{
 <<
I.D
$*4444r=   c                    g }| D ]L  \  }}|j                    d|j                   }|j                  d      r|dd  }||vs<|j                  |       N |S )Nr  zpytest-   )project_namer  ri  r  )r  rE   rM  distr  s        r<   r  r     sb    F"##$Adll^4??9%8DvMM$ # Mr=   c                h    | dk  r| ddS t        j                  t        |             }| dd| dS )zQFormat the given seconds in a human readable manner to show in the final summary.<   z.2fr   )secondszs (r^  )datetime	timedeltar   )r  dts     r<   rI  rI    sA    |#a  G5#c"Q''r=   c                <   t        | d      r-| j                  }|j                  d      r|t        d      d }|S | j                  sJ t        | j                  t              sJ | j                  \  }}}|j                  d      r|t        d      d }|S |dk(  rd}|S )zqGet the reason string of a skip/xfail/xpass test report.

    The string is just the part given by the user.
    rW  zreason: Nrg  Skippedr   )re  rW  ri  r/  r(   r*  r  rd  )r   rq  r  s      r<   ri  ri    s    
 vz"Z(C
O-.F~~~&//51111f[)C,./F  y Fr=   )rC   r   rM   rN   )r   r   rM   rN   )r   r   rM   rI   )r   r"   rM   ztuple[str, str, str])r  r   r   r   rn  r"   )r  rI   r   rI   rr  r   rM   rL   )
r   r   rn  r"   r  r   r  zdict[str, bool]rM   rI   )r   r   r(   zSequence[CollectReport]rM   z&list[tuple[int, str, int | None, str]])r`   r   r  rI   rM   ztuple[int, str])rM   rs  )r  floatrM   rI   )r   r$   rM   rI   )VrS   
__future__r   argparsecollectionsr   dataclassesr  	functoolsr   r  pathlibr   r  r   r!  typingr   r   r	   r
   r   r   r   r   r   r   r   r,   r  r   r   r   _pytest._coder   _pytest._code.coder   _pytest._ior   _pytest._io.wcwidthr   _pytest._version_pytest.assertion.utilr   r   r   r   r   r   _pytest.config.argparsingr   _pytest.nodesr   r   _pytest.pathlibr    r!   _pytest.reportsr"   r#   r$   _pytest.mainr%   r  rz  r   Actionr0   rV   r   r   r   r   	dataclassr   r   r_  rj  rX  rh  rV  rW  r  r  rI  ri  r[   r=   r<   <module>r     s  
 #         
                  ' , & (  0 ( ! # # ,   ( ' & ) & $  # 	  "=hoo "=J/ /(Od	B2 
$, ,   8 ]! ]! ]!@!2#)7FU<$ ,@ 	 # 
5(r=   