以下问题是由这篇文章中的讨论引发的。
假设有两个文件(foobar.py 和 foobar_unittest.py)。文件 foobar.py 包含一个具有两个函数(foo和bar)的类(FooBar)。函数栏引发内置异常,函数引发用户定义的异常。
# 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)
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
,如果您使用reload
导入异常,也会发生同样的情况(发生在我身上)。
在我的单元测试中,我有相关的导入,例如
from importlib import reload
import foobar
reload(foobar)
from foobar import MyException
无论出于何种原因,这也行不通。 写这个就像
from foobar import MyException
会工作。然后,当然,您必须自己重新加载模块。
如果您想知道我为什么要使用 reload:如何卸载(重新加载)Python 模块?