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


Python error.HTTPError方法代碼示例

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


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

示例1: provisioning_completed

# 需要導入模塊: from six.moves.urllib import error [as 別名]
# 或者: from six.moves.urllib.error import HTTPError [as 別名]
def provisioning_completed(self):
        """Signal to Packet that the instance is ready.

        To complete the provisioning, on the first boot after installation
        make a GET request to CONF.packet.metadata_url, which will return a
        JSON object which contains phone_home_url entry.
        Make a POST request to phone_home_url with no body (important!)
        and this will complete the installation process.
        """
        phone_home_url = self._get_phone_home_url()
        LOG.info("Calling home to: %s", phone_home_url)
        try:
            action = lambda: self._http_request(url=phone_home_url,
                                                method="post")
            return self._exec_with_retry(action)
        except error.HTTPError as exc:
            LOG.exception(exc)
            raise exception.MetadataEndpointException(
                "Failed to call home to the metadata service") 
開發者ID:cloudbase,項目名稱:cloudbase-init,代碼行數:21,代碼來源:packet.py

示例2: _test_post_password

# 需要導入模塊: from six.moves.urllib import error [as 別名]
# 或者: from six.moves.urllib.error import HTTPError [as 別名]
def _test_post_password(self, mock_http_request,
                            mock_get_phone_url, mock_sleep, fail=False):
        fake_phone_url = 'fake_phone_url'
        fake_response = 'fake_response'
        fake_encoded_password = b'fake_password'

        if fail:
            mock_http_request.side_effect = (
                error.HTTPError(401, "invalid", {}, 0, 0))
            with self.assertRaises(exception.MetadataEndpointException):
                self._packet_service.post_password(fake_encoded_password)
        else:
            mock_http_request.return_value = fake_response
            mock_get_phone_url.return_value = fake_phone_url

            response = self._packet_service.post_password(
                fake_encoded_password)
            mock_get_phone_url.assert_called_once()
            mock_http_request.assert_called_once_with(
                data='{"password": "fake_password"}',
                url=fake_phone_url)

            self.assertEqual(response, fake_response) 
開發者ID:cloudbase,項目名稱:cloudbase-init,代碼行數:25,代碼來源:test_packet.py

示例3: _test_provisioning_completed

# 需要導入模塊: from six.moves.urllib import error [as 別名]
# 或者: from six.moves.urllib.error import HTTPError [as 別名]
def _test_provisioning_completed(self, mock_http_request,
                                     mock_get_phone_url, mock_sleep,
                                     fail=False):
        fake_phone_url = 'fake_phone_url'
        fake_response = 'fake_response'

        if fail:
            mock_http_request.side_effect = (
                error.HTTPError(401, "invalid", {}, 0, 0))
            with self.assertRaises(exception.MetadataEndpointException):
                self._packet_service.provisioning_completed()
        else:
            mock_http_request.return_value = fake_response
            mock_get_phone_url.return_value = fake_phone_url

            response = self._packet_service.provisioning_completed()
            mock_get_phone_url.assert_called_once()
            mock_http_request.assert_called_once_with(
                url=fake_phone_url,
                method="post")

            self.assertEqual(response, fake_response) 
開發者ID:cloudbase,項目名稱:cloudbase-init,代碼行數:24,代碼來源:test_packet.py

示例4: download

# 需要導入模塊: from six.moves.urllib import error [as 別名]
# 或者: from six.moves.urllib.error import HTTPError [as 別名]
def download(self):
        """Downloads the archive from one of the mirrors"""
        if not os.path.exists(self.archive_path):
            for turn in xrange(self.trials_404):
                for i, link in enumerate(self.download_links()):
                    try:
                        return self.do_download(link, self.archive_path)
                    except HTTPError as e:
                        if e.code != 404:
                            raise
                        print("HTTP 404 while trying to get the archive using link" \
                              " '%s' (trial %d/%d)" % (link, turn+1, self.trials_404))
                    except URLError as e:
                        print("Error while trying to get the archive using link" \
                              " '%s' (trial %d/%d)" % (link, turn+1, self.trials_404))
                        raise e 
開發者ID:pysmt,項目名稱:pysmt,代碼行數:18,代碼來源:base.py

示例5: check_url

# 需要導入模塊: from six.moves.urllib import error [as 別名]
# 或者: from six.moves.urllib.error import HTTPError [as 別名]
def check_url(docker_ip, public_port):
    """Check if a service is reachable.

    Makes a simple GET request to '/' of the HTTP endpoint. Service is
    available if returned status code is < 500.
    """
    url = 'http://{}:{}'.format(docker_ip, public_port)
    try:
        r = urlopen(url)
        return r.code < 500
    except HTTPError as e:
        # If service returns e.g. a 404 it's ok
        return e.code < 500
    except Exception:
        # Possible service not yet started
        return False 
開發者ID:lovelysystems,項目名稱:lovely-pytest-docker,代碼行數:18,代碼來源:compose.py

示例6: _request

# 需要導入模塊: from six.moves.urllib import error [as 別名]
# 或者: from six.moves.urllib.error import HTTPError [as 別名]
def _request(self, req_body=None, method=None,
                 header=constants.CONTENT_TYPE_URLENCODE):
        req = url_request.Request(self._url, req_body.encode(), header)
        if method not in (None, 'GET', 'POST'):
            req.get_method = lambda: method
        self._http_log_req(req)
        try:
            resp = self.url_opener.open(req)
            resp_body = resp.read()
            self._http_log_resp(resp, resp_body)
        except url_error.HTTPError as http_err:
            if '403' == six.text_type(http_err.code):
                raise exception.NotAuthorized()
            else:
                err = {'errorCode': -1,
                       'httpStatusCode': http_err.code,
                       'messages': six.text_type(http_err),
                       'request': req_body}
                msg = (_("The request is invalid. Reason: %(reason)s") %
                       {'reason': err})
                raise exception.ManilaException(message=msg)

        return resp_body 
開發者ID:openstack,項目名稱:manila,代碼行數:25,代碼來源:connector.py

示例7: test_upload_vnf_package_from_uri_with_invalid_auth

# 需要導入模塊: from six.moves.urllib import error [as 別名]
# 或者: from six.moves.urllib.error import HTTPError [as 別名]
def test_upload_vnf_package_from_uri_with_invalid_auth(self,
                                                           mock_url_open):
        address_information = "http://localhost/test.zip"
        user_name = "username"
        password = "password"
        mock_url_open.side_effect = urlerr.HTTPError(
            url='', code=401, msg='HTTP Error 401 Unauthorized', hdrs={},
            fp=None)
        self.assertRaises(exceptions.VNFPackageURLInvalid,
                          self.conductor.upload_vnf_package_from_uri,
                          self.context,
                          self.vnf_package,
                          address_information,
                          user_name=user_name,
                          password=password)
        self.assertEqual('CREATED', self.vnf_package.onboarding_state) 
開發者ID:openstack,項目名稱:tacker,代碼行數:18,代碼來源:test_conductor_server.py

示例8: get

# 需要導入模塊: from six.moves.urllib import error [as 別名]
# 或者: from six.moves.urllib.error import HTTPError [as 別名]
def get(path, **kwargs):
    """Send a GET request.

    Parameters
    ----------
    path : str
        The path portion of the URL.
    kwargs : any
        Passed to `request`.

    Returns
    -------
    RestObj or None
        The results or None if the resource was not found.

    """
    try:
        return request('get', path, **kwargs)
    except HTTPError as e:
        if e.code == 404:
            return None  # Resource not found
        raise e 
開發者ID:sassoftware,項目名稱:python-sasctl,代碼行數:24,代碼來源:core.py

示例9: test_register_model_403_error

# 需要導入模塊: from six.moves.urllib import error [as 別名]
# 或者: from six.moves.urllib.error import HTTPError [as 別名]
def test_register_model_403_error(get_project, get_repository):
    """Verify HTTP 403 is converted to a user-friendly error.

    Depending on environment configuration, this can happen when attempting to
    find a repository.

    See: https://github.com/sassoftware/python-sasctl/issues/39
    """

    from six.moves.urllib.error import HTTPError
    from sasctl.exceptions import AuthorizationError
    from sasctl.tasks import register_model

    get_project.return_value = {'name': 'Project Name'}
    get_repository.side_effect = HTTPError(None, 403, None, None, None)

    # HTTP 403 error when getting repository should throw a user-friendly
    # AuthorizationError
    with pytest.raises(AuthorizationError):
        register_model(None, 'model name', 'project name')

    # All other errors should be bubbled up
    get_repository.side_effect = HTTPError(None, 404, None, None, None)
    with pytest.raises(HTTPError):
        register_model(None, 'model name', 'project name') 
開發者ID:sassoftware,項目名稱:python-sasctl,代碼行數:27,代碼來源:test_tasks.py

示例10: FetchDiscoveryDoc

# 需要導入模塊: from six.moves.urllib import error [as 別名]
# 或者: from six.moves.urllib.error import HTTPError [as 別名]
def FetchDiscoveryDoc(discovery_url, retries=5):
    """Fetch the discovery document at the given url."""
    discovery_urls = _NormalizeDiscoveryUrls(discovery_url)
    discovery_doc = None
    last_exception = None
    for url in discovery_urls:
        for _ in range(retries):
            try:
                content = _GetURLContent(url)
                if isinstance(content, bytes):
                    content = content.decode('utf8')
                discovery_doc = json.loads(content)
                if discovery_doc:
                    return discovery_doc
            except (urllib_error.HTTPError, urllib_error.URLError) as e:
                logging.info(
                    'Attempting to fetch discovery doc again after "%s"', e)
                last_exception = e
    if discovery_doc is None:
        raise CommunicationError(
            'Could not find discovery doc at any of %s: %s' % (
                discovery_urls, last_exception)) 
開發者ID:google,項目名稱:apitools,代碼行數:24,代碼來源:util.py

示例11: test_app_http_error_retry_ok

# 需要導入模塊: from six.moves.urllib import error [as 別名]
# 或者: from six.moves.urllib.error import HTTPError [as 別名]
def test_app_http_error_retry_ok(self, urlopen_mock):
        http_error = HTTPError(
            "http://mock.test",
            500,
            "HTTP 500 whatever",
            None,
            None
        )

        # this will make the function raise exception / return the value
        # in this given order
        side_effect_results = [
            http_error,
            http_error,
            open(TestEsiApp.ESI_META_SWAGGER)
        ]

        urlopen_mock.side_effect = side_effect_results
        with httmock.HTTMock(*_swagger_spec_mock_):
            EsiApp(cache_prefix='esipy_test')
            self.assertEqual(urlopen_mock.call_count, 3) 
開發者ID:Kyria,項目名稱:EsiPy,代碼行數:23,代碼來源:test_app.py

示例12: create_HTTPError

# 需要導入模塊: from six.moves.urllib import error [as 別名]
# 或者: from six.moves.urllib.error import HTTPError [as 別名]
def create_HTTPError(url=Undefined, code=Undefined, msg=Undefined,
            hdrs=Undefined, fp=None):
        """
        Test utility method constructing a HTTPError instance. Allows callers
        to construct a HTTPError instance using input data they are interested
        in, with some built-in default values used for any input data they are
        not interested in.

        """
        if url is Undefined:
            url = object()
        if code is Undefined:
            code = object()
        if msg is Undefined:
            msg = object()
        if hdrs is Undefined:
            hdrs = object()
        return HTTPError(url=url, code=code, msg=msg, hdrs=hdrs, fp=fp) 
開發者ID:suds-community,項目名稱:suds,代碼行數:20,代碼來源:test_transport_http.py

示例13: test_open_propagating_HTTPError_exceptions

# 需要導入模塊: from six.moves.urllib import error [as 別名]
# 或者: from six.moves.urllib.error import HTTPError [as 別名]
def test_open_propagating_HTTPError_exceptions(self, status_code,
            monkeypatch):
        """
        HttpTransport open() operation should transform HTTPError urlopener
        exceptions to suds.transport.TransportError exceptions.

        """
        # Setup.
        monkeypatch.delattr(locals(), "e", False)
        fp = MockFP()
        e_original = self.create_HTTPError(code=status_code, fp=fp)
        t = suds.transport.http.HttpTransport()
        t.urlopener = MockURLOpenerSaboteur(open_exception=e_original)
        request = create_request()

        # Execute.
        e = pytest.raises(suds.transport.TransportError, t.open, request).value
        try:
            # Verify.
            assert e.args == (str(e_original),)
            assert e.httpcode is status_code
            assert e.fp is fp
        finally:
            del e  # explicitly break circular reference chain in Python 3 
開發者ID:suds-community,項目名稱:suds,代碼行數:26,代碼來源:test_transport_http.py

示例14: test_operation_invoke_with_urlopen_accept_no_content__data

# 需要導入模塊: from six.moves.urllib import error [as 別名]
# 或者: from six.moves.urllib.error import HTTPError [as 別名]
def test_operation_invoke_with_urlopen_accept_no_content__data(self,
            status_code):
        """
        suds.client.Client web service operation invocation expecting output
        data, and for which a corresponding urlopen call raises a HTTPError
        with status code ACCEPTED or NO_CONTENT, should report this as a
        TransportError.

        """
        e = self.create_HTTPError(code=status_code)
        transport = suds.transport.http.HttpTransport()
        transport.urlopener = MockURLOpenerSaboteur(open_exception=e)
        wsdl = testutils.wsdl('<xsd:element name="o" type="xsd:string"/>',
            output="o", operation_name="f")
        client = testutils.client_from_wsdl(wsdl, transport=transport)
        pytest.raises(suds.transport.TransportError, client.service.f) 
開發者ID:suds-community,項目名稱:suds,代碼行數:18,代碼來源:test_transport_http.py

示例15: test_operation_invoke_with_urlopen_accept_no_content__no_data

# 需要導入模塊: from six.moves.urllib import error [as 別名]
# 或者: from six.moves.urllib.error import HTTPError [as 別名]
def test_operation_invoke_with_urlopen_accept_no_content__no_data(self,
            status_code):
        """
        suds.client.Client web service operation invocation expecting no output
        data, and for which a corresponding urlopen call raises a HTTPError
        with status code ACCEPTED or NO_CONTENT, should treat this as a
        successful invocation.

        """
        # We are not yet sure that the behaviour checked for in this test is
        # actually desired. The test is only an 'educated guess' prepared to
        # demonstrate a related problem in the original suds library
        # implementation. The original implementation is definitely buggy as
        # its web service operation invocation raises an AttributeError
        # exception by attempting to access a non-existing 'None.message'
        # attribute internally.
        e = self.create_HTTPError(code=status_code)
        transport = suds.transport.http.HttpTransport()
        transport.urlopener = MockURLOpenerSaboteur(open_exception=e)
        wsdl = testutils.wsdl('<xsd:element name="o" type="xsd:string"/>',
            output="o", operation_name="f")
        client = testutils.client_from_wsdl(wsdl, transport=transport)
        assert client.service.f() is None 
開發者ID:suds-community,項目名稱:suds,代碼行數:25,代碼來源:test_transport_http.py


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