summaryrefslogtreecommitdiff
path: root/tests/user_commands
diff options
context:
space:
mode:
Diffstat (limited to 'tests/user_commands')
-rw-r--r--tests/user_commands/management/commands/required_option.py11
-rw-r--r--tests/user_commands/tests.py12
2 files changed, 23 insertions, 0 deletions
diff --git a/tests/user_commands/management/commands/required_option.py b/tests/user_commands/management/commands/required_option.py
new file mode 100644
index 0000000000..3b30ed942e
--- /dev/null
+++ b/tests/user_commands/management/commands/required_option.py
@@ -0,0 +1,11 @@
+from django.core.management.base import BaseCommand
+
+
+class Command(BaseCommand):
+
+ def add_arguments(self, parser):
+ parser.add_argument('-n', '--need-me', required=True)
+ parser.add_argument('-t', '--need-me-too', required=True, dest='needme2')
+
+ def handle(self, *args, **options):
+ self.stdout.write(','.join(options))
diff --git a/tests/user_commands/tests.py b/tests/user_commands/tests.py
index 3900a58247..ae05bcfe25 100644
--- a/tests/user_commands/tests.py
+++ b/tests/user_commands/tests.py
@@ -194,6 +194,18 @@ class CommandTests(SimpleTestCase):
with self.assertRaisesMessage(TypeError, msg):
management.call_command('dance', unrecognized=1, unrecognized2=1)
+ def test_call_command_with_required_parameters_in_options(self):
+ out = StringIO()
+ management.call_command('required_option', need_me='foo', needme2='bar', stdout=out)
+ self.assertIn('need_me', out.getvalue())
+ self.assertIn('needme2', out.getvalue())
+
+ def test_call_command_with_required_parameters_in_mixed_options(self):
+ out = StringIO()
+ management.call_command('required_option', '--need-me=foo', needme2='bar', stdout=out)
+ self.assertIn('need_me', out.getvalue())
+ self.assertIn('needme2', out.getvalue())
+
class CommandRunTests(AdminScriptTestCase):
"""