Mit unittest.mock patch input() in Python 3
Wie verwenden Sie das @ - patch Dekorator patch der eingebauten input () - Funktion?
Zum Beispiel, hier ist eine Funktion in question.py das würde ich gerne testen, das enthält einen call-to input():
def query_yes_no(question, default="yes"):
""" Adapted from http://stackoverflow.com/questions/3041986/python-command-line-yes-no-input """
valid = {"yes": True, "y": True, "ye": True, "no": False, "n": False}
if default is None:
prompt = " [y/n] "
elif default == "yes":
prompt = " [Y/n] "
elif default == "no":
prompt = " [y/N] "
else:
raise ValueError("invalid default answer: '%s'" % default)
while True:
sys.stdout.write(question + prompt)
choice = input().lower()
if default is not None and choice == '':
return valid[default]
elif choice in valid:
return valid[choice]
else:
sys.stdout.write("Please respond with 'yes' or 'no' "
"(or 'y' or 'n').\n")
Hier mein test, die gibt mir den Fehler "ImportError: No module named 'gelieferten'":
import unittest
from unittest.mock import patch
import question
class TestQueryYesNo(unittest.TestCase):
@patch('__builtins__.input.return_value', 'y')
def test_query_y(self):
answer = question.query_yes_no("Blah?")
self.assertTrue(answer)
Du musst angemeldet sein, um einen Kommentar abzugeben.
__builtin__ Modul wird umbenannt in gelieferten in Python 3. Ersetzen Sie wie folgt:
UPDATE
input
hat einen optionalen parameter. aktualisiert den code zu akzeptieren optionale parameter.@patch('builtins.input', lambda _ : 'y')
input
's argument ist optional; so habe ich*args
statt_
.Oder verwenden Sie Mock
return_value
Attribut. Ich konnte es nicht zu der Arbeit als Dekorateur, aber hier ist, wie tun Sie es mit einem context-manager:Für Python 2.x:
arbeitete für mich.