我有一个名为test_web.py的文件,其中包含一个类TestWeb和许多名为test_something()的方法。
我可以像这样做每一个测试:
$ nosetests test_web.py
...
======================================================================
FAIL: checkout test
----------------------------------------------------------------------
Traceback (most recent call last):
File "/Users/me/path/here/test_web.py", line 187, in test_checkout
...
但我似乎不能进行单独的测试。当在同一个PWD中运行时,它们会给我“没有这样的测试”错误:
$ nosetests test_web.py:test_checkout
$ nosetests TestWeb:test_checkout
这里可能有什么问题?
也可以指定模块:
您必须这样指定:
nosetests <file>:<Test_Case>.<test_method>
,或者见the docs
像其他答案建议的那样在命令行上指定名称确实有用。然而,当我正在编写测试时,我经常发现我只想运行我正在进行的测试,而且我必须在命令行中编写的名称会变得非常长和繁琐。在这种情况下,我更喜欢使用自定义的decorator和flag。
我定义
wipd
(“正在工作的装饰器”)如下:这将定义一个decorator
@wipd
,该decorator将对其所修饰的对象设置wip
属性。例如:然后,可以在命令行使用
-a wip
,将测试的执行范围缩小到标有@wipd
的测试。关于姓名的说明…
我使用装饰器的名称
@wipd
,而不是@wip
来避免此类问题:import
将使wip
装饰程序成为类的成员,并且将选择类中的所有测试。attrib
插件检查测试方法的父类,以查看所选属性是否也存在,并且由attrib
创建和测试的属性不存在于隔离空间中。因此,如果使用-a foo
进行测试,并且类包含foo = "platypus"
,则该插件将选择类中的所有测试。相关问题 更多 >
编程相关推荐