當前位置: 首頁>>代碼示例>>Python>>正文


Python setuptools.sandbox方法代碼示例

本文整理匯總了Python中setuptools.sandbox方法的典型用法代碼示例。如果您正苦於以下問題:Python setuptools.sandbox方法的具體用法?Python setuptools.sandbox怎麽用?Python setuptools.sandbox使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在setuptools的用法示例。


在下文中一共展示了setuptools.sandbox方法的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: _no_sandbox

# 需要導入模塊: import setuptools [as 別名]
# 或者: from setuptools import sandbox [as 別名]
def _no_sandbox(function):
    def __no_sandbox(*args, **kw):
        try:
            from setuptools.sandbox import DirectorySandbox
            if not hasattr(DirectorySandbox, '_old'):
                def violation(*args):
                    pass
                DirectorySandbox._old = DirectorySandbox._violation
                DirectorySandbox._violation = violation
                patched = True
            else:
                patched = False
        except ImportError:
            patched = False

        try:
            return function(*args, **kw)
        finally:
            if patched:
                DirectorySandbox._violation = DirectorySandbox._old
                del DirectorySandbox._old

    return __no_sandbox 
開發者ID:bunbun,項目名稱:nested-dict,代碼行數:25,代碼來源:ez_setup.py

示例2: test_unpickleable_exception_when_hiding_setuptools

# 需要導入模塊: import setuptools [as 別名]
# 或者: from setuptools import sandbox [as 別名]
def test_unpickleable_exception_when_hiding_setuptools(self):
        """
        As revealed in #440, an infinite recursion can occur if an unpickleable
        exception while setuptools is hidden. Ensure this doesn't happen.
        """

        class ExceptionUnderTest(Exception):
            """
            An unpickleable exception (not in globals).
            """

        with pytest.raises(setuptools.sandbox.UnpickleableException) as caught:
            with setuptools.sandbox.save_modules():
                setuptools.sandbox.hide_setuptools()
                raise ExceptionUnderTest()

        msg, = caught.value.args
        assert msg == 'ExceptionUnderTest()' 
開發者ID:pypa,項目名稱:setuptools,代碼行數:20,代碼來源:test_sandbox.py

示例3: _rename_path

# 需要導入模塊: import setuptools [as 別名]
# 或者: from setuptools import sandbox [as 別名]
def _rename_path(path):
    new_name = path + '.OLD.%s' % time.time()
    log.warn('Renaming %s into %s', path, new_name)
    try:
        from setuptools.sandbox import DirectorySandbox
        def _violation(*args):
            pass
        DirectorySandbox._violation = _violation
    except ImportError:
        pass

    os.rename(path, new_name)
    return new_name 
開發者ID:arcpy,項目名稱:sample-gp-tools,代碼行數:15,代碼來源:distribute_setup.py

示例4: test_devnull

# 需要導入模塊: import setuptools [as 別名]
# 或者: from setuptools import sandbox [as 別名]
def test_devnull(self, tmpdir):
        with setuptools.sandbox.DirectorySandbox(str(tmpdir)):
            self._file_writer(os.devnull) 
開發者ID:pypa,項目名稱:setuptools,代碼行數:5,代碼來源:test_sandbox.py

示例5: test_setup_py_with_BOM

# 需要導入模塊: import setuptools [as 別名]
# 或者: from setuptools import sandbox [as 別名]
def test_setup_py_with_BOM(self):
        """
        It should be possible to execute a setup.py with a Byte Order Mark
        """
        target = pkg_resources.resource_filename(
            __name__,
            'script-with-bom.py')
        namespace = types.ModuleType('namespace')
        setuptools.sandbox._execfile(target, vars(namespace))
        assert namespace.result == 'passed' 
開發者ID:pypa,項目名稱:setuptools,代碼行數:12,代碼來源:test_sandbox.py

示例6: test_setup_py_with_CRLF

# 需要導入模塊: import setuptools [as 別名]
# 或者: from setuptools import sandbox [as 別名]
def test_setup_py_with_CRLF(self, tmpdir):
        setup_py = tmpdir / 'setup.py'
        with setup_py.open('wb') as stream:
            stream.write(b'"degenerate script"\r\n')
        setuptools.sandbox._execfile(str(setup_py), globals()) 
開發者ID:pypa,項目名稱:setuptools,代碼行數:7,代碼來源:test_sandbox.py

示例7: test_exception_trapped

# 需要導入模塊: import setuptools [as 別名]
# 或者: from setuptools import sandbox [as 別名]
def test_exception_trapped(self):
        with setuptools.sandbox.ExceptionSaver():
            raise ValueError("details") 
開發者ID:pypa,項目名稱:setuptools,代碼行數:5,代碼來源:test_sandbox.py

示例8: test_exception_resumed

# 需要導入模塊: import setuptools [as 別名]
# 或者: from setuptools import sandbox [as 別名]
def test_exception_resumed(self):
        with setuptools.sandbox.ExceptionSaver() as saved_exc:
            raise ValueError("details")

        with pytest.raises(ValueError) as caught:
            saved_exc.resume()

        assert isinstance(caught.value, ValueError)
        assert str(caught.value) == 'details' 
開發者ID:pypa,項目名稱:setuptools,代碼行數:11,代碼來源:test_sandbox.py

示例9: test_no_exception_passes_quietly

# 需要導入模塊: import setuptools [as 別名]
# 或者: from setuptools import sandbox [as 別名]
def test_no_exception_passes_quietly(self):
        with setuptools.sandbox.ExceptionSaver() as saved_exc:
            pass

        saved_exc.resume() 
開發者ID:pypa,項目名稱:setuptools,代碼行數:7,代碼來源:test_sandbox.py

示例10: test_unpickleable_exception

# 需要導入模塊: import setuptools [as 別名]
# 或者: from setuptools import sandbox [as 別名]
def test_unpickleable_exception(self):
        class CantPickleThis(Exception):
            "This Exception is unpickleable because it's not in globals"
            def __repr__(self):
                return 'CantPickleThis%r' % (self.args,)

        with setuptools.sandbox.ExceptionSaver() as saved_exc:
            raise CantPickleThis('detail')

        with pytest.raises(setuptools.sandbox.UnpickleableException) as caught:
            saved_exc.resume()

        assert str(caught.value) == "CantPickleThis('detail',)" 
開發者ID:pypa,項目名稱:setuptools,代碼行數:15,代碼來源:test_sandbox.py

示例11: test_sandbox_violation_raised_hiding_setuptools

# 需要導入模塊: import setuptools [as 別名]
# 或者: from setuptools import sandbox [as 別名]
def test_sandbox_violation_raised_hiding_setuptools(self, tmpdir):
        """
        When in a sandbox with setuptools hidden, a SandboxViolation
        should reflect a proper exception and not be wrapped in
        an UnpickleableException.
        """

        def write_file():
            "Trigger a SandboxViolation by writing outside the sandbox"
            with open('/etc/foo', 'w'):
                pass

        with pytest.raises(setuptools.sandbox.SandboxViolation) as caught:
            with setuptools.sandbox.save_modules():
                setuptools.sandbox.hide_setuptools()
                with setuptools.sandbox.DirectorySandbox(str(tmpdir)):
                    write_file()

        cmd, args, kwargs = caught.value.args
        assert cmd == 'open'
        assert args == ('/etc/foo', 'w')
        assert kwargs == {}

        msg = str(caught.value)
        assert 'open' in msg
        assert "('/etc/foo', 'w')" in msg 
開發者ID:pypa,項目名稱:setuptools,代碼行數:28,代碼來源:test_sandbox.py

示例12: user_install_setup_context

# 需要導入模塊: import setuptools [as 別名]
# 或者: from setuptools import sandbox [as 別名]
def user_install_setup_context(self, *args, **kwargs):
        """
        Wrap sandbox.setup_context to patch easy_install in that context to
        appear as user-installed.
        """
        with self.orig_context(*args, **kwargs):
            import setuptools.command.easy_install as ei
            ei.__file__ = site.USER_SITE
            yield 
開發者ID:pypa,項目名稱:setuptools,代碼行數:11,代碼來源:test_easy_install.py

示例13: test_setup_requires_honors_fetch_params

# 需要導入模塊: import setuptools [as 別名]
# 或者: from setuptools import sandbox [as 別名]
def test_setup_requires_honors_fetch_params(self, mock_index, monkeypatch):
        """
        When easy_install installs a source distribution which specifies
        setup_requires, it should honor the fetch parameters (such as
        index-url, and find-links).
        """
        monkeypatch.setenv(str('PIP_RETRIES'), str('0'))
        monkeypatch.setenv(str('PIP_TIMEOUT'), str('0'))
        with contexts.quiet():
            # create an sdist that has a build-time dependency.
            with TestSetupRequires.create_sdist() as dist_file:
                with contexts.tempdir() as temp_install_dir:
                    with contexts.environment(PYTHONPATH=temp_install_dir):
                        ei_params = [
                            '--index-url', mock_index.url,
                            '--exclude-scripts',
                            '--install-dir', temp_install_dir,
                            dist_file,
                        ]
                        with sandbox.save_argv(['easy_install']):
                            # attempt to install the dist. It should
                            # fail because it doesn't exist.
                            with pytest.raises(SystemExit):
                                easy_install_pkg.main(ei_params)
        # there should have been one requests to the server
        assert [r.path for r in mock_index.requests] == ['/does-not-exist/'] 
開發者ID:pypa,項目名稱:setuptools,代碼行數:28,代碼來源:test_easy_install.py


注:本文中的setuptools.sandbox方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。