Commit b015ae99 by hellysmile

Inline @transaction.non_atomic_requests for Django<1.6.

parent c292b3d1
...@@ -33,16 +33,6 @@ class APIExceptionView(APIView): ...@@ -33,16 +33,6 @@ class APIExceptionView(APIView):
raise APIException raise APIException
class NonAtomicAPIExceptionView(APIView):
@method_decorator(transaction.non_atomic_requests)
def dispatch(self, *args, **kwargs):
return super(NonAtomicAPIExceptionView, self).dispatch(*args, **kwargs)
def post(self, request, *args, **kwargs):
BasicModel.objects.create()
raise PermissionDenied
@skipUnless(connection.features.uses_savepoints, @skipUnless(connection.features.uses_savepoints,
"'atomic' requires transactions and savepoints.") "'atomic' requires transactions and savepoints.")
class DBTransactionTests(TestCase): class DBTransactionTests(TestCase):
...@@ -125,6 +115,16 @@ class DBTransactionAPIExceptionTests(TestCase): ...@@ -125,6 +115,16 @@ class DBTransactionAPIExceptionTests(TestCase):
"'atomic' requires transactions and savepoints.") "'atomic' requires transactions and savepoints.")
class NonAtomicDBTransactionAPIExceptionTests(TestCase): class NonAtomicDBTransactionAPIExceptionTests(TestCase):
def setUp(self): def setUp(self):
# only Django >= 1.6 provides @transaction.non_atomic_requests
class NonAtomicAPIExceptionView(APIView):
@method_decorator(transaction.non_atomic_requests)
def dispatch(self, *args, **kwargs):
return super(NonAtomicAPIExceptionView, self).dispatch(*args, **kwargs)
def post(self, request, *args, **kwargs):
BasicModel.objects.create()
raise PermissionDenied
self.view = NonAtomicAPIExceptionView.as_view() self.view = NonAtomicAPIExceptionView.as_view()
connections.databases['default']['ATOMIC_REQUESTS'] = True connections.databases['default']['ATOMIC_REQUESTS'] = True
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment