Prevented the generic views from automatically creating a HEAD method when there is no GET. Reverts r16105, refs #17449.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@17545 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
8d221e554c
commit
52b06e29c7
|
@ -43,6 +43,8 @@ class View(object):
|
||||||
|
|
||||||
def view(request, *args, **kwargs):
|
def view(request, *args, **kwargs):
|
||||||
self = cls(**initkwargs)
|
self = cls(**initkwargs)
|
||||||
|
if hasattr(self, 'get') and not hasattr(self, 'head'):
|
||||||
|
self.head = self.get
|
||||||
return self.dispatch(request, *args, **kwargs)
|
return self.dispatch(request, *args, **kwargs)
|
||||||
|
|
||||||
# take name and docstring from class
|
# take name and docstring from class
|
||||||
|
@ -76,9 +78,6 @@ class View(object):
|
||||||
)
|
)
|
||||||
return http.HttpResponseNotAllowed(allowed_methods)
|
return http.HttpResponseNotAllowed(allowed_methods)
|
||||||
|
|
||||||
def head(self, *args, **kwargs):
|
|
||||||
return self.get(*args, **kwargs)
|
|
||||||
|
|
||||||
|
|
||||||
class TemplateResponseMixin(object):
|
class TemplateResponseMixin(object):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -19,9 +19,15 @@ class SimplePostView(SimpleView):
|
||||||
post = SimpleView.get
|
post = SimpleView.get
|
||||||
|
|
||||||
|
|
||||||
|
class PostOnlyView(View):
|
||||||
|
def post(self, request):
|
||||||
|
return HttpResponse('This view only accepts POST')
|
||||||
|
|
||||||
|
|
||||||
class CustomizableView(SimpleView):
|
class CustomizableView(SimpleView):
|
||||||
parameter = {}
|
parameter = {}
|
||||||
|
|
||||||
|
|
||||||
def decorator(view):
|
def decorator(view):
|
||||||
view.is_decorated = True
|
view.is_decorated = True
|
||||||
return view
|
return view
|
||||||
|
@ -102,12 +108,19 @@ class ViewTest(unittest.TestCase):
|
||||||
|
|
||||||
def test_get_and_head(self):
|
def test_get_and_head(self):
|
||||||
"""
|
"""
|
||||||
Test a view which supplies a GET method also responds correctly to HEAD
|
Test a view which supplies a GET method also responds correctly to HEAD.
|
||||||
"""
|
"""
|
||||||
self._assert_simple(SimpleView.as_view()(self.rf.get('/')))
|
self._assert_simple(SimpleView.as_view()(self.rf.get('/')))
|
||||||
response = SimpleView.as_view()(self.rf.head('/'))
|
response = SimpleView.as_view()(self.rf.head('/'))
|
||||||
self.assertEqual(response.status_code, 200)
|
self.assertEqual(response.status_code, 200)
|
||||||
|
|
||||||
|
def test_head_no_get(self):
|
||||||
|
"""
|
||||||
|
Test a view which supplies no GET method responds to HEAD with HTTP 405.
|
||||||
|
"""
|
||||||
|
response = PostOnlyView.as_view()(self.rf.head('/'))
|
||||||
|
self.assertEqual(response.status_code, 405)
|
||||||
|
|
||||||
def test_get_and_post(self):
|
def test_get_and_post(self):
|
||||||
"""
|
"""
|
||||||
Test a view which only allows both GET and POST.
|
Test a view which only allows both GET and POST.
|
||||||
|
|
Loading…
Reference in New Issue