所以我们知道装饰器顺序很重要,但这些都不起作用:
@it.should('do something')
@mock.patch('datetime.date')
@mock.patch('datetime.time')
def test_1(date, time, case):
pass
@mock.patch('datetime.time')
@mock.patch('datetime.date')
@it.should('do something')
def test_2(case, date, time):
pass
因为方式patch
而should
被执行。两个库都对最终的修饰函数做了一些假设,因此不可能直接将修饰结果从一个传递到另一个。
但是我们可以使用“适配器”装饰器从外部修复它:
import mock
import nose2.tools
def fix_case(f):
def test(case):
f(case=case)
return test
with nose2.tools.such.A('system') as it:
@it.should('do something')
@fix_case
@mock.patch('datetime.time')
@mock.patch('datetime.date')
def test_3(date, time, case=None):
print(date, time, case)
it.createTests(globals())
现在这有效并导致:
$ nose2 -v
test 0000: should do something (tests.test_nose2_such.A system) ...
(<MagicMock name='date' id='4334752592'>, <MagicMock name='time' id='4334762000'>,
<tests.test_nose2_such.A system testMethod=test 0000: should do something>)
ok
----------------------------------------------------------------------
Ran 1 test in 0.001s
OK
这是相当快速和肮脏的,但可以完成工作。我会看看我是否可以改进这一点并让它变得更好。