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


Python exceptions.ErrorDetail方法代碼示例

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


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

示例1: test_token_view

# 需要導入模塊: from rest_framework import exceptions [as 別名]
# 或者: from rest_framework.exceptions import ErrorDetail [as 別名]
def test_token_view(self):
        random_address = Account.create().address
        response = self.client.get(reverse('v1:token', args=(random_address,)))
        self.assertEqual(response.status_code, status.HTTP_404_NOT_FOUND)
        self.assertEqual(response.data, {'detail': ErrorDetail(string='Not found.', code='not_found')})

        token = TokenFactory(address=random_address)
        response = self.client.get(reverse('v1:token', args=(random_address,)))
        self.assertEqual(response.status_code, status.HTTP_200_OK)
        self.assertEqual(response.data, {'address': token.address,
                                         'logo_uri': token.get_full_logo_uri(),
                                         'default': token.gas,
                                         'name': token.name,
                                         'symbol': token.symbol,
                                         'description': token.description,
                                         'decimals': token.decimals,
                                         'website_uri': token.website_uri,
                                         'gas': token.gas}) 
開發者ID:gnosis,項目名稱:safe-relay-service,代碼行數:20,代碼來源:test_views.py

示例2: render

# 需要導入模塊: from rest_framework import exceptions [as 別名]
# 或者: from rest_framework.exceptions import ErrorDetail [as 別名]
def render(self, data, accepted_media_type=None, renderer_context=None):

        # data should be str, but in case it's a dict, return as XML.
        # e.g. It happens with 404
        if isinstance(data, dict):
            # Force cast `ErrorDetail` as `six.text_type` because `dicttoxml`
            # does not recognize this type and treat each character as xml node.
            for k, v in data.items():
                if isinstance(v, ErrorDetail):
                    data[k] = str(v)

            # FIXME new `v2` list endpoint enters this block
            # Submissions are wrapped in `<item>` nodes.
            return dicttoxml(data, attr_type=False)

        if renderer_context.get("view").action == "list":
            return "<root>{}</root>".format("".join(data))
        else:
            return data 
開發者ID:kobotoolbox,項目名稱:kpi,代碼行數:21,代碼來源:renderers.py

示例3: validate_user_password_confirm

# 需要導入模塊: from rest_framework import exceptions [as 別名]
# 或者: from rest_framework.exceptions import ErrorDetail [as 別名]
def validate_user_password_confirm(user_data: Dict[str, Any]) -> None:
    if user_data['password'] != user_data['password_confirm']:
        raise ValidationError(ErrorDetail(
            _("Passwords don't match"),
            code='passwords-do-not-match'),
        ) 
開發者ID:apragacz,項目名稱:django-rest-registration,代碼行數:8,代碼來源:validation.py

示例4: __init__

# 需要導入模塊: from rest_framework import exceptions [as 別名]
# 或者: from rest_framework.exceptions import ErrorDetail [as 別名]
def __init__(self, detail=None, code=None):
        if detail is None:
            detail = self.default_detail
        if code is None:
            code = self.default_code
        self.detail = ErrorDetail(detail, code) 
開發者ID:anyant,項目名稱:rssant,代碼行數:8,代碼來源:errors.py

示例5: test_update_wrong_data_sent

# 需要導入模塊: from rest_framework import exceptions [as 別名]
# 或者: from rest_framework.exceptions import ErrorDetail [as 別名]
def test_update_wrong_data_sent(self):
        data = {
            "active": "wrong",
            "webradio": 12,
        }
        response = self.client.post(self.url, data, format='json')
        expected = {'active': [ErrorDetail(string='Must be a valid boolean.', code='invalid')],
                    'webradio': [ErrorDetail(string='Invalid pk "12" - object does not exist.', code='does_not_exist')]}
        self.assertEquals(expected, response.data)
        self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST) 
開發者ID:Sispheor,項目名稱:piclodio3,代碼行數:12,代碼來源:test_update.py

示例6: test_update_web_radio_do_not_exist

# 需要導入模塊: from rest_framework import exceptions [as 別名]
# 或者: from rest_framework.exceptions import ErrorDetail [as 別名]
def test_update_web_radio_do_not_exist(self):
        data = {
            "active": True,
            "webradio": 12,
        }
        response = self.client.post(self.url, data, format='json')
        expected = {'webradio': [ErrorDetail(string='Invalid pk "12" - object does not exist.', code='does_not_exist')]}
        self.assertEquals(expected, response.data)
        self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST) 
開發者ID:Sispheor,項目名稱:piclodio3,代碼行數:11,代碼來源:test_update.py

示例7: test_set_volume_invalid

# 需要導入模塊: from rest_framework import exceptions [as 別名]
# 或者: from rest_framework.exceptions import ErrorDetail [as 別名]
def test_set_volume_invalid(self):
        data = {
            "volume": 200
        }
        response = self.client.post(self.url, data, format='json')
        expected = {'volume':
                        [ErrorDetail(string='Ensure this value is less than or equal to 100.',
                                     code='max_value')]}
        self.assertEquals(expected, response.data)
        self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST) 
開發者ID:Sispheor,項目名稱:piclodio3,代碼行數:12,代碼來源:test_update.py

示例8: errors

# 需要導入模塊: from rest_framework import exceptions [as 別名]
# 或者: from rest_framework.exceptions import ErrorDetail [as 別名]
def errors(self):
        ret = super(Serializer, self).errors
        if isinstance(ret, list) and len(ret) == 1 and getattr(ret[0], 'code', None) == 'null':
            # Edge case. Provide a more descriptive error than
            # "this field may not be null", when no data is passed.
            detail = ErrorDetail('No data provided', code='null')
            ret = {api_settings.NON_FIELD_ERRORS_KEY: [detail]}
        return ReturnDict(ret, serializer=self)


# There's some replication of `ListField` here,
# but that's probably better than obfuscating the call hierarchy. 
開發者ID:BeanWei,項目名稱:Dailyfresh-B2C,代碼行數:14,代碼來源:serializers.py

示例9: get_error_detail

# 需要導入模塊: from rest_framework import exceptions [as 別名]
# 或者: from rest_framework.exceptions import ErrorDetail [as 別名]
def get_error_detail(exc_info):
    """
    Given a Django ValidationError, return a list of ErrorDetail,
    with the `code` populated.
    """
    code = getattr(exc_info, 'code', None) or 'invalid'
    return [
        ErrorDetail(msg, code=code)
        for msg in exc_info.messages
    ] 
開發者ID:BeanWei,項目名稱:Dailyfresh-B2C,代碼行數:12,代碼來源:fields.py

示例10: __init__

# 需要導入模塊: from rest_framework import exceptions [as 別名]
# 或者: from rest_framework.exceptions import ErrorDetail [as 別名]
def __init__(self, detail=None, code=None, reinit=True):
        message = detail if detail is not None else self.default_detail
        self.code = code if code is not None else self.default_code
        self.detail = {
            'detail': exceptions.ErrorDetail(message, self.default_code),
            'reinit': reinit,
        } 
開發者ID:PeteAndersen,項目名稱:swarfarm,代碼行數:9,代碼來源:views.py

示例11: _get_list_of_errors

# 需要導入模塊: from rest_framework import exceptions [as 別名]
# 或者: from rest_framework.exceptions import ErrorDetail [as 別名]
def _get_list_of_errors(self, field_path='', errors_dict=None):
        """
        Error_dict is in the following format:
        {
            'field1': {
                'message': 'some message..'
                'code' 'some code...'
            },
            'field2: ...'
        }
        """
        if errors_dict is None:
            return []

        message_value = errors_dict.get(self.MESSAGE, None)

        # Note: If 'message' is name of a field we don't want to stop the recursion here!
        if message_value is not None and\
           (type(message_value) in {str, exceptions.ErrorDetail}):
            if field_path:
                errors_dict[self.FIELD] = field_path
            return [errors_dict]

        errors_list = []
        for key, value in errors_dict.items():
            new_field_path = '{0}.{1}'.format(field_path, key) if field_path else key
            key_is_non_field_errors = key == api_settings.NON_FIELD_ERRORS_KEY

            if type(value) is list:
                current_level_error_list = []
                new_value = value

                for error in new_value:
                    # if the type of field_error is list we need to unpack it
                    field_error = self._unpack(error)

                    if not key_is_non_field_errors:
                        field_error[self.FIELD] = new_field_path

                    current_level_error_list.append(field_error)
            else:
                path = field_path if key_is_non_field_errors else new_field_path

                current_level_error_list = self._get_list_of_errors(field_path=path, errors_dict=value)

            errors_list += current_level_error_list

        return errors_list 
開發者ID:HackSoftware,項目名稱:Django-Styleguide,代碼行數:50,代碼來源:utils.py


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