diff options
| author | Tom Christie | 2015-02-27 09:13:01 +0000 | 
|---|---|---|
| committer | Tom Christie | 2015-02-27 09:13:01 +0000 | 
| commit | cda74b59971f85da873b0e15da8b4afb4411a026 (patch) | |
| tree | 8981ad8adf5b2f16e6771be3790952bd51ab61fc /rest_framework | |
| parent | c66f23391ac669f2a9a27431e66588e9092300f2 (diff) | |
| parent | e6b06c34c1ee526b65c92b9071c47be2ddc668c4 (diff) | |
| download | django-rest-framework-cda74b59971f85da873b0e15da8b4afb4411a026.tar.bz2 | |
Merge pull request #2608 from ezheidtmann/dont-swallow-errors-in-callable-sources
Dont swallow errors in callable sources
Diffstat (limited to 'rest_framework')
| -rw-r--r-- | rest_framework/fields.py | 9 | 
1 files changed, 8 insertions, 1 deletions
| diff --git a/rest_framework/fields.py b/rest_framework/fields.py index 13ea6dde..c0f93816 100644 --- a/rest_framework/fields.py +++ b/rest_framework/fields.py @@ -71,7 +71,14 @@ def get_attribute(instance, attrs):          except ObjectDoesNotExist:              return None          if is_simple_callable(instance): -            instance = instance() +            try: +                instance = instance() +            except (AttributeError, KeyError) as exc: +                # If we raised an Attribute or KeyError here it'd get treated +                # as an omitted field in `Field.get_attribute()`. Instead we +                # raise a ValueError to ensure the exception is not masked. +                raise ValueError('Exception raised in callable attribute "{0}"; original exception was: {1}'.format(attr, exc)) +      return instance | 
