From b79fc11d730b5beff92e9dd8853a61524cdeffe3 Mon Sep 17 00:00:00 2001 From: Aymeric Augustin Date: Sat, 29 Aug 2015 13:26:00 +0200 Subject: [PATCH] Made the autoreloader survive all exceptions. Refs #24704. --- django/utils/autoreload.py | 3 +-- tests/utils_tests/test_autoreload.py | 16 ++++++++++++++++ 2 files changed, 17 insertions(+), 2 deletions(-) diff --git a/django/utils/autoreload.py b/django/utils/autoreload.py index 0cf00a9646..4fba0fe1a0 100644 --- a/django/utils/autoreload.py +++ b/django/utils/autoreload.py @@ -224,8 +224,7 @@ def check_errors(fn): global _exception try: fn(*args, **kwargs) - except (ImportError, IndentationError, NameError, SyntaxError, - TypeError, AttributeError): + except Exception: _exception = sys.exc_info() et, ev, tb = _exception diff --git a/tests/utils_tests/test_autoreload.py b/tests/utils_tests/test_autoreload.py index fd477bd268..6b60f00ede 100644 --- a/tests/utils_tests/test_autoreload.py +++ b/tests/utils_tests/test_autoreload.py @@ -169,3 +169,19 @@ class TestFilenameGenerator(SimpleTestCase): with self.assertRaises(SyntaxError): autoreload.check_errors(import_module)('test_syntax_error') self.assertFileFoundOnlyNew(filename) + + def test_check_errors_catches_all_exceptions(self): + """ + Since Python may raise arbitrary exceptions when importing code, + check_errors() must catch Exception, not just some subclasses. + """ + dirname = tempfile.mkdtemp() + filename = os.path.join(dirname, 'test_exception.py') + self.addCleanup(shutil.rmtree, dirname) + with open(filename, 'w') as f: + f.write("raise Exception") + + with extend_sys_path(dirname): + with self.assertRaises(Exception): + autoreload.check_errors(import_module)('test_exception') + self.assertFileFound(filename)