假设我们有这样的东西:
import py, pytest
ERROR1 = ' --- Error : value < 5! ---'
ERROR2 = ' --- Error : value > 10! ---'
class MyError(Exception):
def __init__(self, m):
self.m = m
def __str__(self):
return self.m
def foo(i):
if i < 5:
raise MyError(ERROR1)
elif i > 10:
raise MyError(ERROR2)
return i
# ---------------------- TESTS -------------------------
def test_foo1():
with pytest.raises(MyError) as e:
foo(3)
assert ERROR1 in str(e)
def test_foo2():
with pytest.raises(MyError) as e:
foo(11)
assert ERROR2 in str(e)
def test_foo3():
....
foo(7)
....
问:如何使test_foo3()进行测试,但不会引发MyError?很明显,我可以测试一下:
def test_foo3():
assert foo(7) == 7
但我想通过pytest.raises()进行测试。有可能吗?例如:在某种情况下,该函数“ foo”根本没有返回值,
def foo(i):
if i < 5:
raise MyError(ERROR1)
elif i > 10:
raise MyError(ERROR2)
恕我直言,以这种方式进行测试可能很有意义。
foo(7)
很好。您将获得正确的消息,并且使用所有pytest输出进行调试将更加容易。您从@Faruk('Unexpected error...'
)强制执行的建议对该错误一无所获,您将陷入困境。要使它变得更好,唯一可以做的就是说出自己的意图test_foo3_works_on_integers_within_range()
。