aboutsummaryrefslogtreecommitdiffstats
path: root/djangorestframework/tests/modelviews.py
diff options
context:
space:
mode:
authorGitHub Merge Button2011-07-11 12:33:49 -0700
committerGitHub Merge Button2011-07-11 12:33:49 -0700
commit2b909062937c37134effc38cf9b98b6ad49f72e9 (patch)
tree4c3a7cddbc099fe6ea65424a9595b87104b55967 /djangorestframework/tests/modelviews.py
parent5433cb3e27058c2f7da6118ffa9ee7712846048d (diff)
parent91b9d0b2a3fa55ff163f64bc689a59ca01cff8bb (diff)
downloaddjango-rest-framework-2b909062937c37134effc38cf9b98b6ad49f72e9.tar.bz2
Merge 91b9d0b2a3fa55ff163f64bc689a59ca01cff8bb into 5433cb3e27058c2f7da6118ffa9ee7712846048d
Diffstat (limited to 'djangorestframework/tests/modelviews.py')
-rw-r--r--djangorestframework/tests/modelviews.py27
1 files changed, 27 insertions, 0 deletions
diff --git a/djangorestframework/tests/modelviews.py b/djangorestframework/tests/modelviews.py
index 14be178e..2fd1878a 100644
--- a/djangorestframework/tests/modelviews.py
+++ b/djangorestframework/tests/modelviews.py
@@ -4,6 +4,7 @@ from django.forms import ModelForm
from django.contrib.auth.models import Group, User
from djangorestframework.resources import ModelResource
from djangorestframework.views import ListOrCreateModelView, InstanceModelView
+from djangorestframework.tests.models import CustomUser
class GroupResource(ModelResource):
model = Group
@@ -16,10 +17,15 @@ class UserForm(ModelForm):
class UserResource(ModelResource):
model = User
form = UserForm
+
+class CustomUserResource(ModelResource):
+ model = CustomUser
urlpatterns = patterns('',
url(r'^users/$', ListOrCreateModelView.as_view(resource=UserResource), name='users'),
url(r'^users/(?P<id>[0-9]+)/$', InstanceModelView.as_view(resource=UserResource)),
+ url(r'^customusers/$', ListOrCreateModelView.as_view(resource=CustomUserResource), name='customusers'),
+ url(r'^customusers/(?P<id>[0-9]+)/$', InstanceModelView.as_view(resource=CustomUserResource)),
url(r'^groups/$', ListOrCreateModelView.as_view(resource=GroupResource), name='groups'),
url(r'^groups/(?P<id>[0-9]+)/$', InstanceModelView.as_view(resource=GroupResource)),
)
@@ -57,3 +63,24 @@ class ModelViewTests(TestCase):
group = user.groups.all()[0]
self.assertEqual('foo', group.name)
+
+ def test_creation_with_m2m_relation_through(self):
+ """
+ Ensure that a model object with a m2m relation can be created where that
+ relation uses a through table
+ """
+ group = Group(name='foo')
+ group.save()
+ self.assertEqual(0, User.objects.count())
+
+ response = self.client.post('/customusers/', {'username': 'bar', 'groups': [group.id]})
+
+ self.assertEqual(response.status_code, 201)
+ self.assertEqual(1, CustomUser.objects.count())
+
+ user = CustomUser.objects.all()[0]
+ self.assertEqual('bar', user.username)
+ self.assertEqual(1, user.groups.count())
+
+ group = user.groups.all()[0]
+ self.assertEqual('foo', group.name)