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


Python xmlrpclib.ProtocolError方法代碼示例

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


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

示例1: is_unavailable_exception

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ProtocolError [as 別名]
def is_unavailable_exception(e):
    '''Returns True if the given ProtocolError is the product of a server-side
       exception caused by the 'temporarily unavailable' response sometimes
       given by operations on non-blocking sockets.'''

    # sometimes we get a -1 error code and/or empty headers
    try:
        if e.errcode == -1 or e.headers is None:
            return True
        exc_mess = e.headers.get('X-exception')
    except AttributeError:
        # Ignore socket.errors here.
        exc_mess = str(e)

    if exc_mess and 'temporarily unavailable' in exc_mess.lower():
        return True

    return False 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:20,代碼來源:test_xmlrpc.py

示例2: test_multicall

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ProtocolError [as 別名]
def test_multicall(self):
        try:
            p = xmlrpclib.ServerProxy(URL)
            multicall = xmlrpclib.MultiCall(p)
            multicall.add(2,3)
            multicall.pow(6,8)
            multicall.div(127,42)
            add_result, pow_result, div_result = multicall()
            self.assertEqual(add_result, 2+3)
            self.assertEqual(pow_result, 6**8)
            self.assertEqual(div_result, 127//42)
        except (xmlrpclib.ProtocolError, socket.error), e:
            # ignore failures due to non-blocking socket 'unavailable' errors
            if not is_unavailable_exception(e):
                # protocol error; provide additional information in test output
                self.fail("%s\n%s" % (e, getattr(e, "headers", ""))) 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:18,代碼來源:test_xmlrpc.py

示例3: test_non_existing_multicall

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ProtocolError [as 別名]
def test_non_existing_multicall(self):
        try:
            p = xmlrpclib.ServerProxy(URL)
            multicall = xmlrpclib.MultiCall(p)
            multicall.this_is_not_exists()
            result = multicall()

            # result.results contains;
            # [{'faultCode': 1, 'faultString': '<type \'exceptions.Exception\'>:'
            #   'method "this_is_not_exists" is not supported'>}]

            self.assertEqual(result.results[0]['faultCode'], 1)
            self.assertEqual(result.results[0]['faultString'],
                '<type \'exceptions.Exception\'>:method "this_is_not_exists" '
                'is not supported')
        except (xmlrpclib.ProtocolError, socket.error), e:
            # ignore failures due to non-blocking socket 'unavailable' errors
            if not is_unavailable_exception(e):
                # protocol error; provide additional information in test output
                self.fail("%s\n%s" % (e, getattr(e, "headers", ""))) 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:22,代碼來源:test_xmlrpc.py

示例4: test_basic

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ProtocolError [as 別名]
def test_basic(self):
        # check that flag is false by default
        flagval = SimpleXMLRPCServer.SimpleXMLRPCServer._send_traceback_header
        self.assertEqual(flagval, False)

        # enable traceback reporting
        SimpleXMLRPCServer.SimpleXMLRPCServer._send_traceback_header = True

        # test a call that shouldn't fail just as a smoke test
        try:
            p = xmlrpclib.ServerProxy(URL)
            self.assertEqual(p.pow(6,8), 6**8)
        except (xmlrpclib.ProtocolError, socket.error), e:
            # ignore failures due to non-blocking socket 'unavailable' errors
            if not is_unavailable_exception(e):
                # protocol error; provide additional information in test output
                self.fail("%s\n%s" % (e, getattr(e, "headers", ""))) 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:19,代碼來源:test_xmlrpc.py

示例5: test_fail_with_info

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ProtocolError [as 別名]
def test_fail_with_info(self):
        # use the broken message class
        SimpleXMLRPCServer.SimpleXMLRPCRequestHandler.MessageClass = FailingMessageClass

        # Check that errors in the server send back exception/traceback
        # info when flag is set
        SimpleXMLRPCServer.SimpleXMLRPCServer._send_traceback_header = True

        try:
            p = xmlrpclib.ServerProxy(URL)
            p.pow(6,8)
        except (xmlrpclib.ProtocolError, socket.error), e:
            # ignore failures due to non-blocking socket 'unavailable' errors
            if not is_unavailable_exception(e) and hasattr(e, "headers"):
                # We should get error info in the response
                expected_err = "invalid literal for int() with base 10: 'I am broken'"
                self.assertEqual(e.headers.get("x-exception"), expected_err)
                self.assertTrue(e.headers.get("x-traceback") is not None) 
開發者ID:IronLanguages,項目名稱:ironpython2,代碼行數:20,代碼來源:test_xmlrpc.py

示例6: terminate

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ProtocolError [as 別名]
def terminate(self):

        if self.server is None:
            # Nothing to do
            return

        try:
            response = self.server.LogOut(self.token)
        except xmlrpclib.ProtocolError:
            raise ProviderNotAvailable
        except xmlrpclib.ResponseNotReady:
            logger.warning('ResponseNotReady exception thrown on logout.')
            return

        if response['status'] != '200 OK':
            raise ProviderError('Logout failed with status %r' % response['status']) 
開發者ID:caronc,項目名稱:nzb-subliminal,代碼行數:18,代碼來源:opensubtitles.py

示例7: download_subtitle

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ProtocolError [as 別名]
def download_subtitle(self, subtitle):

        if self.server is None:
            # Nothing to do
            raise ProviderError('Provider not initialized.')

        try:
            response = self.server.DownloadSubtitles(self.token, [subtitle.id])
            logger.debug('Download URL: %s {token=%s, subid:%s}' % (
                self.server_url,
                self.token, subtitle.id,
            ))
        except xmlrpclib.ProtocolError:
            raise ProviderNotAvailable
        if response['status'] != '200 OK':
            raise ProviderError(
                'Download failed with status %s' % str(response['status']))
        if not response['data']:
            raise ProviderError('Nothing to download')
        subtitle_bytes = zlib.decompress(base64.b64decode(response['data'][0]['data']), 47)
        subtitle_text = subtitle_bytes.decode(
            detect(subtitle_bytes, subtitle.language.alpha2)['encoding'], 'replace')
        if not is_valid_subtitle(subtitle_text):
            raise InvalidSubtitle
        return subtitle_text 
開發者ID:caronc,項目名稱:nzb-subliminal,代碼行數:27,代碼來源:opensubtitles.py

示例8: request

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ProtocolError [as 別名]
def request(self, host, handler, request_body, verbose):
        """
        Make an xmlrpc request.
        """
        client = self.session or requests
        headers = {'User-Agent': self.user_agent,
                   'Content-Type': 'text/xml',
                   }
        url = self._build_url(host, handler)
        try:
            resp = client.post(url, data=request_body, headers=headers, timeout=self.timeout)
        except ValueError:
            raise
        except Exception:
            raise # something went wrong
        else:
            try:
                resp.raise_for_status()
            except requests.RequestException as e:
                raise xmlrpc.ProtocolError(url, resp.status_code,
                    str(e), resp.headers)
            else:
                return self.parse_response(resp) 
開發者ID:ip-tools,項目名稱:patzilla,代碼行數:25,代碼來源:requests_xmlrpclib.py

示例9: bitcoind_get_transactions_from_block

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ProtocolError [as 別名]
def bitcoind_get_transactions_from_block(self, block, addresses):
    logging.info(addresses)
    transaction_ids = block['tx']

    transactions_per_address = {}
    for addr in addresses:
      transactions_per_address[addr] = []

    for tx in transaction_ids:
      try:
        raw_transaction = self.get_raw_transaction(tx)
      except ProtocolError:
        continue
      transaction = self.decode_raw_transaction(raw_transaction)
      for vout in transaction['vout']:
        if not 'addresses' in vout['scriptPubKey']:
          continue
        addresses_in_vout = set(vout['scriptPubKey']['addresses'])
        for addr in addresses:
          if addr in addresses_in_vout:
            transactions_per_address[addr].append(transaction)

    logging.info(transactions_per_address)
    return transactions_per_address 
開發者ID:orisi,項目名稱:orisi,代碼行數:26,代碼來源:bitcoinclient.py

示例10: _run_and_ignore_connection_lost

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ProtocolError [as 別名]
def _run_and_ignore_connection_lost(self):
        try:
            yield
        except RuntimeError as r:  # disconnection from remotelibrary
            if 'Connection to remote server broken:' in r.args[0]:
                logger.info('Connection died as expected')
                return
            raise
        except HandlerExecutionFailed as e:  # disconnection from xmlrpc wrapped in robot keyword
            if any(elem in e.args[0] for elem in ('Connection to remote server broken:', 'ProtocolError')):
                logger.info('Connection died as expected')
                return
            raise
        except ProtocolError as r:  # disconnection from xmlrpc in jython on some platforms
            logger.info('Connection died as expected')
            return 
開發者ID:robotframework,項目名稱:remoteswinglibrary,代碼行數:18,代碼來源:RemoteSwingLibrary.py

示例11: _request

# 需要導入模塊: import xmlrpclib [as 別名]
# 或者: from xmlrpclib import ProtocolError [as 別名]
def _request(self, host, handler, request_body, verbose=0):
        # issue XML-RPC request
        h = self.cache.get_connection()
        try:
            self._set_connection_params(h)
            h.add_data(request_body)
            response = pycurllib.urlopen(h, close=False)
        except:
            # connection may no longer be valid
            self.cache.destroy_connection(h)
            raise
        self.cache.put_connection(h)
        if response.code != 200:
            raise xmlrpclib.ProtocolError(
                host + handler,
                response.code, response.msg,
                'N/A',
            )
        self.verbose = verbose
        return self._parse_response(response) 
開發者ID:kenorb-contrib,項目名稱:BitTorrent,代碼行數:22,代碼來源:xmlrpclib2.py


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