diff options
| author | GitHub Merge Button | 2011-07-11 12:33:31 -0700 |
|---|---|---|
| committer | GitHub Merge Button | 2011-07-11 12:33:31 -0700 |
| commit | 7f0b291528061accf921e58253fd38b018d427ca (patch) | |
| tree | b28bfb1cea09f7bc2851a4fc2d28ee4a60a50859 /djangorestframework/tests/modelviews.py | |
| parent | e4ce57b88cdcb3a0e642d05a74b392c3303929fc (diff) | |
| parent | 8a2944acdf66a966f0bd4ea4770f012f2597fb4e (diff) | |
| download | django-rest-framework-7f0b291528061accf921e58253fd38b018d427ca.tar.bz2 | |
Merge 8a2944acdf66a966f0bd4ea4770f012f2597fb4e into e4ce57b88cdcb3a0e642d05a74b392c3303929fc
Diffstat (limited to 'djangorestframework/tests/modelviews.py')
| -rw-r--r-- | djangorestframework/tests/modelviews.py | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/djangorestframework/tests/modelviews.py b/djangorestframework/tests/modelviews.py new file mode 100644 index 00000000..14be178e --- /dev/null +++ b/djangorestframework/tests/modelviews.py @@ -0,0 +1,59 @@ +from django.conf.urls.defaults import patterns, url +from django.test import TestCase +from django.forms import ModelForm +from django.contrib.auth.models import Group, User +from djangorestframework.resources import ModelResource +from djangorestframework.views import ListOrCreateModelView, InstanceModelView + +class GroupResource(ModelResource): + model = Group + +class UserForm(ModelForm): + class Meta: + model = User + exclude = ('last_login', 'date_joined') + +class UserResource(ModelResource): + model = User + form = UserForm + +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'^groups/$', ListOrCreateModelView.as_view(resource=GroupResource), name='groups'), + url(r'^groups/(?P<id>[0-9]+)/$', InstanceModelView.as_view(resource=GroupResource)), +) + + +class ModelViewTests(TestCase): + """Test the model views djangorestframework provides""" + urls = 'djangorestframework.tests.modelviews' + + def test_creation(self): + """Ensure that a model object can be created""" + self.assertEqual(0, Group.objects.count()) + + response = self.client.post('/groups/', {'name': 'foo'}) + + self.assertEqual(response.status_code, 201) + self.assertEqual(1, Group.objects.count()) + self.assertEqual('foo', Group.objects.all()[0].name) + + def test_creation_with_m2m_relation(self): + """Ensure that a model object with a m2m relation can be created""" + group = Group(name='foo') + group.save() + self.assertEqual(0, User.objects.count()) + + response = self.client.post('/users/', {'username': 'bar', 'password': 'baz', 'groups': [group.id]}) + + self.assertEqual(response.status_code, 201) + self.assertEqual(1, User.objects.count()) + + user = User.objects.all()[0] + self.assertEqual('bar', user.username) + self.assertEqual('baz', user.password) + self.assertEqual(1, user.groups.count()) + + group = user.groups.all()[0] + self.assertEqual('foo', group.name) |
