PK APOCALYPSE V1

APOCALYPSE V1

Current Path : /opt/hc_python/lib/python3.12/site-packages/nose/plugins/__pycache__/
Upload File :
Current File : //opt/hc_python/lib/python3.12/site-packages/nose/plugins/__pycache__/manager.cpython-312.pyc

�

���g�<����dZddlZddlZddlZddlZddlmZddlm	Z	ddl
Zddlm
Z
ddlmZddlmZ	ddlZ	ddlmZgd	�Zej,e�ZGd
�de�ZGd�d
e�ZGd�de�ZGd�d�ZGd�de�ZGd�de�Z	ddl Z Gd�dee�Z!Gd�de!�Z#y#ddlZY��xYw#ddlmZY��xYw#e"$rGd�de�Z!Y�6wxYw)a
Plugin Manager
--------------

A plugin manager class is used to load plugins, manage the list of
loaded plugins, and proxy calls to those plugins.

The plugin managers provided with nose are:

:class:`PluginManager`
    This manager doesn't implement loadPlugins, so it can only work
    with a static list of plugins.

:class:`BuiltinPluginManager`
    This manager loads plugins referenced in ``nose.plugins.builtin``.

:class:`EntryPointPluginManager`
    This manager uses setuptools entrypoints to load plugins.

:class:`ExtraPluginsPluginManager`
    This manager loads extra plugins specified with the keyword
    `addplugins`.

:class:`DefaultPluginMananger`
    This is the manager class that will be used by default. If
    setuptools is installed, it is a subclass of
    :class:`EntryPointPluginManager` and :class:`BuiltinPluginManager`;
    otherwise, an alias to :class:`BuiltinPluginManager`.

:class:`RestrictedPluginManager`
    This manager is for use in test runs where some plugin calls are
    not available, such as runs started with ``python setup.py test``,
    where the test runner is the default unittest :class:`TextTestRunner`. It
    is a subclass of :class:`DefaultPluginManager`.

Writing a plugin manager
========================

If you want to load plugins via some other means, you can write a
plugin manager and pass an instance of your plugin manager class when
instantiating the :class:`nose.config.Config` instance that you pass to
:class:`TestProgram` (or :func:`main` or :func:`run`).

To implement your plugin loading scheme, implement ``loadPlugins()``,
and in that method, call ``addPlugin()`` with an instance of each plugin
you wish to make available. Make sure to call
``super(self).loadPlugins()`` as well if have subclassed a manager
other than ``PluginManager``.

�N)�chain)�warn)�Failure)�IPluginInterface)�	sort_list)�StringIO)�DefaultPluginManager�
PluginManager�EntryPointPluginManager�BuiltinPluginManager�RestrictedPluginManagerc�F�eZdZdZeZd�Zd�Zd�Zd�Z	d�Z
d�Zd�Zdd
�Z
y	)�PluginProxya#Proxy for plugin calls. Essentially a closure bound to the
    given call and plugin list.

    The plugin proxy also must be bound to a particular plugin
    interface specification, so that it knows what calls are available
    and any special handling that is required for each call.
    c��	t|j|�|_|j|�|_g|_|D]}|j||��y#t$r&t|�d|jj�d���wxYw)Nz is not a valid z method)	�getattr�	interface�method�AttributeError�__name__�makeCall�call�plugins�	addPlugin)�selfrr�ps    �C/opt/hc_python/lib/python3.12/site-packages/nose/plugins/manager.py�__init__zPluginProxy.__init__Ws���	D�!�$�.�.�$�7�D�K��M�M�$�'��	�����A��N�N�1�d�#����	D� �$(�$�.�.�*A�*A�"C�D�
D�	D�s�A�/Bc�&�|j|i|��S�N)r)r�arg�kws   r�__call__zPluginProxy.__call__bs���t�y�y�#�$��$�$�c���t||d�}|�N|dk(r+ttj|�d�dk(r|��fd�}|jj||f�yy)z`Add plugin to my list of plugins to call, if it has the attribute
        I'm bound to.
        N�loadTestsFromModuler�c����|�Sr�)�module�path�kwargs�	orig_meths   �r�<lambda>z'PluginProxy.addPlugin.<locals>.<lambda>ns
���i��6Gr#)r�len�inspect�
getargspecr�append)r�pluginr�methr,s    @rrzPluginProxy.addPluginesd����v�t�T�*�����,�,���*�*�4�0��3�4��9� �	�G���L�L������/�r#c���|dk(r�jS�j}t|dd�r�fd�St|dd�r�jS�jS)N�loadTestsFromNames�
generativeFc�:��t�j|i|���Sr)�list�generate)r r!rs  �rr-z&PluginProxy.makeCall.<locals>.<lambda>{s���d�=�4�=�=�#�+D��+D�&Er#�	chainable)�_loadTestsFromNamesrrr�simple)rrr3s`  rrzPluginProxy.makeCallqsW����'�'��+�+�+��{�{���4��u�-�E�E�
�T�;��
.��:�:���;�;�r#c���d}tt|jdg�|�D��cgc]	\}}|r|��c}}}|jD]#\}}||i|��}|dd}|j	|��%|Scc}}w)z�Call plugins in a chain, where the result of each plugin call is
        sent to the next plugin as input. The final output result is returned.
        N�static_args)�ziprrrr1)rr r!�result�static�arr3s        rrzPluginProxy.chain�s����������m�R�@�#�F��F�$�����F����|�|�G�A�t��3�%�"�%�F���)�C��J�J�v��$��
��s�A-c/��K�|jD]\}}d}	||i|��}|�|D]}|����y#ttf$r�tj�}t|���Y�RxYw�w)zFCall all plugins, yielding each item in each non-None result.
        N)r�KeyboardInterrupt�
SystemExit�sys�exc_infor)rr r!rr3r@�r�excs        rr9zPluginProxy.generate�sy�����|�|�G�A�t��F�

��s�)�b�)���%�#����$��$��&�z�2�
��
��l�l�n���s�m�#��s�A$�0�A$�/A!�A$c�H�|jD]\}}||i|��}|��|cSy)z?Call all plugins, returning the first non-None result.
        N)r)rr r!rr3r@s      rr<zPluginProxy.simple�s0���|�|�G�A�t��3�%�"�%�F��!��
�$r#Nc��g}|jD]+\}}|||��}|��|\}}|s�|j|��-||fS)a
Chainable but not quite normal. Plugins return a tuple of
        (tests, names) after processing the names. The tests are added
        to a suite that is accumulated throughout the full call, while
        names are input for the next plugin in the chain.
        )r))r�extend)r�namesr)�suiterr3r@�
suite_parts        rr;zPluginProxy._loadTestsFromNames�sR�����|�|�G�A�t��%��/�F��!�$*�!�
�E���L�L��,�$��e�|�r#r)r�
__module__�__qualname__�__doc__rrrr"rrrr9r<r;r(r#rrrNs6���!�I�	$�%�
0��"� �"�
r#rc�P�eZdZdZeZd�Zd�Zd�Zd�Z	d�Z
d�Zd�Zd	�Z
d
�Zd�Zy)
�	NoPluginsz(Null Plugin manager that has no plugins.c� �dx|_|_y�Nr()�_pluginsr�rs rrzNoPlugins.__init__�s��')�)��
��r#c��yrVr(rXs r�__iter__zNoPlugins.__iter__����r#c��yrr(�r�args�kwdss   r�
_doNothingzNoPlugins._doNothing����r#c��yrVr(r]s   r�_emptyIteratorzNoPlugins._emptyIterator�r[r#c�x�t|j|�}t|dd�r|jS|jS)Nr6F)rrrcr`)rrrs   r�__getattr__zNoPlugins.__getattr__�s4�������.���6�<��/��&�&�&��?�?�"r#c��t��r��NotImplementedError�r�plugs  rrzNoPlugins.addPlugin����!�#�#r#c��t��rrg�rrs  r�
addPluginszNoPlugins.addPlugins�rkr#c��yrr()r�options�configs   r�	configurezNoPlugins.configure�rar#c��yrr(rXs r�loadPluginszNoPlugins.loadPlugins�rar#c��yrr(rXs r�sortzNoPlugins.sort�rar#N)rrPrQrRrrrrZr`rcrerrnrrrtrvr(r#rrTrT�s<��2� �I�*��
��#�$�$�
�
�
r#rTc�j�eZdZdZeZdd�Zd�Zd�Zd�Z	dd�Z
d�Zd	�Zd
�Z
d�Zd�Zeeedd
�Zy)r
a�Base class for plugin managers. PluginManager is intended to be
    used only with a static list of plugins. The loadPlugins() implementation
    only reloads plugins from _extraplugins to prevent those from being
    overridden by a subclass.

    The basic functionality of a plugin manager is to proxy all unknown
    attributes through a ``PluginProxy`` to a list of plugins.

    Note that the list of plugins *may not* be changed after the first plugin
    call.
    Nc�h�g|_d|_i|_|r|j|�|�||_yyrV)rW�
_extraplugins�_proxiesrn�
proxyClass)rrr{s   rrzPluginManager.__init__�s9����
������
���O�O�G�$��!�(�D�O�"r#c��	|j|S#t$r/|j||j�}||j|<Y|SwxYwr)rz�KeyErrorr{rW)rr�proxys   rrezPluginManager.__getattr__�sL��	(��=�=��&�&���	(��O�O�D�$�-�-�8�E�"'�D�M�M�$����	(�s��4A	�A	c�,�t|j�Sr)�iterrrXs rrZzPluginManager.__iter__s���D�L�L�!�!r#c���t|dt��}|jD�cgc]}t|dd�|k7r|��c}|jdd|jj|�ycc}w)N�name)r�objectrWr1)rrj�new_namers    rrzPluginManager.addPluginsg���4����2��'+�}�}�E�}�!�&�q�&�$�7�8�C��}�E��
�
�a���
�
���T�"��Es�A)c�V�||_t||�D]}|j|��y)z�extraplugins are maintained in a separate list and
        re-added by loadPlugins() to prevent their being overwritten
        by plugins added by a subclass of PluginManager
        N)ry�	iterchainr)rr�extrapluginsrjs    rrnzPluginManager.addPluginss)��
*����g�|�4�D��N�N�4� �5r#c�*�tjd�||_td|j�}|||�|jD�cgc]}|j
s�|��}}||_|j�tjd|�ycc}w)z�Configure the set of plugins with the given options
        and config instance. After configuration, disabled plugins
        are removed from the plugins list.
        zConfiguring pluginsrrzPlugins enabled: %sN)�log�debugrqrrW�enabledrrv)rrprq�cfgrjr�s      rrrzPluginManager.configuresu��
	�	�	�'�(�����+�t�}�}�5���G�V��$(�M�M�B�M�D�T�\�\�4�M��B�����	�	���	�	�'��1��Cs�
B�Bc�H�|jD]}|j|��yr)ryrris  rrtzPluginManager.loadPlugins"s���&�&�D��N�N�4� �'r#c�4�t|jd�d��S)Nc��t|dd�S)N�score�)r)�xs rr-z$PluginManager.sort.<locals>.<lambda>'s
��'�!�W�a�2Hr#T)�reverse)rrWrXs rrvzPluginManager.sort&s������(H�RV�W�Wr#c��|jSr)rWrXs r�_get_pluginszPluginManager._get_plugins)s���}�}�r#c�4�g|_|j|�yr)rWrnrms  r�_set_pluginszPluginManager._set_plugins,s����
����� r#zPAccess the list of plugins managed by
                       this plugin manager)r(N)r(r()rrPrQrRrr{rrerZrrnrrrtrvr�r��propertyrr(r#rr
r
�sX��
��J�)��"�#�!�2�!�X��!��|�\�4�.�/�Gr#r
c�^�eZdZdZd�Zejfd�Zd�Zd�Z	d�Z
d�Zd�Zd	�Z
d
�Zy)�ZeroNinePluginz>Proxy for 0.9 plugins, adapts 0.10 calls to 0.9 standard.
    c��||_yr)r2)rr2s  rrzZeroNinePlugin.__init__8s	����r#c�<�|jj||�yr)r2�add_options)r�parser�envs   rrpzZeroNinePlugin.options;s���������,r#c���t|jd�syddlm}m}|\}}}t||�r<t|jd�sy|jj
|j�St||�r<t|jd�sy|jj|j�S|j}|jj|j||�S)N�addErrorr)�SkipTest�DeprecatedTest�addSkip�
addDeprecated)�hasattrr2�nose.excr�r��
issubclassr��testr��capturedOutputr�)	rr��errr�r��ec�ev�tb�capts	         rr�zZeroNinePlugin.addError>s����t�{�{�J�/��5��
��B���b�(�#��4�;�;�	�2���;�;�&�&�t�y�y�1�1�
��N�
+��4�;�;��8���;�;�,�,�T�Y�Y�7�7��"�"���{�{�#�#�D�I�I�s�D�9�9r#c�f�t|jd�r|jj|�Sy)N�loadTestsFromPath)r�r2r�)r�filenames  r�loadTestsFromFilez ZeroNinePlugin.loadTestsFromFilePs+���4�;�;� 3�4��;�;�0�0��:�:�5r#c��t|jd�sy|j}|j}|jj	|j
|||�S)N�
addFailure)r�r2r��tbinfor�r�)rr�r�r�r�s     rr�zZeroNinePlugin.addFailureTsF���t�{�{�L�1���"�"�������{�{�%�%�d�i�i��d�F�C�Cr#c��t|jd�sy|j}|jj|j|�y)N�
addSuccess)r�r2r�r�r�)rr�r�s   rr�zZeroNinePlugin.addSuccess\s6���t�{�{�L�1���"�"�������t�y�y�$�/r#c�z�t|jd�sy|jj|j�S)N�	startTest)r�r2r�r��rr�s  rr�zZeroNinePlugin.startTestbs,���t�{�{�K�0���{�{�$�$�T�Y�Y�/�/r#c�z�t|jd�sy|jj|j�S)N�stopTest)r�r2r�r�r�s  rr�zZeroNinePlugin.stopTestgs,���t�{�{�J�/���{�{�#�#�D�I�I�.�.r#c�.�t|j|�Sr)rr2)r�vals  rrezZeroNinePlugin.__getattr__ls���t�{�{�C�(�(r#N)rrPrQrRr�os�environrpr�r�r�r�r�r�rer(r#rr�r�5s>����#%�*�*�-�:�$;�D�0�0�
/�
)r#r�c�.��eZdZdZddeffZ�fd�Z�xZS)rzhPlugin manager that loads plugins from the `nose.plugins` and
    `nose.plugins.0.10` entry points.
    )znose.plugins.0.10Nznose.pluginsc	����ddlm}i}|jD]�\}}||�D]�}|j|vr�d||j<tjd|jj|�	|j�}|r||��}n|�}|j|�����tt|�C�y#t$r�t$r }td|�d|��t�Yd}~��d}~wwxYw)zBLoad plugins by iterating the `nose.plugins` entry point.
        r)�iter_entry_pointsTz%s load plugin %szUnable to load plugin z: N)�
pkg_resourcesr��entry_pointsr�r�r��	__class__r�loadrD�	Exceptionr�RuntimeWarningr�superrrt)
rr��loaded�entry_point�adapt�ep�plugcls�erjr�s
         �rrtz#EntryPointPluginManager.loadPluginsws����	4���"&�"3�"3��K��'��4���7�7�f�$��"&��r�w�w���	�	�-�t�~�~�/F�/F��K�
� �g�g�i�G�� ���+�D�"�9�D����t�$�)5�#4�,	�%�t�8�:��)��� ���2�q�A�'�)���
�s�1C�C2�C-�-C2)rrPrQrRr�r�rt�
__classcell__�r�s@rrrps&����0�#�^�4�6�L�;�;r#rc�"��eZdZdZ�fd�Z�xZS)rzSPlugin manager that loads plugins from the list in
    `nose.plugins.builtin`.
    c���ddlm}|jD]}|j|���tt
|��y)z-Load plugins in nose.plugins.builtin
        r)�builtinN)�nose.pluginsr�rrr�rrt)rr�rjr�s   �rrtz BuiltinPluginManager.loadPlugins�s2���	)��O�O�D��N�N�4�6�"�$�
�"�D�5�7r#)rrPrQrRrtr�r�s@rrr�s����8�8r#rc��eZdZy�r	N�rrPrQr(r#rr	r	����r#r	c��eZdZyr�r�r(r#rr	r	�r�r#c�$�eZdZdZdd�Zd�Zd�Zy)r
z�Plugin manager that restricts the plugin list to those not
    excluded by a list of exclude methods. Any plugin that implements
    an excluded method will be removed from the manager's plugin list
    after plugins are loaded.
    c�h�tj||�||_||_g|_d|_yr)r	rr��exclude�excluded�
_excludedOpts)rrr�r�s    rrz RestrictedPluginManager.__init__�s/���%�%�d�G�4���	������
�!��r#c���|j�Bddlm}|d��|_|jD]}|j	|ji���!|jjd|z�S)Nr)�OptionParserF)�add_help_option)r�z--)r��optparser�r�rp�
get_option)rr�r�r2s    r�excludedOptionz&RestrictedPluginManager.excludedOption�s]�����%�-�!-�e�!D�D���-�-�����t�1�1�r��:�(��!�!�,�,�T�D�[�9�9r#c��|jrtj|�g}|jD]T}d}|jD]-}t||�s�d}|jj|�n|s�D|j|��V||_y)NTF)r�r	rtrr�r�r�r1)r�allowr2�okrs     rrtz#RestrictedPluginManager.loadPlugins�s{���9�9� �,�,�T�2����l�l�F��B��,�,���6�6�*��B��M�M�(�(��0��	'�
����V�$�#���r#N)r(r(T)rrPrQrRrr�rtr(r#rr
r
�s���
"�:�
r#r
)$rRr/�loggingr�rF�	itertoolsrr��warningsr�nose.config�nose�nose.failurer�nose.plugins.baser�nose.pyversionr�pickle�ior�__all__�	getLoggerrr�r�rrTr
r�rrr�r	�ImportErrorr
r(r#r�<module>r�s���1�d��	�
�(��� �.�$�����
>���g����!��j�&�j�Z#
��#
�LQ/�F�Q/�h8)�8)�v";�m�";�J
8�=�
8�
��
�6�8L�
�"�2�"��U������B�
�
�3�
�
�s(�B5�C�C
�5B=�C
�
C �C 

if you don't want to be vaporized in a nuclear explosion, i simply have to become nuclear myself… i am atomic