refactored and added new tests for per-user, per-view, and per-resource htrottling

This commit is contained in:
markotibold 2011-06-11 20:21:24 +02:00
parent f854bc9065
commit 7bed352e97

View File

@ -8,78 +8,77 @@ from django.core.cache import cache
from djangorestframework.compat import RequestFactory from djangorestframework.compat import RequestFactory
from djangorestframework.views import View from djangorestframework.views import View
from djangorestframework.permissions import PerUserThrottling, PerResourceThrottling from djangorestframework.permissions import PerUserThrottling, PerViewThrottling, PerResourceThrottling, ConfigurationException
from djangorestframework.resources import FormResource
class MockView(View): class MockView(View):
permissions = ( PerUserThrottling, ) permissions = ( PerUserThrottling, )
throttle = (3, 1) # 3 requests per second throttle = '3/sec' # 3 requests per second
def get(self, request): def get(self, request):
return 'foo' return 'foo'
class MockView1(View): class MockView1(MockView):
permissions = ( PerViewThrottling, )
class MockView2(MockView):
permissions = ( PerResourceThrottling, ) permissions = ( PerResourceThrottling, )
throttle = (3, 1) # 3 requests per second #No resource set
def get(self, request): class MockView3(MockView2):
return 'foo' resource = FormResource
urlpatterns = patterns('',
(r'^$', MockView.as_view()),
(r'^1$', MockView1.as_view()),
)
class ThrottlingTests(TestCase): class ThrottlingTests(TestCase):
urls = 'djangorestframework.tests.throttling' urls = 'djangorestframework.tests.throttling'
def setUp(self): def setUp(self):
"""Reset the cache so that no throttles will be active""" """Reset the cache so that no throttles will be active"""
cache.clear() cache.clear()
self.factory = RequestFactory()
def test_requests_are_throttled(self): def test_requests_are_throttled(self):
"""Ensure request rate is limited""" """Ensure request rate is limited"""
for dummy in range(3): request = self.factory.get('/')
response = self.client.get('/') for dummy in range(4):
response = self.client.get('/') response = MockView.as_view()(request)
self.assertEqual(503, response.status_code)
def test_request_throttling_is_per_user(self):
"""Ensure request rate is only limited per user, not globally"""
for username in ('testuser', 'another_testuser'):
user = User.objects.create(username=username)
user.set_password('test')
user.save()
self.assertTrue(self.client.login(username='testuser', password='test'), msg='Login Failed')
for dummy in range(3):
response = self.client.get('/')
self.client.logout()
self.assertTrue(self.client.login(username='another_testuser', password='test'), msg='Login failed')
response = self.client.get('/')
self.assertEqual(200, response.status_code)
def test_request_throttling_is_per_resource(self):
"""Ensure request rate is limited globally per View"""
for username in ('testuser', 'another_testuser'):
user = User.objects.create(username=username)
user.set_password('test')
user.save()
self.assertTrue(self.client.login(username='testuser', password='test'), msg='Login Failed')
for dummy in range(3):
response = self.client.get('/1')
self.client.logout()
self.assertTrue(self.client.login(username='another_testuser', password='test'), msg='Login failed')
response = self.client.get('/1')
self.assertEqual(503, response.status_code) self.assertEqual(503, response.status_code)
def test_request_throttling_expires(self): def test_request_throttling_expires(self):
"""Ensure request rate is limited for a limited duration only""" """Ensure request rate is limited for a limited duration only"""
for dummy in range(3): request = self.factory.get('/')
response = self.client.get('/') for dummy in range(4):
response = self.client.get('/') response = MockView.as_view()(request)
self.assertEqual(503, response.status_code) self.assertEqual(503, response.status_code)
time.sleep(1) time.sleep(1)
response = self.client.get('/') response = MockView.as_view()(request)
self.assertEqual(200, response.status_code) self.assertEqual(200, response.status_code)
def ensure_is_throttled(self, view):
request = self.factory.get('/')
request.user = User.objects.create(username='a')
for dummy in range(3):
response = view.as_view()(request)
request.user = User.objects.create(username='b')
response = view.as_view()(request)
self.assertEqual(503, response.status_code)
def test_request_throttling_is_per_user(self):
"""Ensure request rate is only limited per user, not globally for PerUserTrottles"""
self.ensure_is_throttled(MockView)
def test_request_throttling_is_per_view(self):
"""Ensure request rate is limited globally per View for PerViewThrottles"""
self.ensure_is_throttled(MockView1)
def test_request_throttling_is_per_resource(self):
"""Ensure request rate is limited globally per Resource for PerResourceThrottles"""
self.ensure_is_throttled(MockView3)
def test_raises_no_resource_found(self):
"""Ensure an Exception is raised when someone sets at per-resource throttle
on a view with no resource set."""
request = self.factory.get('/')
view = MockView2.as_view()
self.assertRaises(ConfigurationException, view, request)