mirror of
https://github.com/django/django.git
synced 2024-12-01 15:42:04 +01:00
f2b6763ad7
Moved sys.exit(1) so as failing management commands reach it only when running from command line.
47 lines
1.6 KiB
Python
47 lines
1.6 KiB
Python
import sys
|
|
from StringIO import StringIO
|
|
|
|
from django.core import management
|
|
from django.core.management.base import CommandError
|
|
from django.test import TestCase
|
|
from django.utils import translation
|
|
|
|
|
|
class CommandTests(TestCase):
|
|
def test_command(self):
|
|
out = StringIO()
|
|
management.call_command('dance', stdout=out)
|
|
self.assertEqual(out.getvalue(),
|
|
"I don't feel like dancing Rock'n'Roll.\n")
|
|
|
|
def test_command_style(self):
|
|
out = StringIO()
|
|
management.call_command('dance', style='Jive', stdout=out)
|
|
self.assertEqual(out.getvalue(),
|
|
"I don't feel like dancing Jive.\n")
|
|
|
|
def test_language_preserved(self):
|
|
out = StringIO()
|
|
with translation.override('fr'):
|
|
management.call_command('dance', stdout=out)
|
|
self.assertEqual(translation.get_language(), 'fr')
|
|
|
|
def test_explode(self):
|
|
""" Test that an unknown command raises CommandError """
|
|
self.assertRaises(CommandError, management.call_command, ('explode',))
|
|
|
|
def test_system_exit(self):
|
|
""" Exception raised in a command should raise CommandError with
|
|
call_command, but SystemExit when run from command line
|
|
"""
|
|
with self.assertRaises(CommandError):
|
|
management.call_command('dance', example="raise")
|
|
old_stderr = sys.stderr
|
|
sys.stderr = err = StringIO()
|
|
try:
|
|
with self.assertRaises(SystemExit):
|
|
management.ManagementUtility(['manage.py', 'dance', '--example=raise']).execute()
|
|
finally:
|
|
sys.stderr = old_stderr
|
|
self.assertIn("CommandError", err.getvalue())
|