1
0
mirror of https://github.com/django/django.git synced 2025-10-25 14:46:09 +00:00

Fixed #23695 -- Made condition decorator work for HEAD requests without ETag.

This commit is contained in:
Anton Novosyolov
2014-10-21 00:22:02 +04:00
committed by Tim Graham
parent 0e16c3e3cd
commit 9f1202c166
2 changed files with 6 additions and 1 deletions

View File

@@ -139,7 +139,7 @@ def condition(etag_func=None, last_modified_func=None):
} }
) )
response = HttpResponse(status=412) response = HttpResponse(status=412)
elif (not if_none_match and request.method == "GET" and elif (not if_none_match and request.method in ("GET", "HEAD") and
res_last_modified and if_modified_since and res_last_modified and if_modified_since and
res_last_modified <= if_modified_since): res_last_modified <= if_modified_since):
response = HttpResponseNotModified() response = HttpResponseNotModified()

View File

@@ -124,6 +124,11 @@ class ConditionalGet(TestCase):
response = self.client.get('/condition/last_modified2/') response = self.client.get('/condition/last_modified2/')
self.assertFullResponse(response, check_etag=False) self.assertFullResponse(response, check_etag=False)
def test_single_condition_head(self):
self.client.defaults['HTTP_IF_MODIFIED_SINCE'] = LAST_MODIFIED_STR
response = self.client.head('/condition/')
self.assertNotModified(response)
def test_invalid_etag(self): def test_invalid_etag(self):
self.client.defaults['HTTP_IF_NONE_MATCH'] = r'"\"' self.client.defaults['HTTP_IF_NONE_MATCH'] = r'"\"'
response = self.client.get('/condition/etag/') response = self.client.get('/condition/etag/')