Added test for OPTIONS before object creation from a PUT

This commit is contained in:
Edmond Wong 2013-09-03 12:30:18 -07:00
parent 3063a50fc2
commit 6e7e4fc01c
2 changed files with 45 additions and 1 deletions

View File

@ -360,7 +360,9 @@ class GenericAPIView(views.APIView):
self.get_object() self.get_object()
except Http404: except Http404:
# Http404 should be acceptable and the serializer # Http404 should be acceptable and the serializer
# metadata should be populated. # metadata should be populated. Except this so the
# outer "else" clause of the try-except-else block
# will be executed.
pass pass
except (exceptions.APIException, PermissionDenied): except (exceptions.APIException, PermissionDenied):
pass pass

View File

@ -272,6 +272,48 @@ class TestInstanceView(TestCase):
self.assertEqual(response.status_code, status.HTTP_200_OK) self.assertEqual(response.status_code, status.HTTP_200_OK)
self.assertEqual(response.data, expected) self.assertEqual(response.data, expected)
def test_options_before_instance_create(self):
"""
OPTIONS requests to RetrieveUpdateDestroyAPIView should return metadata
before the instance has been created
"""
request = factory.options('/999')
with self.assertNumQueries(1):
response = self.view(request, pk=999).render()
expected = {
'parses': [
'application/json',
'application/x-www-form-urlencoded',
'multipart/form-data'
],
'renders': [
'application/json',
'text/html'
],
'name': 'Instance',
'description': 'Example description for OPTIONS.',
'actions': {
'PUT': {
'text': {
'max_length': 100,
'read_only': False,
'required': True,
'type': 'string',
'label': 'Text comes here',
'help_text': 'Text description.'
},
'id': {
'read_only': True,
'required': False,
'type': 'integer',
'label': 'ID',
},
}
}
}
self.assertEqual(response.status_code, status.HTTP_200_OK)
self.assertEqual(response.data, expected)
def test_get_instance_view_incorrect_arg(self): def test_get_instance_view_incorrect_arg(self):
""" """
GET requests with an incorrect pk type, should raise 404, not 500. GET requests with an incorrect pk type, should raise 404, not 500.