From 5c6d397956f405f5c3fee6dc42568386972b9fc2 Mon Sep 17 00:00:00 2001 From: Tim Graham Date: Sat, 9 Apr 2016 13:24:45 -0400 Subject: [PATCH] Refs #26484 -- Avoided masking useful exceptions in manage.py's ImportError. --- django/conf/project_template/manage.py-tpl | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/django/conf/project_template/manage.py-tpl b/django/conf/project_template/manage.py-tpl index 71d47d97ec..41309844e0 100755 --- a/django/conf/project_template/manage.py-tpl +++ b/django/conf/project_template/manage.py-tpl @@ -7,9 +7,16 @@ if __name__ == "__main__": try: from django.core.management import execute_from_command_line except ImportError: - raise ImportError( - "Couldn't import Django. Are you sure it's installed and available " - "on your PATH environment variable? Did you forget to activate a " - "virtual environment?" - ) + # The above import may fail for some other reason. Ensure that the + # issue is really that Django is missing to avoid masking other + # exceptions on Python 2. + try: + import django + except ImportError: + raise ImportError( + "Couldn't import Django. Are you sure it's installed and " + "available on your PYTHONPATH environment variable? Did you " + "forget to activate a virtual environment?" + ) + raise execute_from_command_line(sys.argv)