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


Python utils.getProcessOutput方法代碼示例

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


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

示例1: _get_changes

# 需要導入模塊: from twisted.internet import utils [as 別名]
# 或者: from twisted.internet.utils import getProcessOutput [as 別名]
def _get_changes(self):
        log.msg('LLVMGitPoller: polling git repo at %s' % self.repourl)

        self.lastPoll = time.time()

        # get a deferred object that performs the fetch
        args = ['fetch', 'origin']
        self._extend_with_fetch_refspec(args)

        # This command always produces data on stderr, but we actually do not care
        # about the stderr or stdout from this command. We set errortoo=True to
        # avoid an errback from the deferred. The callback which will be added to this
        # deferred will not use the response.
        d = utils.getProcessOutput(self.gitbin, args,
                    path=self.workdir,
                    env=dict(PATH=os.environ['PATH']), errortoo=True )

        return d 
開發者ID:llvm,項目名稱:llvm-zorg,代碼行數:20,代碼來源:llvmgitpoller.py

示例2: test_output

# 需要導入模塊: from twisted.internet import utils [as 別名]
# 或者: from twisted.internet.utils import getProcessOutput [as 別名]
def test_output(self):
        """
        L{getProcessOutput} returns a L{Deferred} which fires with the complete
        output of the process it runs after that process exits.
        """
        scriptFile = self.makeSourceFile([
                "import sys",
                "for s in b'hello world\\n':",
                "    if hasattr(sys.stdout, 'buffer'):",
                "        # Python 3",
                "        s = bytes([s])",
                "        sys.stdout.buffer.write(s)",
                "    else:",
                "        # Python 2",
                "        sys.stdout.write(s)",
                "    sys.stdout.flush()"])
        d = utils.getProcessOutput(self.exe, ['-u', scriptFile])
        return d.addCallback(self.assertEqual, b"hello world\n") 
開發者ID:proxysh,項目名稱:Safejumper-for-Desktop,代碼行數:20,代碼來源:test_iutils.py

示例3: test_outputWithErrorIgnored

# 需要導入模塊: from twisted.internet import utils [as 別名]
# 或者: from twisted.internet.utils import getProcessOutput [as 別名]
def test_outputWithErrorIgnored(self):
        """
        The L{Deferred} returned by L{getProcessOutput} is fired with an
        L{IOError} L{Failure} if the child process writes to stderr.
        """
        # make sure stderr raises an error normally
        scriptFile = self.makeSourceFile([
            'import sys',
            'sys.stderr.write("hello world\\n")'
            ])

        d = utils.getProcessOutput(self.exe, ['-u', scriptFile])
        d = self.assertFailure(d, IOError)
        def cbFailed(err):
            return self.assertFailure(err.processEnded, error.ProcessDone)
        d.addCallback(cbFailed)
        return d 
開發者ID:proxysh,項目名稱:Safejumper-for-Desktop,代碼行數:19,代碼來源:test_iutils.py

示例4: test_outputWithErrorCollected

# 需要導入模塊: from twisted.internet import utils [as 別名]
# 或者: from twisted.internet.utils import getProcessOutput [as 別名]
def test_outputWithErrorCollected(self):
        """
        If a C{True} value is supplied for the C{errortoo} parameter to
        L{getProcessOutput}, the returned L{Deferred} fires with the child's
        stderr output as well as its stdout output.
        """
        scriptFile = self.makeSourceFile([
            'import sys',
            # Write the same value to both because ordering isn't guaranteed so
            # this simplifies the test.
            'sys.stdout.write("foo")',
            'sys.stdout.flush()',
            'sys.stderr.write("foo")',
            'sys.stderr.flush()'])

        d = utils.getProcessOutput(self.exe, ['-u', scriptFile], errortoo=True)
        return d.addCallback(self.assertEqual, b"foofoo") 
開發者ID:proxysh,項目名稱:Safejumper-for-Desktop,代碼行數:19,代碼來源:test_iutils.py

示例5: run_script

# 需要導入模塊: from twisted.internet import utils [as 別名]
# 或者: from twisted.internet.utils import getProcessOutput [as 別名]
def run_script(self, script, options=None):
        """
        Run a script that logs messages and uses ``FlockerScriptRunner``.

        :param ICommandLineScript: Script to run. Must be class in this module.
        :param list options: Extra command line options to pass to the
            script.

        :return: ``Deferred`` that fires with list of decoded JSON messages.
        """
        if options is None:
            options = []
        code = _SCRIPT_CODE.format(script.__name__, script.__name__)
        d = getProcessOutput(
            sys.executable, [b"-c", code] + options,
            env=os.environ,
            errortoo=True
        )
        d.addCallback(lambda data: (msg(b"script output: " + data), data)[1])
        d.addCallback(lambda data: map(loads, data.splitlines()))
        return d 
開發者ID:ClusterHQ,項目名稱:flocker,代碼行數:23,代碼來源:test_script.py

示例6: spawn_reporter

# 需要導入模塊: from twisted.internet import utils [as 別名]
# 或者: from twisted.internet.utils import getProcessOutput [as 別名]
def spawn_reporter(self):
        args = ["--quiet"]
        if self.config.config:
            args.extend(["-c", self.config.config])
        env = os.environ.copy()

        if self.config.clones > 0:
            if self.config.is_clone:
                return self._run_fake_reporter(args)
            else:
                env["FAKE_GLOBAL_PACKAGE_STORE"] = "1"

        if self._reporter_command is None:
            self._reporter_command = find_reporter_command(self.config)
        # path is set to None so that getProcessOutput does not
        # chdir to "." see bug #211373
        env = encode_values(env)
        result = getProcessOutput(self._reporter_command,
                                  args=args, env=env,
                                  errortoo=1,
                                  path=None)
        result.addCallback(self._got_reporter_output)
        return result 
開發者ID:CanonicalLtd,項目名稱:landscape-client,代碼行數:25,代碼來源:packagemonitor.py

示例7: test_outputWithErrorCollected

# 需要導入模塊: from twisted.internet import utils [as 別名]
# 或者: from twisted.internet.utils import getProcessOutput [as 別名]
def test_outputWithErrorCollected(self):
        """
        If a C{True} value is supplied for the C{errortoo} parameter to
        L{getProcessOutput}, the returned L{Deferred} fires with the child's
        stderr output as well as its stdout output.
        """
        scriptFile = self.makeSourceFile([
            'import sys',
            # Write the same value to both because ordering isn't guaranteed so
            # this simplifies the test.
            'sys.stdout.write("foo")',
            'sys.stdout.flush()',
            'sys.stderr.write("foo")',
            'sys.stderr.flush()'])

        d = utils.getProcessOutput(self.exe, ['-u', scriptFile], errortoo=True)
        return d.addCallback(self.assertEqual, "foofoo") 
開發者ID:kuri65536,項目名稱:python-for-android,代碼行數:19,代碼來源:test_iutils.py

示例8: _get_commit_comments

# 需要導入模塊: from twisted.internet import utils [as 別名]
# 或者: from twisted.internet.utils import getProcessOutput [as 別名]
def _get_commit_comments(self, rev):
        args = ['log', rev, '--no-walk', r'--format=%s%n%b']
        d = utils.getProcessOutput(self.gitbin, args, path=self.workdir, env=dict(PATH=os.environ['PATH']), errortoo=False )
        def process(git_output):
            stripped_output = git_output.strip().decode(self.encoding)
            if len(stripped_output) == 0:
                raise EnvironmentError('could not get commit comment for rev')
            #log.msg("LLVMGitPoller: _get_commit_comments: '%s'" % stripped_output)
            return stripped_output
        d.addCallback(process)
        return d 
開發者ID:llvm,項目名稱:llvm-zorg,代碼行數:13,代碼來源:llvmgitpoller.py

示例9: _get_commit_timestamp

# 需要導入模塊: from twisted.internet import utils [as 別名]
# 或者: from twisted.internet.utils import getProcessOutput [as 別名]
def _get_commit_timestamp(self, rev):
        # unix timestamp
        args = ['log', rev, '--no-walk', r'--format=%ct']
        d = utils.getProcessOutput(self.gitbin, args, path=self.workdir, env=dict(PATH=os.environ['PATH']), errortoo=False )
        def process(git_output):
            stripped_output = git_output.strip()
            if self.usetimestamps:
                try:
                    stamp = float(stripped_output)
                    #log.msg("LLVMGitPoller: _get_commit_timestamp: \'%s\'" % stamp)
                except Exception, e:
                        log.msg('LLVMGitPoller: caught exception converting output \'%s\' to timestamp' % stripped_output)
                        raise e
                return stamp
            else: 
開發者ID:llvm,項目名稱:llvm-zorg,代碼行數:17,代碼來源:llvmgitpoller.py

示例10: _get_commit_files

# 需要導入模塊: from twisted.internet import utils [as 別名]
# 或者: from twisted.internet.utils import getProcessOutput [as 別名]
def _get_commit_files(self, rev):
        args = ['log', rev, '--name-only', '--no-walk', r'--format=%n']
        d = utils.getProcessOutput(self.gitbin, args, path=self.workdir, env=dict(PATH=os.environ['PATH']), errortoo=False )
        def process(git_output):
            fileList = git_output.split()
            #log.msg("LLVMGitPoller: _get_commit_files: \'%s\'" % fileList)
            return fileList
        d.addCallback(process)
        return d 
開發者ID:llvm,項目名稱:llvm-zorg,代碼行數:11,代碼來源:llvmgitpoller.py

示例11: _get_commit_name

# 需要導入模塊: from twisted.internet import utils [as 別名]
# 或者: from twisted.internet.utils import getProcessOutput [as 別名]
def _get_commit_name(self, rev):
        args = ['log', rev, '--no-walk', r'--format=%aN <%aE>']
        d = utils.getProcessOutput(self.gitbin, args, path=self.workdir, env=dict(PATH=os.environ['PATH']), errortoo=False )
        def process(git_output):
            stripped_output = git_output.strip().decode(self.encoding)
            if len(stripped_output) == 0:
                raise EnvironmentError('could not get commit name for rev')
            #log.msg("LLVMGitPoller: _get_commit_name: \'%s\'" % stripped_output)
            return stripped_output
        d.addCallback(process)
        return d 
開發者ID:llvm,項目名稱:llvm-zorg,代碼行數:13,代碼來源:llvmgitpoller.py

示例12: get_logs

# 需要導入模塊: from twisted.internet import utils [as 別名]
# 或者: from twisted.internet.utils import getProcessOutput [as 別名]
def get_logs(self, _):
        args = []
        args.extend(["log", "--xml", "--verbose", "--non-interactive"])
        if self.svnuser:
            args.extend(["--username=%s" % self.svnuser])
        if self.svnpasswd:
            args.extend(["--password=%s" % self.svnpasswd])
        args.extend(["--limit=%d" % (self.histmax), self.svnurl])
        d = self.getProcessOutput(args)
        return d 
開發者ID:llvm,項目名稱:llvm-zorg,代碼行數:12,代碼來源:llvmpoller.py

示例13: cmd_EXEC

# 需要導入模塊: from twisted.internet import utils [as 別名]
# 或者: from twisted.internet.utils import getProcessOutput [as 別名]
def cmd_EXEC(self, rest):
        """
        Run C{rest} using the user's shell (or /bin/sh if they do not have
        one).
        """
        shell = self._pwd.getpwnam(getpass.getuser())[6]
        if not shell:
            shell = '/bin/sh'
        if rest:
            cmds = ['-c', rest]
            return utils.getProcessOutput(shell, cmds, errortoo=1)
        else:
            os.system(shell)

    # accessory functions 
開發者ID:proxysh,項目名稱:Safejumper-for-Desktop,代碼行數:17,代碼來源:cftp.py

示例14: test_getProcessOutputPath

# 需要導入模塊: from twisted.internet import utils [as 別名]
# 或者: from twisted.internet.utils import getProcessOutput [as 別名]
def test_getProcessOutputPath(self):
        """
        L{getProcessOutput} runs the given command with the working directory
        given by the C{path} parameter.
        """
        return self._pathTest(utils.getProcessOutput, self.assertEqual) 
開發者ID:proxysh,項目名稱:Safejumper-for-Desktop,代碼行數:8,代碼來源:test_iutils.py

示例15: this_node_uuid

# 需要導入模塊: from twisted.internet import utils [as 別名]
# 或者: from twisted.internet.utils import getProcessOutput [as 別名]
def this_node_uuid(self):
        getting_era = getProcessOutput(
            "flocker-node-era", reactor=self._reactor, env=environ)

        def got_era(era):
            return retry_failure(
                self._reactor, lambda: self._request(
                    b"GET", b"/state/nodes/by_era/" + era, None, {OK},
                    {NOT_FOUND: NotFound},
                ), [NotFound])
        request = getting_era.addCallback(got_era)
        request.addCallback(lambda result: UUID(result["uuid"]))
        return request 
開發者ID:ClusterHQ,項目名稱:flocker,代碼行數:15,代碼來源:_client.py


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