Fixed #28501 -- Fixed "python -m django runserver" crash.

This commit is contained in:
Yusuke Miyazaki 2017-10-25 16:29:05 +09:00 committed by Tim Graham
parent ac21f2e391
commit 278d66b94b
2 changed files with 17 additions and 1 deletions

View File

@ -280,8 +280,15 @@ def reloader_thread():
def restart_with_reloader(): def restart_with_reloader():
import django.__main__
while True: while True:
args = [sys.executable] + ['-W%s' % o for o in sys.warnoptions] + sys.argv args = [sys.executable] + ['-W%s' % o for o in sys.warnoptions]
if sys.argv[0] == django.__main__.__file__:
# The server was started with `python -m django runserver`.
args += ['-m', 'django']
args += sys.argv[1:]
else:
args += sys.argv
new_environ = os.environ.copy() new_environ = os.environ.copy()
new_environ["RUN_MAIN"] = 'true' new_environ["RUN_MAIN"] = 'true'
exit_code = subprocess.call(args, env=new_environ) exit_code = subprocess.call(args, env=new_environ)

View File

@ -277,3 +277,12 @@ class RestartWithReloaderTests(SimpleTestCase):
autoreload.restart_with_reloader() autoreload.restart_with_reloader()
self.assertEqual(mock_call.call_count, 1) self.assertEqual(mock_call.call_count, 1)
self.assertEqual(mock_call.call_args[0][0], [self.executable, '-Wall'] + argv) self.assertEqual(mock_call.call_args[0][0], [self.executable, '-Wall'] + argv)
def test_python_m_django(self):
main = '/usr/lib/pythonX.Y/site-packages/django/__main__.py'
argv = [main, 'runserver']
mock_call = self.patch_autoreload(argv)
with mock.patch('django.__main__.__file__', main):
autoreload.restart_with_reloader()
self.assertEqual(mock_call.call_count, 1)
self.assertEqual(mock_call.call_args[0][0], [self.executable, '-Wall', '-m', 'django'] + argv[1:])