Fixed #29704 -- Fixed manage.py test --testrunner if it isn't followed by an equals sign.

This commit is contained in:
Matthijs Kooijman 2018-08-16 21:49:03 +02:00 committed by Tim Graham
parent 69071e7f51
commit 08f360355a
3 changed files with 28 additions and 6 deletions

View File

@ -2,6 +2,7 @@ import sys
from django.conf import settings from django.conf import settings
from django.core.management.base import BaseCommand from django.core.management.base import BaseCommand
from django.core.management.utils import get_command_line_option
from django.test.utils import get_runner from django.test.utils import get_runner
@ -18,11 +19,7 @@ class Command(BaseCommand):
option. This allows a test runner to define additional command line option. This allows a test runner to define additional command line
arguments. arguments.
""" """
option = '--testrunner=' self.test_runner = get_command_line_option(argv, '--testrunner')
for arg in argv[2:]:
if arg.startswith(option):
self.test_runner = arg[len(option):]
break
super().run_from_argv(argv) super().run_from_argv(argv)
def add_arguments(self, parser): def add_arguments(self, parser):

View File

@ -5,7 +5,7 @@ from django.apps import apps as installed_apps
from django.utils.crypto import get_random_string from django.utils.crypto import get_random_string
from django.utils.encoding import DEFAULT_LOCALE_ENCODING from django.utils.encoding import DEFAULT_LOCALE_ENCODING
from .base import CommandError from .base import CommandError, CommandParser
def popen_wrapper(args, stdout_encoding='utf-8'): def popen_wrapper(args, stdout_encoding='utf-8'):
@ -106,3 +106,19 @@ def parse_apps_and_model_labels(labels):
apps.add(app_config) apps.add(app_config)
return models, apps return models, apps
def get_command_line_option(argv, option):
"""
Return the value of a command line option (which should include leading
dashes, e.g. '--testrunnner') from an argument list. Return None if the
option wasn't passed or if the argument list couldn't be parsed.
"""
parser = CommandParser(add_help=False, allow_abbrev=False)
parser.add_argument(option, dest='value')
try:
options, _ = parser.parse_known_args(argv[2:])
except CommandError:
return None
else:
return options.value

View File

@ -201,6 +201,15 @@ class CustomTestRunnerOptionsCmdlineTests(AdminScriptTestCase):
def tearDown(self): def tearDown(self):
self.remove_settings('settings.py') self.remove_settings('settings.py')
def test_testrunner_option(self):
args = [
'test', '--testrunner', 'test_runner.runner.CustomOptionsTestRunner',
'--option_a=bar', '--option_b=foo', '--option_c=31337'
]
out, err = self.run_django_admin(args, 'test_project.settings')
self.assertNoOutput(err)
self.assertOutput(out, 'bar:foo:31337')
def test_testrunner_equals(self): def test_testrunner_equals(self):
args = [ args = [
'test', '--testrunner=test_runner.runner.CustomOptionsTestRunner', 'test', '--testrunner=test_runner.runner.CustomOptionsTestRunner',