aboutsummaryrefslogtreecommitdiffstats
path: root/djangorestframework/tests
diff options
context:
space:
mode:
authorGitHub Merge Button2011-07-08 14:59:57 -0700
committerGitHub Merge Button2011-07-08 14:59:57 -0700
commit3a4f39497be899218ad8d3638bbee38f455782c5 (patch)
treeebbe6a68174746a1e15727c5ef92d0e685b068f8 /djangorestframework/tests
parent3b2e70dd3a3bbac0fb5318329483b4a4eb20410a (diff)
parent91b9d0b2a3fa55ff163f64bc689a59ca01cff8bb (diff)
downloaddjango-rest-framework-3a4f39497be899218ad8d3638bbee38f455782c5.tar.bz2
Merge 91b9d0b2a3fa55ff163f64bc689a59ca01cff8bb into 3b2e70dd3a3bbac0fb5318329483b4a4eb20410a
Diffstat (limited to 'djangorestframework/tests')
-rw-r--r--djangorestframework/tests/mixins.py113
-rw-r--r--djangorestframework/tests/models.py28
-rw-r--r--djangorestframework/tests/modelviews.py86
3 files changed, 227 insertions, 0 deletions
diff --git a/djangorestframework/tests/mixins.py b/djangorestframework/tests/mixins.py
new file mode 100644
index 00000000..b9aa4c3b
--- /dev/null
+++ b/djangorestframework/tests/mixins.py
@@ -0,0 +1,113 @@
+"""Tests for the status module"""
+from django.test import TestCase
+from djangorestframework import status
+from djangorestframework.compat import RequestFactory
+from django.contrib.auth.models import Group, User
+from djangorestframework.mixins import CreateModelMixin
+from djangorestframework.resources import ModelResource
+from djangorestframework.tests.models import CustomUser
+
+
+class TestModelCreation(TestCase):
+ """Tests on CreateModelMixin"""
+
+ def setUp(self):
+ self.req = RequestFactory()
+
+ def test_creation(self):
+ self.assertEquals(0, Group.objects.count())
+
+ class GroupResource(ModelResource):
+ model = Group
+
+ form_data = {'name': 'foo'}
+ request = self.req.post('/groups', data=form_data)
+ mixin = CreateModelMixin()
+ mixin.resource = GroupResource
+ mixin.CONTENT = form_data
+
+ response = mixin.post(request)
+ self.assertEquals(1, Group.objects.count())
+ self.assertEquals('foo', response.cleaned_content.name)
+
+
+ def test_creation_with_m2m_relation(self):
+ class UserResource(ModelResource):
+ model = User
+
+ def url(self, instance):
+ return "/users/%i" % instance.id
+
+ group = Group(name='foo')
+ group.save()
+
+ form_data = {'username': 'bar', 'password': 'baz', 'groups': [group.id]}
+ request = self.req.post('/groups', data=form_data)
+ cleaned_data = dict(form_data)
+ cleaned_data['groups'] = [group]
+ mixin = CreateModelMixin()
+ mixin.resource = UserResource
+ mixin.CONTENT = cleaned_data
+
+ response = mixin.post(request)
+ self.assertEquals(1, User.objects.count())
+ self.assertEquals(1, response.cleaned_content.groups.count())
+ self.assertEquals('foo', response.cleaned_content.groups.all()[0].name)
+
+ def test_creation_with_m2m_relation_through(self):
+ """
+ Tests creation where the m2m relation uses a through table
+ """
+ class UserResource(ModelResource):
+ model = CustomUser
+
+ def url(self, instance):
+ return "/customusers/%i" % instance.id
+
+ form_data = {'username': 'bar0', 'groups': []}
+ request = self.req.post('/groups', data=form_data)
+ cleaned_data = dict(form_data)
+ cleaned_data['groups'] = []
+ mixin = CreateModelMixin()
+ mixin.resource = UserResource
+ mixin.CONTENT = cleaned_data
+
+ response = mixin.post(request)
+ self.assertEquals(1, CustomUser.objects.count())
+ self.assertEquals(0, response.cleaned_content.groups.count())
+
+ group = Group(name='foo1')
+ group.save()
+
+ form_data = {'username': 'bar1', 'groups': [group.id]}
+ request = self.req.post('/groups', data=form_data)
+ cleaned_data = dict(form_data)
+ cleaned_data['groups'] = [group]
+ mixin = CreateModelMixin()
+ mixin.resource = UserResource
+ mixin.CONTENT = cleaned_data
+
+ response = mixin.post(request)
+ self.assertEquals(2, CustomUser.objects.count())
+ self.assertEquals(1, response.cleaned_content.groups.count())
+ self.assertEquals('foo1', response.cleaned_content.groups.all()[0].name)
+
+
+ group2 = Group(name='foo2')
+ group2.save()
+
+ form_data = {'username': 'bar2', 'groups': [group.id, group2.id]}
+ request = self.req.post('/groups', data=form_data)
+ cleaned_data = dict(form_data)
+ cleaned_data['groups'] = [group, group2]
+ mixin = CreateModelMixin()
+ mixin.resource = UserResource
+ mixin.CONTENT = cleaned_data
+
+ response = mixin.post(request)
+ self.assertEquals(3, CustomUser.objects.count())
+ self.assertEquals(2, response.cleaned_content.groups.count())
+ self.assertEquals('foo', response.cleaned_content.groups.all()[0].name)
+ self.assertEquals('foo2', response.cleaned_content.groups.all()[1].name)
+
+
diff --git a/djangorestframework/tests/models.py b/djangorestframework/tests/models.py
new file mode 100644
index 00000000..61da1d45
--- /dev/null
+++ b/djangorestframework/tests/models.py
@@ -0,0 +1,28 @@
+from django.db import models
+from django.contrib.auth.models import Group
+
+class CustomUser(models.Model):
+ """
+ A custom user model, which uses a 'through' table for the foreign key
+ """
+ username = models.CharField(max_length=255, unique=True)
+ groups = models.ManyToManyField(
+ to=Group, blank=True, null=True, through='UserGroupMap'
+ )
+
+ @models.permalink
+ def get_absolute_url(self):
+ return ('custom_user', (), {
+ 'pk': self.id
+ })
+
+
+class UserGroupMap(models.Model):
+ user = models.ForeignKey(to=CustomUser)
+ group = models.ForeignKey(to=Group)
+
+ @models.permalink
+ def get_absolute_url(self):
+ return ('user_group_map', (), {
+ 'pk': self.id
+ }) \ No newline at end of file
diff --git a/djangorestframework/tests/modelviews.py b/djangorestframework/tests/modelviews.py
new file mode 100644
index 00000000..2fd1878a
--- /dev/null
+++ b/djangorestframework/tests/modelviews.py
@@ -0,0 +1,86 @@
+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
+from djangorestframework.tests.models import CustomUser
+
+class GroupResource(ModelResource):
+ model = Group
+
+class UserForm(ModelForm):
+ class Meta:
+ model = User
+ exclude = ('last_login', 'date_joined')
+
+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)),
+)
+
+
+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)
+
+ 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)