洁婕 发表于 2022-7-22 16:46:41

pytest --duration重复展示test用例的用时情况

本帖最后由 洁婕 于 2022-7-22 16:49 编辑


代码:
import pytest
import time

class Test_ABC:
    def setup_class(self):
      print('-------->setup_class')

    def teardown_class(self):
      print('------>teardown_class')

   def test_c(self):
      print('------>test_c')
      time.sleep(0.1)
      assert 1

    @pytest.mark.parametrize('data', )
    def test_b(self,data):
      print('------>test_b')
      #pdb.set_trace()#程序运行到这里会暂停
      time.sleep(data*0.1)
      assert data%2==1

运行:
import pytest

if __name__ == '__main__':
    pytest.main(['-s','test_parametrize.py','--durations=4','-v'])#筛选出运行时间最慢的4条用例

结果:结果是展示了4条最慢的用例,但是是最慢前两条的重复展示。求助:我想解决重复展示的问题,我不知道原因在哪里

suchocolate 发表于 2022-7-23 18:02:33

看起来像有rerun, 把整体运行后输出贴一下,FAILED test_parametrize.py 下面应该还有内容。

洁婕 发表于 2022-7-25 15:25:03

suchocolate 发表于 2022-7-23 18:02
看起来像有rerun, 把整体运行后输出贴一下,FAILED test_parametrize.py 下面应该还有内容。

结果只有两个test结果是没问题的,不知道为啥展示的时候重复展示了

suchocolate 发表于 2022-7-25 16:08:46

洁婕 发表于 2022-7-25 15:25
结果只有两个test结果是没问题的,不知道为啥展示的时候重复展示了

奇怪,是不是有别的log系统干扰了。
我这运行你的代码正常的,两条输出。
页: [1]
查看完整版本: pytest --duration重复展示test用例的用时情况