我查看了--with-timer
和--with-profile
来分析我的测试,但这些选项要么提供的信息太少或信息太多。
示例,如果我有以下测试:
def test_foo():
do_something()
do_something_else()
我只想分析每个函数调用或测试中每一行所花费的时间。所以输出将是这样的:
do_something() : .5 seconds
do_something_else() : .5 seconds
test_foo() : 1 seconds
答案 0 :(得分:1)
受此talk的启发,您可以使用Xunit插件并对其xml进行后期处理
使用--with-xunit和以下代码来处理nosetests.xml
from xml.etree.cElementTree import parse
from operator import itemgetter
elems = parse(open("nosetests.xml")).getiterator("testcase")
tests = sorted(((e.get("name"), int(e.get("time"))) for e in elems),
key=itemgetter(1), reverse=1)
for test in (test for test in tests if test[1]):
print "%s: %s sec" % test