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
d0b3b647
Commit
d0b3b647
authored
Oct 11, 2016
by
Tom Christie
Committed by
GitHub
Oct 11, 2016
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix prefetch_related updates. (#4553)
parent
aed4ed5e
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
48 additions
and
0 deletions
+48
-0
rest_framework/mixins.py
+7
-0
tests/test_prefetch_related.py
+41
-0
No files found.
rest_framework/mixins.py
View file @
d0b3b647
...
@@ -68,6 +68,13 @@ class UpdateModelMixin(object):
...
@@ -68,6 +68,13 @@ class UpdateModelMixin(object):
serializer
=
self
.
get_serializer
(
instance
,
data
=
request
.
data
,
partial
=
partial
)
serializer
=
self
.
get_serializer
(
instance
,
data
=
request
.
data
,
partial
=
partial
)
serializer
.
is_valid
(
raise_exception
=
True
)
serializer
.
is_valid
(
raise_exception
=
True
)
self
.
perform_update
(
serializer
)
self
.
perform_update
(
serializer
)
if
getattr
(
instance
,
'_prefetched_objects_cache'
,
None
):
# If 'prefetch_related' has been applied to a queryset, we need to
# refresh the instance from the database.
instance
=
self
.
get_object
()
serializer
=
self
.
get_serializer
(
instance
)
return
Response
(
serializer
.
data
)
return
Response
(
serializer
.
data
)
def
perform_update
(
self
,
serializer
):
def
perform_update
(
self
,
serializer
):
...
...
tests/test_prefetch_related.py
0 → 100644
View file @
d0b3b647
from
django.contrib.auth.models
import
Group
,
User
from
django.test
import
TestCase
from
rest_framework
import
generics
,
serializers
from
rest_framework.test
import
APIRequestFactory
factory
=
APIRequestFactory
()
class
UserSerializer
(
serializers
.
ModelSerializer
):
class
Meta
:
model
=
User
fields
=
(
'id'
,
'username'
,
'email'
,
'groups'
)
class
UserUpdate
(
generics
.
UpdateAPIView
):
queryset
=
User
.
objects
.
all
()
.
prefetch_related
(
'groups'
)
serializer_class
=
UserSerializer
class
TestPrefetchRelatedUpdates
(
TestCase
):
def
setUp
(
self
):
self
.
user
=
User
.
objects
.
create
(
username
=
'tom'
,
email
=
'tom@example.com'
)
self
.
groups
=
[
Group
.
objects
.
create
(
name
=
'a'
),
Group
.
objects
.
create
(
name
=
'b'
)]
self
.
user
.
groups
=
self
.
groups
self
.
user
.
save
()
def
test_prefetch_related_updates
(
self
):
view
=
UserUpdate
.
as_view
()
pk
=
self
.
user
.
pk
groups_pk
=
self
.
groups
[
0
]
.
pk
request
=
factory
.
put
(
'/'
,
{
'username'
:
'new'
,
'groups'
:
[
groups_pk
]},
format
=
'json'
)
response
=
view
(
request
,
pk
=
pk
)
assert
User
.
objects
.
get
(
pk
=
pk
)
.
groups
.
count
()
==
1
expected
=
{
'id'
:
pk
,
'username'
:
'new'
,
'groups'
:
[
1
],
'email'
:
'tom@example.com'
}
assert
response
.
data
==
expected
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