Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
D
django-rest-framework
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
edx
django-rest-framework
Commits
92fe7560
Commit
92fe7560
authored
Jan 17, 2014
by
Tom Christie
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1360 from diox/fix-querysets-json-encoding
Encode django QuerySets to lists and not dicts in JSONEncoder
parents
71c03b9d
f034cb59
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
22 additions
and
0 deletions
+22
-0
rest_framework/tests/test_renderers.py
+19
-0
rest_framework/utils/encoders.py
+3
-0
No files found.
rest_framework/tests/test_renderers.py
View file @
92fe7560
...
...
@@ -3,6 +3,7 @@ from __future__ import unicode_literals
from
decimal
import
Decimal
from
django.core.cache
import
cache
from
django.db
import
models
from
django.test
import
TestCase
from
django.utils
import
unittest
from
django.utils.translation
import
ugettext_lazy
as
_
...
...
@@ -34,6 +35,10 @@ expected_results = [
]
class
DummyTestModel
(
models
.
Model
):
name
=
models
.
CharField
(
max_length
=
42
,
default
=
''
)
class
BasicRendererTests
(
TestCase
):
def
test_expected_results
(
self
):
for
value
,
renderer_cls
,
expected
in
expected_results
:
...
...
@@ -276,6 +281,20 @@ class JSONRendererTests(TestCase):
ret
=
JSONRenderer
()
.
render
(
_
(
'test'
))
self
.
assertEqual
(
ret
,
b
'"test"'
)
def
test_render_queryset_values
(
self
):
o
=
DummyTestModel
.
objects
.
create
(
name
=
'dummy'
)
qs
=
DummyTestModel
.
objects
.
values
(
'id'
,
'name'
)
ret
=
JSONRenderer
()
.
render
(
qs
)
data
=
json
.
loads
(
ret
.
decode
(
'utf-8'
))
self
.
assertEquals
(
data
,
[{
'id'
:
o
.
id
,
'name'
:
o
.
name
}])
def
test_render_queryset_values_list
(
self
):
o
=
DummyTestModel
.
objects
.
create
(
name
=
'dummy'
)
qs
=
DummyTestModel
.
objects
.
values_list
(
'id'
,
'name'
)
ret
=
JSONRenderer
()
.
render
(
qs
)
data
=
json
.
loads
(
ret
.
decode
(
'utf-8'
))
self
.
assertEquals
(
data
,
[[
o
.
id
,
o
.
name
]])
def
test_render_dict_abc_obj
(
self
):
class
Dict
(
MutableMapping
):
def
__init__
(
self
):
...
...
rest_framework/utils/encoders.py
View file @
92fe7560
...
...
@@ -2,6 +2,7 @@
Helper classes for parsers.
"""
from
__future__
import
unicode_literals
from
django.db.models.query
import
QuerySet
from
django.utils.datastructures
import
SortedDict
from
django.utils.functional
import
Promise
from
rest_framework.compat
import
timezone
,
force_text
...
...
@@ -42,6 +43,8 @@ class JSONEncoder(json.JSONEncoder):
return
str
(
o
.
total_seconds
())
elif
isinstance
(
o
,
decimal
.
Decimal
):
return
str
(
o
)
elif
isinstance
(
o
,
QuerySet
):
return
list
(
o
)
elif
hasattr
(
o
,
'tolist'
):
return
o
.
tolist
()
elif
hasattr
(
o
,
'__getitem__'
):
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment