繁体   English   中英

在Python单元测试中模拟输入时输出为空

[英]Output is empty when mocking input in Python Unit Test

所以我已经有一段时间这个问题了,找不到解决方案。我有这个非常基本的运行代码。 当我使用side_effects模拟输入时,我想测试预期的输出"TEST" 第一次调用输入函数时,我模拟了'y' ,然后第二次调用时模拟了'1' ,然后应触发print语句。 问题是返回的输出为空。 我不知道发生了什么,但是当我手动运行main方法并输入输入时,我得到了预期的输出,因此我知道运行代码可以按预期工作,但是在测试过程中有些时髦。

这是我的运行代码

def main():

    newGame = input("")

    if newGame == 'y':
        print("1.Scallywag\n2.Crew\n3.Pirate")

        difficulty = input("")

        if difficulty == '1':
            print("TEST")


main()

这是我的测试代码

import unittest
from unittest.mock import patch
import io
import sys

from Run import main

class MyTestCase(unittest.TestCase):

    @patch('builtins.input', side_effects=['y','1'])
    def test_output(self,m):
      saved_stdout = sys.stdout
      try:
          out = io.StringIO()
          sys.stdout = out
          main()
          output = out.getvalue().strip()
          self.assertIn("TEST", output)
      finally:
          sys.stdout = saved_stdout


if __name__ == "__main__":
  unittest.main()

这是我与追溯一起返回的AssertionError ,请注意,它不是期望的""

F
======================================================================
FAIL: test_output (__main__.MyTestCase)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "C:\Python33\lib\unittest\mock.py", line 1087, in patched
    return func(*args, **keywargs)
  File "C:\Users\jsalce\Desktop\Testcases\Test.py", line 20, in test_output
    self.assertIn("TEST", output)
AssertionError: 'TEST' not found in ''

----------------------------------------------------------------------
Ran 1 test in 0.006s

FAILED (failures=1)

谢谢大家

Print("String", file=out)

这是您想要的,但是您需要传递给main。

您为输入打补丁无法按要求工作,因为您没有给它打功能。 尝试这个:

import unittest
from unittest.mock import patch, MagicMock
import io
import sys

from Run import main

class MyTestCase(unittest.TestCase):

    #@patch('builtins.input', side_effects=['y','1'])
    @patch('builtins.input', MagicMock(side_effect=['y','1']))
    def test_output(self):
      saved_stdout = sys.stdout
      try:
          out = io.StringIO()
          sys.stdout = out
          main()
          output = out.getvalue().strip()
          self.assertIn("TEST", output)
          #I used equals to see if I am truly grabbing the stdout
          #self.assertEquals("TEST", output)
      finally:
          sys.stdout = saved_stdout

if __name__ == "__main__":
  unittest.main(verbosity=2)

而且,您在test_output签名中不需要变量'm'。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM