tests.py 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898
  1. import sys
  2. from django.conf import settings
  3. from django.core.exceptions import MiddlewareNotUsed
  4. from django.core.signals import got_request_exception
  5. from django.http import HttpResponse
  6. from django.template.response import TemplateResponse
  7. from django.template import Template
  8. from django.test import RequestFactory, TestCase, override_settings
  9. from django.test.utils import patch_logger
  10. class TestException(Exception):
  11. pass
  12. # A middleware base class that tracks which methods have been called
  13. class TestMiddleware(object):
  14. def __init__(self):
  15. self.process_request_called = False
  16. self.process_view_called = False
  17. self.process_response_called = False
  18. self.process_template_response_called = False
  19. self.process_exception_called = False
  20. def process_request(self, request):
  21. self.process_request_called = True
  22. def process_view(self, request, view_func, view_args, view_kwargs):
  23. self.process_view_called = True
  24. def process_template_response(self, request, response):
  25. self.process_template_response_called = True
  26. return response
  27. def process_response(self, request, response):
  28. self.process_response_called = True
  29. return response
  30. def process_exception(self, request, exception):
  31. self.process_exception_called = True
  32. # Middleware examples that do the right thing
  33. class RequestMiddleware(TestMiddleware):
  34. def process_request(self, request):
  35. super(RequestMiddleware, self).process_request(request)
  36. return HttpResponse('Request Middleware')
  37. class ViewMiddleware(TestMiddleware):
  38. def process_view(self, request, view_func, view_args, view_kwargs):
  39. super(ViewMiddleware, self).process_view(request, view_func, view_args, view_kwargs)
  40. return HttpResponse('View Middleware')
  41. class ResponseMiddleware(TestMiddleware):
  42. def process_response(self, request, response):
  43. super(ResponseMiddleware, self).process_response(request, response)
  44. return HttpResponse('Response Middleware')
  45. class TemplateResponseMiddleware(TestMiddleware):
  46. def process_template_response(self, request, response):
  47. super(TemplateResponseMiddleware, self).process_template_response(request, response)
  48. return TemplateResponse(request, Template('Template Response Middleware'))
  49. class ExceptionMiddleware(TestMiddleware):
  50. def process_exception(self, request, exception):
  51. super(ExceptionMiddleware, self).process_exception(request, exception)
  52. return HttpResponse('Exception Middleware')
  53. # Sample middlewares that raise exceptions
  54. class BadRequestMiddleware(TestMiddleware):
  55. def process_request(self, request):
  56. super(BadRequestMiddleware, self).process_request(request)
  57. raise TestException('Test Request Exception')
  58. class BadViewMiddleware(TestMiddleware):
  59. def process_view(self, request, view_func, view_args, view_kwargs):
  60. super(BadViewMiddleware, self).process_view(request, view_func, view_args, view_kwargs)
  61. raise TestException('Test View Exception')
  62. class BadTemplateResponseMiddleware(TestMiddleware):
  63. def process_template_response(self, request, response):
  64. super(BadTemplateResponseMiddleware, self).process_template_response(request, response)
  65. raise TestException('Test Template Response Exception')
  66. class BadResponseMiddleware(TestMiddleware):
  67. def process_response(self, request, response):
  68. super(BadResponseMiddleware, self).process_response(request, response)
  69. raise TestException('Test Response Exception')
  70. class BadExceptionMiddleware(TestMiddleware):
  71. def process_exception(self, request, exception):
  72. super(BadExceptionMiddleware, self).process_exception(request, exception)
  73. raise TestException('Test Exception Exception')
  74. # Sample middlewares that omit to return an HttpResonse
  75. class NoTemplateResponseMiddleware(TestMiddleware):
  76. def process_template_response(self, request, response):
  77. super(NoTemplateResponseMiddleware, self).process_template_response(request, response)
  78. class NoResponseMiddleware(TestMiddleware):
  79. def process_response(self, request, response):
  80. super(NoResponseMiddleware, self).process_response(request, response)
  81. @override_settings(ROOT_URLCONF='middleware_exceptions.urls')
  82. class BaseMiddlewareExceptionTest(TestCase):
  83. def setUp(self):
  84. self.exceptions = []
  85. got_request_exception.connect(self._on_request_exception)
  86. self.client.handler.load_middleware()
  87. def tearDown(self):
  88. got_request_exception.disconnect(self._on_request_exception)
  89. self.exceptions = []
  90. def _on_request_exception(self, sender, request, **kwargs):
  91. self.exceptions.append(sys.exc_info())
  92. def _add_middleware(self, middleware):
  93. self.client.handler._request_middleware.insert(0, middleware.process_request)
  94. self.client.handler._view_middleware.insert(0, middleware.process_view)
  95. self.client.handler._template_response_middleware.append(middleware.process_template_response)
  96. self.client.handler._response_middleware.append(middleware.process_response)
  97. self.client.handler._exception_middleware.append(middleware.process_exception)
  98. def assert_exceptions_handled(self, url, errors, extra_error=None):
  99. try:
  100. self.client.get(url)
  101. except TestException:
  102. # Test client intentionally re-raises any exceptions being raised
  103. # during request handling. Hence actual testing that exception was
  104. # properly handled is done by relying on got_request_exception
  105. # signal being sent.
  106. pass
  107. except Exception as e:
  108. if type(extra_error) != type(e):
  109. self.fail("Unexpected exception: %s" % e)
  110. self.assertEqual(len(self.exceptions), len(errors))
  111. for i, error in enumerate(errors):
  112. exception, value, tb = self.exceptions[i]
  113. self.assertEqual(value.args, (error, ))
  114. def assert_middleware_usage(self, middleware, request, view, template_response, response, exception):
  115. self.assertEqual(middleware.process_request_called, request)
  116. self.assertEqual(middleware.process_view_called, view)
  117. self.assertEqual(middleware.process_template_response_called, template_response)
  118. self.assertEqual(middleware.process_response_called, response)
  119. self.assertEqual(middleware.process_exception_called, exception)
  120. class MiddlewareTests(BaseMiddlewareExceptionTest):
  121. def test_process_request_middleware(self):
  122. pre_middleware = TestMiddleware()
  123. middleware = RequestMiddleware()
  124. post_middleware = TestMiddleware()
  125. self._add_middleware(post_middleware)
  126. self._add_middleware(middleware)
  127. self._add_middleware(pre_middleware)
  128. self.assert_exceptions_handled('/middleware_exceptions/view/', [])
  129. # Check that the right middleware methods have been invoked
  130. self.assert_middleware_usage(pre_middleware, True, False, False, True, False)
  131. self.assert_middleware_usage(middleware, True, False, False, True, False)
  132. self.assert_middleware_usage(post_middleware, False, False, False, True, False)
  133. def test_process_view_middleware(self):
  134. pre_middleware = TestMiddleware()
  135. middleware = ViewMiddleware()
  136. post_middleware = TestMiddleware()
  137. self._add_middleware(post_middleware)
  138. self._add_middleware(middleware)
  139. self._add_middleware(pre_middleware)
  140. self.assert_exceptions_handled('/middleware_exceptions/view/', [])
  141. # Check that the right middleware methods have been invoked
  142. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  143. self.assert_middleware_usage(middleware, True, True, False, True, False)
  144. self.assert_middleware_usage(post_middleware, True, False, False, True, False)
  145. def test_process_response_middleware(self):
  146. pre_middleware = TestMiddleware()
  147. middleware = ResponseMiddleware()
  148. post_middleware = TestMiddleware()
  149. self._add_middleware(post_middleware)
  150. self._add_middleware(middleware)
  151. self._add_middleware(pre_middleware)
  152. self.assert_exceptions_handled('/middleware_exceptions/view/', [])
  153. # Check that the right middleware methods have been invoked
  154. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  155. self.assert_middleware_usage(middleware, True, True, False, True, False)
  156. self.assert_middleware_usage(post_middleware, True, True, False, True, False)
  157. def test_process_template_response_middleware(self):
  158. pre_middleware = TestMiddleware()
  159. middleware = TemplateResponseMiddleware()
  160. post_middleware = TestMiddleware()
  161. self._add_middleware(post_middleware)
  162. self._add_middleware(middleware)
  163. self._add_middleware(pre_middleware)
  164. self.assert_exceptions_handled('/middleware_exceptions/template_response/', [])
  165. # Check that the right middleware methods have been invoked
  166. self.assert_middleware_usage(pre_middleware, True, True, True, True, False)
  167. self.assert_middleware_usage(middleware, True, True, True, True, False)
  168. self.assert_middleware_usage(post_middleware, True, True, True, True, False)
  169. def test_process_exception_middleware(self):
  170. pre_middleware = TestMiddleware()
  171. middleware = ExceptionMiddleware()
  172. post_middleware = TestMiddleware()
  173. self._add_middleware(post_middleware)
  174. self._add_middleware(middleware)
  175. self._add_middleware(pre_middleware)
  176. self.assert_exceptions_handled('/middleware_exceptions/view/', [])
  177. # Check that the right middleware methods have been invoked
  178. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  179. self.assert_middleware_usage(middleware, True, True, False, True, False)
  180. self.assert_middleware_usage(post_middleware, True, True, False, True, False)
  181. def test_process_request_middleware_not_found(self):
  182. pre_middleware = TestMiddleware()
  183. middleware = RequestMiddleware()
  184. post_middleware = TestMiddleware()
  185. self._add_middleware(post_middleware)
  186. self._add_middleware(middleware)
  187. self._add_middleware(pre_middleware)
  188. self.assert_exceptions_handled('/middleware_exceptions/not_found/', [])
  189. # Check that the right middleware methods have been invoked
  190. self.assert_middleware_usage(pre_middleware, True, False, False, True, False)
  191. self.assert_middleware_usage(middleware, True, False, False, True, False)
  192. self.assert_middleware_usage(post_middleware, False, False, False, True, False)
  193. def test_process_view_middleware_not_found(self):
  194. pre_middleware = TestMiddleware()
  195. middleware = ViewMiddleware()
  196. post_middleware = TestMiddleware()
  197. self._add_middleware(post_middleware)
  198. self._add_middleware(middleware)
  199. self._add_middleware(pre_middleware)
  200. self.assert_exceptions_handled('/middleware_exceptions/not_found/', [])
  201. # Check that the right middleware methods have been invoked
  202. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  203. self.assert_middleware_usage(middleware, True, True, False, True, False)
  204. self.assert_middleware_usage(post_middleware, True, False, False, True, False)
  205. def test_process_template_response_middleware_not_found(self):
  206. pre_middleware = TestMiddleware()
  207. middleware = TemplateResponseMiddleware()
  208. post_middleware = TestMiddleware()
  209. self._add_middleware(post_middleware)
  210. self._add_middleware(middleware)
  211. self._add_middleware(pre_middleware)
  212. self.assert_exceptions_handled('/middleware_exceptions/not_found/', [])
  213. # Check that the right middleware methods have been invoked
  214. self.assert_middleware_usage(pre_middleware, True, True, False, True, True)
  215. self.assert_middleware_usage(middleware, True, True, False, True, True)
  216. self.assert_middleware_usage(post_middleware, True, True, False, True, True)
  217. def test_process_response_middleware_not_found(self):
  218. pre_middleware = TestMiddleware()
  219. middleware = ResponseMiddleware()
  220. post_middleware = TestMiddleware()
  221. self._add_middleware(post_middleware)
  222. self._add_middleware(middleware)
  223. self._add_middleware(pre_middleware)
  224. self.assert_exceptions_handled('/middleware_exceptions/not_found/', [])
  225. # Check that the right middleware methods have been invoked
  226. self.assert_middleware_usage(pre_middleware, True, True, False, True, True)
  227. self.assert_middleware_usage(middleware, True, True, False, True, True)
  228. self.assert_middleware_usage(post_middleware, True, True, False, True, True)
  229. def test_process_exception_middleware_not_found(self):
  230. pre_middleware = TestMiddleware()
  231. middleware = ExceptionMiddleware()
  232. post_middleware = TestMiddleware()
  233. self._add_middleware(post_middleware)
  234. self._add_middleware(middleware)
  235. self._add_middleware(pre_middleware)
  236. self.assert_exceptions_handled('/middleware_exceptions/not_found/', [])
  237. # Check that the right middleware methods have been invoked
  238. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  239. self.assert_middleware_usage(middleware, True, True, False, True, True)
  240. self.assert_middleware_usage(post_middleware, True, True, False, True, True)
  241. def test_process_request_middleware_exception(self):
  242. pre_middleware = TestMiddleware()
  243. middleware = RequestMiddleware()
  244. post_middleware = TestMiddleware()
  245. self._add_middleware(post_middleware)
  246. self._add_middleware(middleware)
  247. self._add_middleware(pre_middleware)
  248. self.assert_exceptions_handled('/middleware_exceptions/error/', [])
  249. # Check that the right middleware methods have been invoked
  250. self.assert_middleware_usage(pre_middleware, True, False, False, True, False)
  251. self.assert_middleware_usage(middleware, True, False, False, True, False)
  252. self.assert_middleware_usage(post_middleware, False, False, False, True, False)
  253. def test_process_view_middleware_exception(self):
  254. pre_middleware = TestMiddleware()
  255. middleware = ViewMiddleware()
  256. post_middleware = TestMiddleware()
  257. self._add_middleware(post_middleware)
  258. self._add_middleware(middleware)
  259. self._add_middleware(pre_middleware)
  260. self.assert_exceptions_handled('/middleware_exceptions/error/', [])
  261. # Check that the right middleware methods have been invoked
  262. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  263. self.assert_middleware_usage(middleware, True, True, False, True, False)
  264. self.assert_middleware_usage(post_middleware, True, False, False, True, False)
  265. def test_process_response_middleware_exception(self):
  266. pre_middleware = TestMiddleware()
  267. middleware = ResponseMiddleware()
  268. post_middleware = TestMiddleware()
  269. self._add_middleware(post_middleware)
  270. self._add_middleware(middleware)
  271. self._add_middleware(pre_middleware)
  272. self.assert_exceptions_handled('/middleware_exceptions/error/', ['Error in view'], Exception())
  273. # Check that the right middleware methods have been invoked
  274. self.assert_middleware_usage(pre_middleware, True, True, False, True, True)
  275. self.assert_middleware_usage(middleware, True, True, False, True, True)
  276. self.assert_middleware_usage(post_middleware, True, True, False, True, True)
  277. def test_process_exception_middleware_exception(self):
  278. pre_middleware = TestMiddleware()
  279. middleware = ExceptionMiddleware()
  280. post_middleware = TestMiddleware()
  281. self._add_middleware(post_middleware)
  282. self._add_middleware(middleware)
  283. self._add_middleware(pre_middleware)
  284. self.assert_exceptions_handled('/middleware_exceptions/error/', [])
  285. # Check that the right middleware methods have been invoked
  286. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  287. self.assert_middleware_usage(middleware, True, True, False, True, True)
  288. self.assert_middleware_usage(post_middleware, True, True, False, True, True)
  289. def test_process_request_middleware_null_view(self):
  290. pre_middleware = TestMiddleware()
  291. middleware = RequestMiddleware()
  292. post_middleware = TestMiddleware()
  293. self._add_middleware(post_middleware)
  294. self._add_middleware(middleware)
  295. self._add_middleware(pre_middleware)
  296. self.assert_exceptions_handled('/middleware_exceptions/null_view/', [])
  297. # Check that the right middleware methods have been invoked
  298. self.assert_middleware_usage(pre_middleware, True, False, False, True, False)
  299. self.assert_middleware_usage(middleware, True, False, False, True, False)
  300. self.assert_middleware_usage(post_middleware, False, False, False, True, False)
  301. def test_process_view_middleware_null_view(self):
  302. pre_middleware = TestMiddleware()
  303. middleware = ViewMiddleware()
  304. post_middleware = TestMiddleware()
  305. self._add_middleware(post_middleware)
  306. self._add_middleware(middleware)
  307. self._add_middleware(pre_middleware)
  308. self.assert_exceptions_handled('/middleware_exceptions/null_view/', [])
  309. # Check that the right middleware methods have been invoked
  310. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  311. self.assert_middleware_usage(middleware, True, True, False, True, False)
  312. self.assert_middleware_usage(post_middleware, True, False, False, True, False)
  313. def test_process_response_middleware_null_view(self):
  314. pre_middleware = TestMiddleware()
  315. middleware = ResponseMiddleware()
  316. post_middleware = TestMiddleware()
  317. self._add_middleware(post_middleware)
  318. self._add_middleware(middleware)
  319. self._add_middleware(pre_middleware)
  320. self.assert_exceptions_handled('/middleware_exceptions/null_view/', [
  321. "The view middleware_exceptions.views.null_view didn't return an HttpResponse object. It returned None instead.",
  322. ],
  323. ValueError())
  324. # Check that the right middleware methods have been invoked
  325. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  326. self.assert_middleware_usage(middleware, True, True, False, True, False)
  327. self.assert_middleware_usage(post_middleware, True, True, False, True, False)
  328. def test_process_exception_middleware_null_view(self):
  329. pre_middleware = TestMiddleware()
  330. middleware = ExceptionMiddleware()
  331. post_middleware = TestMiddleware()
  332. self._add_middleware(post_middleware)
  333. self._add_middleware(middleware)
  334. self._add_middleware(pre_middleware)
  335. self.assert_exceptions_handled('/middleware_exceptions/null_view/', [
  336. "The view middleware_exceptions.views.null_view didn't return an HttpResponse object. It returned None instead."
  337. ],
  338. ValueError())
  339. # Check that the right middleware methods have been invoked
  340. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  341. self.assert_middleware_usage(middleware, True, True, False, True, False)
  342. self.assert_middleware_usage(post_middleware, True, True, False, True, False)
  343. def test_process_request_middleware_permission_denied(self):
  344. pre_middleware = TestMiddleware()
  345. middleware = RequestMiddleware()
  346. post_middleware = TestMiddleware()
  347. self._add_middleware(post_middleware)
  348. self._add_middleware(middleware)
  349. self._add_middleware(pre_middleware)
  350. self.assert_exceptions_handled('/middleware_exceptions/permission_denied/', [])
  351. # Check that the right middleware methods have been invoked
  352. self.assert_middleware_usage(pre_middleware, True, False, False, True, False)
  353. self.assert_middleware_usage(middleware, True, False, False, True, False)
  354. self.assert_middleware_usage(post_middleware, False, False, False, True, False)
  355. def test_process_view_middleware_permission_denied(self):
  356. pre_middleware = TestMiddleware()
  357. middleware = ViewMiddleware()
  358. post_middleware = TestMiddleware()
  359. self._add_middleware(post_middleware)
  360. self._add_middleware(middleware)
  361. self._add_middleware(pre_middleware)
  362. self.assert_exceptions_handled('/middleware_exceptions/permission_denied/', [])
  363. # Check that the right middleware methods have been invoked
  364. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  365. self.assert_middleware_usage(middleware, True, True, False, True, False)
  366. self.assert_middleware_usage(post_middleware, True, False, False, True, False)
  367. def test_process_response_middleware_permission_denied(self):
  368. pre_middleware = TestMiddleware()
  369. middleware = ResponseMiddleware()
  370. post_middleware = TestMiddleware()
  371. self._add_middleware(post_middleware)
  372. self._add_middleware(middleware)
  373. self._add_middleware(pre_middleware)
  374. self.assert_exceptions_handled('/middleware_exceptions/permission_denied/', [])
  375. # Check that the right middleware methods have been invoked
  376. self.assert_middleware_usage(pre_middleware, True, True, False, True, True)
  377. self.assert_middleware_usage(middleware, True, True, False, True, True)
  378. self.assert_middleware_usage(post_middleware, True, True, False, True, True)
  379. def test_process_exception_middleware_permission_denied(self):
  380. pre_middleware = TestMiddleware()
  381. middleware = ExceptionMiddleware()
  382. post_middleware = TestMiddleware()
  383. self._add_middleware(post_middleware)
  384. self._add_middleware(middleware)
  385. self._add_middleware(pre_middleware)
  386. self.assert_exceptions_handled('/middleware_exceptions/permission_denied/', [])
  387. # Check that the right middleware methods have been invoked
  388. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  389. self.assert_middleware_usage(middleware, True, True, False, True, True)
  390. self.assert_middleware_usage(post_middleware, True, True, False, True, True)
  391. def test_process_template_response_error(self):
  392. middleware = TestMiddleware()
  393. self._add_middleware(middleware)
  394. self.assert_exceptions_handled('/middleware_exceptions/template_response_error/', [])
  395. # Check that the right middleware methods have been invoked
  396. self.assert_middleware_usage(middleware, True, True, True, True, False)
  397. class BadMiddlewareTests(BaseMiddlewareExceptionTest):
  398. def test_process_request_bad_middleware(self):
  399. pre_middleware = TestMiddleware()
  400. bad_middleware = BadRequestMiddleware()
  401. post_middleware = TestMiddleware()
  402. self._add_middleware(post_middleware)
  403. self._add_middleware(bad_middleware)
  404. self._add_middleware(pre_middleware)
  405. self.assert_exceptions_handled('/middleware_exceptions/view/', ['Test Request Exception'])
  406. # Check that the right middleware methods have been invoked
  407. self.assert_middleware_usage(pre_middleware, True, False, False, True, False)
  408. self.assert_middleware_usage(bad_middleware, True, False, False, True, False)
  409. self.assert_middleware_usage(post_middleware, False, False, False, True, False)
  410. def test_process_view_bad_middleware(self):
  411. pre_middleware = TestMiddleware()
  412. bad_middleware = BadViewMiddleware()
  413. post_middleware = TestMiddleware()
  414. self._add_middleware(post_middleware)
  415. self._add_middleware(bad_middleware)
  416. self._add_middleware(pre_middleware)
  417. self.assert_exceptions_handled('/middleware_exceptions/view/', ['Test View Exception'])
  418. # Check that the right middleware methods have been invoked
  419. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  420. self.assert_middleware_usage(bad_middleware, True, True, False, True, False)
  421. self.assert_middleware_usage(post_middleware, True, False, False, True, False)
  422. def test_process_template_response_bad_middleware(self):
  423. pre_middleware = TestMiddleware()
  424. bad_middleware = BadTemplateResponseMiddleware()
  425. post_middleware = TestMiddleware()
  426. self._add_middleware(post_middleware)
  427. self._add_middleware(bad_middleware)
  428. self._add_middleware(pre_middleware)
  429. self.assert_exceptions_handled('/middleware_exceptions/template_response/', ['Test Template Response Exception'])
  430. # Check that the right middleware methods have been invoked
  431. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  432. self.assert_middleware_usage(bad_middleware, True, True, True, True, False)
  433. self.assert_middleware_usage(post_middleware, True, True, True, True, False)
  434. def test_process_response_bad_middleware(self):
  435. pre_middleware = TestMiddleware()
  436. bad_middleware = BadResponseMiddleware()
  437. post_middleware = TestMiddleware()
  438. self._add_middleware(post_middleware)
  439. self._add_middleware(bad_middleware)
  440. self._add_middleware(pre_middleware)
  441. self.assert_exceptions_handled('/middleware_exceptions/view/', ['Test Response Exception'])
  442. # Check that the right middleware methods have been invoked
  443. self.assert_middleware_usage(pre_middleware, True, True, False, False, False)
  444. self.assert_middleware_usage(bad_middleware, True, True, False, True, False)
  445. self.assert_middleware_usage(post_middleware, True, True, False, True, False)
  446. def test_process_exception_bad_middleware(self):
  447. pre_middleware = TestMiddleware()
  448. bad_middleware = BadExceptionMiddleware()
  449. post_middleware = TestMiddleware()
  450. self._add_middleware(post_middleware)
  451. self._add_middleware(bad_middleware)
  452. self._add_middleware(pre_middleware)
  453. self.assert_exceptions_handled('/middleware_exceptions/view/', [])
  454. # Check that the right middleware methods have been invoked
  455. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  456. self.assert_middleware_usage(bad_middleware, True, True, False, True, False)
  457. self.assert_middleware_usage(post_middleware, True, True, False, True, False)
  458. def test_process_request_bad_middleware_not_found(self):
  459. pre_middleware = TestMiddleware()
  460. bad_middleware = BadRequestMiddleware()
  461. post_middleware = TestMiddleware()
  462. self._add_middleware(post_middleware)
  463. self._add_middleware(bad_middleware)
  464. self._add_middleware(pre_middleware)
  465. self.assert_exceptions_handled('/middleware_exceptions/not_found/', ['Test Request Exception'])
  466. # Check that the right middleware methods have been invoked
  467. self.assert_middleware_usage(pre_middleware, True, False, False, True, False)
  468. self.assert_middleware_usage(bad_middleware, True, False, False, True, False)
  469. self.assert_middleware_usage(post_middleware, False, False, False, True, False)
  470. def test_process_view_bad_middleware_not_found(self):
  471. pre_middleware = TestMiddleware()
  472. bad_middleware = BadViewMiddleware()
  473. post_middleware = TestMiddleware()
  474. self._add_middleware(post_middleware)
  475. self._add_middleware(bad_middleware)
  476. self._add_middleware(pre_middleware)
  477. self.assert_exceptions_handled('/middleware_exceptions/not_found/', ['Test View Exception'])
  478. # Check that the right middleware methods have been invoked
  479. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  480. self.assert_middleware_usage(bad_middleware, True, True, False, True, False)
  481. self.assert_middleware_usage(post_middleware, True, False, False, True, False)
  482. def test_process_response_bad_middleware_not_found(self):
  483. pre_middleware = TestMiddleware()
  484. bad_middleware = BadResponseMiddleware()
  485. post_middleware = TestMiddleware()
  486. self._add_middleware(post_middleware)
  487. self._add_middleware(bad_middleware)
  488. self._add_middleware(pre_middleware)
  489. self.assert_exceptions_handled('/middleware_exceptions/not_found/', ['Test Response Exception'])
  490. # Check that the right middleware methods have been invoked
  491. self.assert_middleware_usage(pre_middleware, True, True, False, False, True)
  492. self.assert_middleware_usage(bad_middleware, True, True, False, True, True)
  493. self.assert_middleware_usage(post_middleware, True, True, False, True, True)
  494. def test_process_exception_bad_middleware_not_found(self):
  495. pre_middleware = TestMiddleware()
  496. bad_middleware = BadExceptionMiddleware()
  497. post_middleware = TestMiddleware()
  498. self._add_middleware(post_middleware)
  499. self._add_middleware(bad_middleware)
  500. self._add_middleware(pre_middleware)
  501. self.assert_exceptions_handled('/middleware_exceptions/not_found/', ['Test Exception Exception'])
  502. # Check that the right middleware methods have been invoked
  503. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  504. self.assert_middleware_usage(bad_middleware, True, True, False, True, True)
  505. self.assert_middleware_usage(post_middleware, True, True, False, True, True)
  506. def test_process_request_bad_middleware_exception(self):
  507. pre_middleware = TestMiddleware()
  508. bad_middleware = BadRequestMiddleware()
  509. post_middleware = TestMiddleware()
  510. self._add_middleware(post_middleware)
  511. self._add_middleware(bad_middleware)
  512. self._add_middleware(pre_middleware)
  513. self.assert_exceptions_handled('/middleware_exceptions/error/', ['Test Request Exception'])
  514. # Check that the right middleware methods have been invoked
  515. self.assert_middleware_usage(pre_middleware, True, False, False, True, False)
  516. self.assert_middleware_usage(bad_middleware, True, False, False, True, False)
  517. self.assert_middleware_usage(post_middleware, False, False, False, True, False)
  518. def test_process_view_bad_middleware_exception(self):
  519. pre_middleware = TestMiddleware()
  520. bad_middleware = BadViewMiddleware()
  521. post_middleware = TestMiddleware()
  522. self._add_middleware(post_middleware)
  523. self._add_middleware(bad_middleware)
  524. self._add_middleware(pre_middleware)
  525. self.assert_exceptions_handled('/middleware_exceptions/error/', ['Test View Exception'])
  526. # Check that the right middleware methods have been invoked
  527. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  528. self.assert_middleware_usage(bad_middleware, True, True, False, True, False)
  529. self.assert_middleware_usage(post_middleware, True, False, False, True, False)
  530. def test_process_response_bad_middleware_exception(self):
  531. pre_middleware = TestMiddleware()
  532. bad_middleware = BadResponseMiddleware()
  533. post_middleware = TestMiddleware()
  534. self._add_middleware(post_middleware)
  535. self._add_middleware(bad_middleware)
  536. self._add_middleware(pre_middleware)
  537. self.assert_exceptions_handled('/middleware_exceptions/error/', ['Error in view', 'Test Response Exception'])
  538. # Check that the right middleware methods have been invoked
  539. self.assert_middleware_usage(pre_middleware, True, True, False, False, True)
  540. self.assert_middleware_usage(bad_middleware, True, True, False, True, True)
  541. self.assert_middleware_usage(post_middleware, True, True, False, True, True)
  542. def test_process_exception_bad_middleware_exception(self):
  543. pre_middleware = TestMiddleware()
  544. bad_middleware = BadExceptionMiddleware()
  545. post_middleware = TestMiddleware()
  546. self._add_middleware(post_middleware)
  547. self._add_middleware(bad_middleware)
  548. self._add_middleware(pre_middleware)
  549. self.assert_exceptions_handled('/middleware_exceptions/error/', ['Test Exception Exception'])
  550. # Check that the right middleware methods have been invoked
  551. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  552. self.assert_middleware_usage(bad_middleware, True, True, False, True, True)
  553. self.assert_middleware_usage(post_middleware, True, True, False, True, True)
  554. def test_process_request_bad_middleware_null_view(self):
  555. pre_middleware = TestMiddleware()
  556. bad_middleware = BadRequestMiddleware()
  557. post_middleware = TestMiddleware()
  558. self._add_middleware(post_middleware)
  559. self._add_middleware(bad_middleware)
  560. self._add_middleware(pre_middleware)
  561. self.assert_exceptions_handled('/middleware_exceptions/null_view/', ['Test Request Exception'])
  562. # Check that the right middleware methods have been invoked
  563. self.assert_middleware_usage(pre_middleware, True, False, False, True, False)
  564. self.assert_middleware_usage(bad_middleware, True, False, False, True, False)
  565. self.assert_middleware_usage(post_middleware, False, False, False, True, False)
  566. def test_process_view_bad_middleware_null_view(self):
  567. pre_middleware = TestMiddleware()
  568. bad_middleware = BadViewMiddleware()
  569. post_middleware = TestMiddleware()
  570. self._add_middleware(post_middleware)
  571. self._add_middleware(bad_middleware)
  572. self._add_middleware(pre_middleware)
  573. self.assert_exceptions_handled('/middleware_exceptions/null_view/', ['Test View Exception'])
  574. # Check that the right middleware methods have been invoked
  575. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  576. self.assert_middleware_usage(bad_middleware, True, True, False, True, False)
  577. self.assert_middleware_usage(post_middleware, True, False, False, True, False)
  578. def test_process_response_bad_middleware_null_view(self):
  579. pre_middleware = TestMiddleware()
  580. bad_middleware = BadResponseMiddleware()
  581. post_middleware = TestMiddleware()
  582. self._add_middleware(post_middleware)
  583. self._add_middleware(bad_middleware)
  584. self._add_middleware(pre_middleware)
  585. self.assert_exceptions_handled('/middleware_exceptions/null_view/', [
  586. "The view middleware_exceptions.views.null_view didn't return an HttpResponse object. It returned None instead.",
  587. 'Test Response Exception'
  588. ])
  589. # Check that the right middleware methods have been invoked
  590. self.assert_middleware_usage(pre_middleware, True, True, False, False, False)
  591. self.assert_middleware_usage(bad_middleware, True, True, False, True, False)
  592. self.assert_middleware_usage(post_middleware, True, True, False, True, False)
  593. def test_process_exception_bad_middleware_null_view(self):
  594. pre_middleware = TestMiddleware()
  595. bad_middleware = BadExceptionMiddleware()
  596. post_middleware = TestMiddleware()
  597. self._add_middleware(post_middleware)
  598. self._add_middleware(bad_middleware)
  599. self._add_middleware(pre_middleware)
  600. self.assert_exceptions_handled('/middleware_exceptions/null_view/', [
  601. "The view middleware_exceptions.views.null_view didn't return an HttpResponse object. It returned None instead."
  602. ],
  603. ValueError())
  604. # Check that the right middleware methods have been invoked
  605. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  606. self.assert_middleware_usage(bad_middleware, True, True, False, True, False)
  607. self.assert_middleware_usage(post_middleware, True, True, False, True, False)
  608. def test_process_request_bad_middleware_permission_denied(self):
  609. pre_middleware = TestMiddleware()
  610. bad_middleware = BadRequestMiddleware()
  611. post_middleware = TestMiddleware()
  612. self._add_middleware(post_middleware)
  613. self._add_middleware(bad_middleware)
  614. self._add_middleware(pre_middleware)
  615. self.assert_exceptions_handled('/middleware_exceptions/permission_denied/', ['Test Request Exception'])
  616. # Check that the right middleware methods have been invoked
  617. self.assert_middleware_usage(pre_middleware, True, False, False, True, False)
  618. self.assert_middleware_usage(bad_middleware, True, False, False, True, False)
  619. self.assert_middleware_usage(post_middleware, False, False, False, True, False)
  620. def test_process_view_bad_middleware_permission_denied(self):
  621. pre_middleware = TestMiddleware()
  622. bad_middleware = BadViewMiddleware()
  623. post_middleware = TestMiddleware()
  624. self._add_middleware(post_middleware)
  625. self._add_middleware(bad_middleware)
  626. self._add_middleware(pre_middleware)
  627. self.assert_exceptions_handled('/middleware_exceptions/permission_denied/', ['Test View Exception'])
  628. # Check that the right middleware methods have been invoked
  629. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  630. self.assert_middleware_usage(bad_middleware, True, True, False, True, False)
  631. self.assert_middleware_usage(post_middleware, True, False, False, True, False)
  632. def test_process_response_bad_middleware_permission_denied(self):
  633. pre_middleware = TestMiddleware()
  634. bad_middleware = BadResponseMiddleware()
  635. post_middleware = TestMiddleware()
  636. self._add_middleware(post_middleware)
  637. self._add_middleware(bad_middleware)
  638. self._add_middleware(pre_middleware)
  639. self.assert_exceptions_handled('/middleware_exceptions/permission_denied/', ['Test Response Exception'])
  640. # Check that the right middleware methods have been invoked
  641. self.assert_middleware_usage(pre_middleware, True, True, False, False, True)
  642. self.assert_middleware_usage(bad_middleware, True, True, False, True, True)
  643. self.assert_middleware_usage(post_middleware, True, True, False, True, True)
  644. def test_process_exception_bad_middleware_permission_denied(self):
  645. pre_middleware = TestMiddleware()
  646. bad_middleware = BadExceptionMiddleware()
  647. post_middleware = TestMiddleware()
  648. self._add_middleware(post_middleware)
  649. self._add_middleware(bad_middleware)
  650. self._add_middleware(pre_middleware)
  651. self.assert_exceptions_handled('/middleware_exceptions/permission_denied/', ['Test Exception Exception'])
  652. # Check that the right middleware methods have been invoked
  653. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  654. self.assert_middleware_usage(bad_middleware, True, True, False, True, True)
  655. self.assert_middleware_usage(post_middleware, True, True, False, True, True)
  656. def test_process_response_no_response_middleware(self):
  657. pre_middleware = TestMiddleware()
  658. middleware = NoResponseMiddleware()
  659. post_middleware = TestMiddleware()
  660. self._add_middleware(post_middleware)
  661. self._add_middleware(middleware)
  662. self._add_middleware(pre_middleware)
  663. self.assert_exceptions_handled('/middleware_exceptions/view/', [
  664. "NoResponseMiddleware.process_response didn't return an HttpResponse object. It returned None instead."
  665. ],
  666. ValueError())
  667. # Check that the right middleware methods have been invoked
  668. self.assert_middleware_usage(pre_middleware, True, True, False, False, False)
  669. self.assert_middleware_usage(middleware, True, True, False, True, False)
  670. self.assert_middleware_usage(post_middleware, True, True, False, True, False)
  671. def test_process_template_response_no_response_middleware(self):
  672. pre_middleware = TestMiddleware()
  673. middleware = NoTemplateResponseMiddleware()
  674. post_middleware = TestMiddleware()
  675. self._add_middleware(post_middleware)
  676. self._add_middleware(middleware)
  677. self._add_middleware(pre_middleware)
  678. self.assert_exceptions_handled('/middleware_exceptions/template_response/', [
  679. "NoTemplateResponseMiddleware.process_template_response didn't return an HttpResponse object. It returned None instead."
  680. ],
  681. ValueError())
  682. # Check that the right middleware methods have been invoked
  683. self.assert_middleware_usage(pre_middleware, True, True, False, True, False)
  684. self.assert_middleware_usage(middleware, True, True, True, True, False)
  685. self.assert_middleware_usage(post_middleware, True, True, True, True, False)
  686. _missing = object()
  687. @override_settings(ROOT_URLCONF='middleware_exceptions.urls')
  688. class RootUrlconfTests(TestCase):
  689. @override_settings(ROOT_URLCONF=None)
  690. def test_missing_root_urlconf(self):
  691. # Removing ROOT_URLCONF is safe, as override_settings will restore
  692. # the previously defined settings.
  693. del settings.ROOT_URLCONF
  694. self.assertRaises(AttributeError, self.client.get, "/middleware_exceptions/view/")
  695. class MyMiddleware(object):
  696. def __init__(self):
  697. raise MiddlewareNotUsed
  698. def process_request(self, request):
  699. pass
  700. class MyMiddlewareWithExceptionMessage(object):
  701. def __init__(self):
  702. raise MiddlewareNotUsed('spam eggs')
  703. def process_request(self, request):
  704. pass
  705. @override_settings(
  706. DEBUG=True,
  707. ROOT_URLCONF='middleware_exceptions.urls',
  708. )
  709. class MiddlewareNotUsedTests(TestCase):
  710. rf = RequestFactory()
  711. def test_raise_exception(self):
  712. request = self.rf.get('middleware_exceptions/view/')
  713. with self.assertRaises(MiddlewareNotUsed):
  714. MyMiddleware().process_request(request)
  715. @override_settings(MIDDLEWARE_CLASSES=(
  716. 'middleware_exceptions.tests.MyMiddleware',
  717. ))
  718. def test_log(self):
  719. with patch_logger('django.request', 'debug') as calls:
  720. self.client.get('/middleware_exceptions/view/')
  721. self.assertEqual(len(calls), 1)
  722. self.assertEqual(
  723. calls[0],
  724. "MiddlewareNotUsed: 'middleware_exceptions.tests.MyMiddleware'"
  725. )
  726. @override_settings(MIDDLEWARE_CLASSES=(
  727. 'middleware_exceptions.tests.MyMiddlewareWithExceptionMessage',
  728. ))
  729. def test_log_custom_message(self):
  730. with patch_logger('django.request', 'debug') as calls:
  731. self.client.get('/middleware_exceptions/view/')
  732. self.assertEqual(len(calls), 1)
  733. self.assertEqual(
  734. calls[0],
  735. "MiddlewareNotUsed('middleware_exceptions.tests.MyMiddlewareWithExceptionMessage'): spam eggs"
  736. )
  737. @override_settings(DEBUG=False)
  738. def test_do_not_log_when_debug_is_false(self):
  739. with patch_logger('django.request', 'debug') as calls:
  740. self.client.get('/middleware_exceptions/view/')
  741. self.assertEqual(len(calls), 0)