• python修改unittestreport中的用例条数


    背景: 自动化框架中使用yaml文件作为数据配置,使用ddt作为数据驱动来运行测试用例,由于测试用例都是基于场景去编写,目前都是一个测试类算是一条测试用例,但基于测试报告里面一个类运行的测试方法有多个,因此统计的测试用例数算的是test方法执行的次数,统计为多条

    1.unittestreport的安装

    pip install unittestreport

    2.unittestreport的使用

    编写一个run.py,将测试用例加载到suite中,使用runner运行

    1. import unittest
    2. import unittestreport
    3. suite = unittest.defaultTestLoader.discover(r'D:\workspace\pytest_project\debug',pattern='huge_test*.py')
    4. # 2、创建一个用例运行程序
    5. runner = unittestreport.TestRunner(suite,
    6. tester='虎哥',
    7. filename="test",
    8. report_dir=".",
    9. title='自动化测试报告',
    10. desc='测试报告',
    11. templates=2
    12. )
    13. # 3、运行测试用例
    14. runner.run()

    3.修改unittestreport中的源码,主要是testResult.py文件

    在TestResult类下面添加self.fail_case=[],用来添加失败测试类

    1. class TestResult(unittest.TestResult):
    2. def __init__(self):
    3. super().__init__()
    4. self.fields = {
    5. "success": 0,
    6. "all": 0,
    7. "fail": 0,
    8. "skip": 0,
    9. "error": 0,
    10. "begin_time": "",
    11. "results": [],
    12. "testClass": set()
    13. }
    14. self.sys_stdout = None
    15. self.sys_stderr = None
    16. self.outputBuffer = None
    17. self.fail_case = []

    修改stopTestRun方法,重新定义success,fail,all的用例总数

    1. def stopTestRun(self, title=None):
    2. # self.fields['fail'] = len(self.failures)
    3. self.fields['error'] = len(self.errors)
    4. self.fields['skip'] = len(self.skipped)
    5. # self.fields['all'] = sum(
    6. # [self.fields['fail'], self.fields['error'], self.fields['skip'],
    7. #self.fields['success']])
    8. self.fields['testClass'] = list(self.fields['testClass'])
    9. #修改用例总数为class的数目
    10. self.fields['all'] = len(list(self.fields['testClass']))
    11. new_list = []
    12. for i in self.fail_case:
    13. new_list.append(list(i)[0])
    14. #修改失败用例数为class失败的数目
    15. self.fields['fail'] = len(set(new_list))
    16. #修改成功用例数为总数-失败数
    17. self.fields['success'] = self.fields['all'] - self.fields['fail']

    修改addFailure方法,添加self.fail_case.append(self.fields['testClass'])

    1. def addFailure(self, test, err):
    2. super().addFailure(test, err)
    3. self.fail_case.append(self.fields['testClass'])
    4. logs = []
    5. test.state = '失败'
    6. sys.stderr.write("{}执行——>【失败】\n".format(test))
    7. output = self.complete_output()
    8. logs.append(output)
    9. logs.extend(traceback.format_exception(*err))
    10. test.run_info = logs

    4.如下图,执行了2个测试类,运行了4个测试方法,有1个测试方法执行失败,测试条数总数统计为2,失败数为1,成功数为1

  • 相关阅读:
    Linux脚本:将.sh文件输出映射到日志文件并添加时间戳
    [附源码]SSM计算机毕业设计“拥抱爱心”公益网站管理系统JAVA
    TrOCR模型微调【基于transformer的光学字符识别】
    Android仿QQ消息拖拽效果(二)
    表驱动法在STM32中的应用
    PPT文件不能编辑的情况总结
    一文看够,植物线粒体基因组分析套路
    GO请求参数规则校验(自定义校验规则、规则中文化)
    python处理kitti激光雷达数据
    云原生|kubernetes |kubelet服务加入系统守护进程supervisor(centos7系统下演示通过)
  • 原文地址:https://blog.csdn.net/meisailor/article/details/133581669