5

以下问题是由这篇文章中的讨论引发的。

假设有两个文件(foobar.pyfoobar_unittest.py)。文件foobar.py包含一个具有两个函数(foobar )的类( FooBar)。函数bar引发内置异常,函数foo引发用户定义异常。

# foobar.py
class MyException(Exception):
    pass
class FooBar:
    def __init__(self):
        pass
    def bar(self):
        raise ValueError('Hello World.')
    def foo(self):
        raise MyException('Hello World.')

.

# foobar_unittest.py
import unittest
import foobar as fb
class MyException(Exception):
    pass
class FooBarTestCases(unittest.TestCase):
    def test_bar(self):
        with self.assertRaises(ValueError):
            fb.FooBar().bar()
    def test_foo(self):
        with self.assertRaises(MyException):
            fb.FooBar().foo()
if __name__ == '__main__':
    unittest.main()

foobar.py上运行单元测试时,为什么引发用户定义异常 ( foo ) 的函数无法通过测试?

>>> python2.7 foobar_unittest.py 
.E
======================================================================
ERROR: test_foo (__main__.FooBarTestCases)
----------------------------------------------------------------------
Traceback (most recent call last):
  File "foobar_unittest.py", line 11, in test_foo
    fb.FooBar().foo()
  File "/a_path/foobar.py", line 9, in foo
    raise MyException('Hello World.')
MyException: Hello World.

----------------------------------------------------------------------
Ran 2 tests in 0.000s

FAILED (errors=1)
4

2 回答 2

2

从 foobar 导入 MyException,不要重新定义它。

import unittest
from foobar import MyException
import foobar as fb

class FooBarTestCases(unittest.TestCase):
    def test_bar(self):
        with self.assertRaises(ValueError):
            fb.FooBar().bar()
    def test_foo(self):
        with self.assertRaises(MyException):
            fb.FooBar().foo()
if __name__ == '__main__':
    unittest.main()

此代码现在应该可以作为

..
----------------------------------------------------------------------
Ran 2 tests in 0.001s

OK
于 2016-02-18T19:44:40.750 回答
0

请注意,如果您使用reload导入异常,也会发生同样的情况(发生在我身上)。

在我的单元测试中,我有相关的导入,例如

from importlib import reload
import foobar
reload(foobar)
from foobar import MyException

无论出于何种原因,这也不起作用。写这个就像

from foobar import MyException

将工作。然后,当然,您必须自己重新加载模块。

如果您想知道我为什么要使用重新加载:如何卸载(重新加载)Python 模块?.

于 2021-11-06T08:27:29.273 回答