mirror of
https://github.com/django/django.git
synced 2024-12-22 00:55:44 +00:00
Fixed #36016 -- Prevented traceback when quitting makemigrations with Ctrl-C.
This commit is contained in:
parent
3ee4c6a27a
commit
f05edb2b43
@ -111,17 +111,19 @@ class InteractiveMigrationQuestioner(MigrationQuestioner):
|
||||
for i, choice in enumerate(choices):
|
||||
self.prompt_output.write(" %s) %s" % (i + 1, choice))
|
||||
self.prompt_output.write("Select an option: ", ending="")
|
||||
result = input()
|
||||
while True:
|
||||
try:
|
||||
result = input()
|
||||
value = int(result)
|
||||
except ValueError:
|
||||
pass
|
||||
except KeyboardInterrupt:
|
||||
self.prompt_output.write("\nCancelled.")
|
||||
sys.exit(1)
|
||||
else:
|
||||
if 0 < value <= len(choices):
|
||||
return value
|
||||
self.prompt_output.write("Please select a valid option: ", ending="")
|
||||
result = input()
|
||||
|
||||
def _ask_default(self, default=""):
|
||||
"""
|
||||
@ -148,7 +150,11 @@ class InteractiveMigrationQuestioner(MigrationQuestioner):
|
||||
else:
|
||||
prompt = ">>> "
|
||||
self.prompt_output.write(prompt, ending="")
|
||||
try:
|
||||
code = input()
|
||||
except KeyboardInterrupt:
|
||||
self.prompt_output.write("\nCancelled.")
|
||||
sys.exit(1)
|
||||
if not code and default:
|
||||
code = default
|
||||
if not code:
|
||||
|
@ -85,8 +85,9 @@ class QuestionerHelperMethodsTests(SimpleTestCase):
|
||||
|
||||
@mock.patch("builtins.input", side_effect=[KeyboardInterrupt()])
|
||||
def test_questioner_no_default_keyboard_interrupt(self, mock_input):
|
||||
with self.assertRaises(KeyboardInterrupt):
|
||||
with self.assertRaises(SystemExit):
|
||||
self.questioner._ask_default()
|
||||
self.assertIn("Cancelled.\n", self.prompt.getvalue())
|
||||
|
||||
@mock.patch("builtins.input", side_effect=["", "n"])
|
||||
def test_questioner_no_default_no_user_entry_boolean(self, mock_input):
|
||||
@ -105,3 +106,18 @@ class QuestionerHelperMethodsTests(SimpleTestCase):
|
||||
expected_msg = f"{question}\n" f" 1) a\n" f" 2) b\n" f" 3) c\n"
|
||||
self.assertIn(expected_msg, self.prompt.getvalue())
|
||||
self.assertEqual(value, 1)
|
||||
|
||||
@mock.patch("builtins.input", side_effect=[KeyboardInterrupt()])
|
||||
def test_questioner_no_choice_keyboard_interrupt(self, mock_input):
|
||||
question = "Make a choice:"
|
||||
with self.assertRaises(SystemExit):
|
||||
self.questioner._choice_input(question, choices="abc")
|
||||
expected_msg = (
|
||||
f"{question}\n"
|
||||
f" 1) a\n"
|
||||
f" 2) b\n"
|
||||
f" 3) c\n"
|
||||
f"Select an option: \n"
|
||||
f"Cancelled.\n"
|
||||
)
|
||||
self.assertIn(expected_msg, self.prompt.getvalue())
|
||||
|
Loading…
Reference in New Issue
Block a user