mirror of
https://github.com/django/django.git
synced 2025-01-14 12:27:24 +00:00
[4.2.x] Fixed #34259 -- Passed called_from_command_line to command subparsers.
Backport of 017fa23d3b
from main
This commit is contained in:
parent
db0e10c037
commit
beaa5f31e1
@ -6,6 +6,7 @@ import argparse
|
|||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
from argparse import ArgumentParser, HelpFormatter
|
from argparse import ArgumentParser, HelpFormatter
|
||||||
|
from functools import partial
|
||||||
from io import TextIOBase
|
from io import TextIOBase
|
||||||
|
|
||||||
import django
|
import django
|
||||||
@ -71,6 +72,15 @@ class CommandParser(ArgumentParser):
|
|||||||
else:
|
else:
|
||||||
raise CommandError("Error: %s" % message)
|
raise CommandError("Error: %s" % message)
|
||||||
|
|
||||||
|
def add_subparsers(self, **kwargs):
|
||||||
|
parser_class = kwargs.get("parser_class", type(self))
|
||||||
|
if issubclass(parser_class, CommandParser):
|
||||||
|
kwargs["parser_class"] = partial(
|
||||||
|
parser_class,
|
||||||
|
called_from_command_line=self.called_from_command_line,
|
||||||
|
)
|
||||||
|
return super().add_subparsers(**kwargs)
|
||||||
|
|
||||||
|
|
||||||
def handle_default_options(options):
|
def handle_default_options(options):
|
||||||
"""
|
"""
|
||||||
|
13
tests/user_commands/management/commands/subparser_vanilla.py
Normal file
13
tests/user_commands/management/commands/subparser_vanilla.py
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
import argparse
|
||||||
|
|
||||||
|
from django.core.management.base import BaseCommand
|
||||||
|
|
||||||
|
|
||||||
|
class Command(BaseCommand):
|
||||||
|
def add_arguments(self, parser):
|
||||||
|
subparsers = parser.add_subparsers(parser_class=argparse.ArgumentParser)
|
||||||
|
parser_foo = subparsers.add_parser("foo")
|
||||||
|
parser_foo.add_argument("bar", type=int)
|
||||||
|
|
||||||
|
def handle(self, *args, **options):
|
||||||
|
pass
|
@ -468,6 +468,30 @@ class CommandRunTests(AdminScriptTestCase):
|
|||||||
self.assertNoOutput(err)
|
self.assertNoOutput(err)
|
||||||
self.assertEqual(out.strip(), "Set foo")
|
self.assertEqual(out.strip(), "Set foo")
|
||||||
|
|
||||||
|
def test_subparser_error_formatting(self):
|
||||||
|
self.write_settings("settings.py", apps=["user_commands"])
|
||||||
|
out, err = self.run_manage(["subparser", "foo", "twelve"])
|
||||||
|
self.maxDiff = None
|
||||||
|
self.assertNoOutput(out)
|
||||||
|
err_lines = err.splitlines()
|
||||||
|
self.assertEqual(len(err_lines), 2)
|
||||||
|
self.assertEqual(
|
||||||
|
err_lines[1],
|
||||||
|
"manage.py subparser foo: error: argument bar: invalid int value: 'twelve'",
|
||||||
|
)
|
||||||
|
|
||||||
|
def test_subparser_non_django_error_formatting(self):
|
||||||
|
self.write_settings("settings.py", apps=["user_commands"])
|
||||||
|
out, err = self.run_manage(["subparser_vanilla", "foo", "seven"])
|
||||||
|
self.assertNoOutput(out)
|
||||||
|
err_lines = err.splitlines()
|
||||||
|
self.assertEqual(len(err_lines), 2)
|
||||||
|
self.assertEqual(
|
||||||
|
err_lines[1],
|
||||||
|
"manage.py subparser_vanilla foo: error: argument bar: invalid int value: "
|
||||||
|
"'seven'",
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class UtilsTests(SimpleTestCase):
|
class UtilsTests(SimpleTestCase):
|
||||||
def test_no_existent_external_program(self):
|
def test_no_existent_external_program(self):
|
||||||
|
Loading…
Reference in New Issue
Block a user