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
2394f05e
Commit
2394f05e
authored
Oct 17, 2013
by
Tom Christie
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1170 from craigds/write-into-foreignkey-with-source
fix writing into foreign key with non-null source
parents
6a40202a
86ea969e
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
68 additions
and
1 deletions
+68
-1
rest_framework/serializers.py
+1
-1
rest_framework/tests/test_serializer_nested.py
+67
-0
No files found.
rest_framework/serializers.py
View file @
2394f05e
...
...
@@ -406,7 +406,7 @@ class BaseSerializer(WritableField):
return
# Set the serializer object if it exists
obj
=
get
attr
(
self
.
parent
.
object
,
field_name
)
if
self
.
parent
.
object
else
None
obj
=
get
_component
(
self
.
parent
.
object
,
self
.
source
or
field_name
)
if
self
.
parent
.
object
else
None
obj
=
obj
.
all
()
if
is_simple_callable
(
getattr
(
obj
,
'all'
,
None
))
else
obj
if
self
.
source
==
'*'
:
...
...
rest_framework/tests/test_serializer_nested.py
View file @
2394f05e
...
...
@@ -244,3 +244,70 @@ class WritableNestedSerializerObjectTests(TestCase):
serializer
=
self
.
AlbumSerializer
(
data
=
data
,
many
=
True
)
self
.
assertEqual
(
serializer
.
is_valid
(),
True
)
self
.
assertEqual
(
serializer
.
object
,
expected_object
)
class
ForeignKeyNestedSerializerUpdateTests
(
TestCase
):
def
setUp
(
self
):
class
Artist
(
object
):
def
__init__
(
self
,
name
):
self
.
name
=
name
def
__eq__
(
self
,
other
):
return
self
.
name
==
other
.
name
class
Album
(
object
):
def
__init__
(
self
,
name
,
artist
):
self
.
name
,
self
.
artist
=
name
,
artist
def
__eq__
(
self
,
other
):
return
self
.
name
==
other
.
name
and
self
.
artist
==
other
.
artist
class
ArtistSerializer
(
serializers
.
Serializer
):
name
=
serializers
.
CharField
()
def
restore_object
(
self
,
attrs
,
instance
=
None
):
if
instance
:
instance
.
name
=
attrs
[
'name'
]
else
:
instance
=
Artist
(
attrs
[
'name'
])
return
instance
class
AlbumSerializer
(
serializers
.
Serializer
):
name
=
serializers
.
CharField
()
by
=
ArtistSerializer
(
source
=
'artist'
)
def
restore_object
(
self
,
attrs
,
instance
=
None
):
if
instance
:
instance
.
name
=
attrs
[
'name'
]
instance
.
artist
=
attrs
[
'artist'
]
else
:
instance
=
Album
(
attrs
[
'name'
],
attrs
[
'artist'
])
return
instance
self
.
Artist
=
Artist
self
.
Album
=
Album
self
.
AlbumSerializer
=
AlbumSerializer
def
test_create_via_foreign_key_with_source
(
self
):
"""
Check that we can both *create* and *update* into objects across
ForeignKeys that have a `source` specified.
Regression test for #1170
"""
data
=
{
'name'
:
'Discovery'
,
'by'
:
{
'name'
:
'Daft Punk'
},
}
expected
=
self
.
Album
(
artist
=
self
.
Artist
(
'Daft Punk'
),
name
=
'Discovery'
)
# create
serializer
=
self
.
AlbumSerializer
(
data
=
data
)
self
.
assertEqual
(
serializer
.
is_valid
(),
True
)
self
.
assertEqual
(
serializer
.
object
,
expected
)
# update
original
=
self
.
Album
(
artist
=
self
.
Artist
(
'The Bats'
),
name
=
'Free All the Monsters'
)
serializer
=
self
.
AlbumSerializer
(
instance
=
original
,
data
=
data
)
self
.
assertEqual
(
serializer
.
is_valid
(),
True
)
self
.
assertEqual
(
serializer
.
object
,
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