BSTestRunner增加历史执行记录展示和重试功能

简介: 之前对于用例的失败重试,和用例的历史测试记录存储展示做了很多的描述呢,但是都是基于各个项目呢,不方便使用,为了更好的使用,我们对这里进行抽离,抽离出来一个单独的模块,集成到BSTestRunner中,以后我们使用BSTestRunner直接就可以使用里面的失败重试和展示历史记录了。

首先呢,我们对于失败重试做了一个简单的调整。


在BSTestRunner 增加之前的重试代码


TestResult = unittest.TestResult
class MyResult(TestResult):
    def __init__(self, verbosity=1, trynum=1):
        # 默认次数是0
        TestResult.__init__(self)
        self.outputBuffer = StringIO()
        self.stdout0 = None
        self.stderr0 = None
        self.success_count = 0
        self.failure_count = 0
        self.error_count = 0
        self.verbosity = verbosity
        self.trynnum = trynum
        self.result = []
        self.trys = 0  #
        self.istry = False
    def startTest(self, test):
        TestResult.startTest(self, test)
        self.stdout0 = sys.stdout
        self.stderr0 = sys.stderr
    def complete_output(self):
        if self.stdout0:
            sys.stdout = self.stdout0
            sys.stderr = self.stderr0
            self.stdout0 = None
            self.stderr0 = None
        return self.outputBuffer.getvalue()
    def stopTest(self, test):
        # 判断是否要重试
        if self.istry is True:
            # 如果执行的次数小于重试的次数 就重试
            if self.trys < self.trynnum:
                # 删除最后一个结果
                reslut = self.result.pop(-1)
                # 判断结果,如果是错误就把错误的个数减掉
                # 如果是失败,就把失败的次数减掉
                if reslut[0] == 1:
                    self.failure_count -= 1
                else:
                    self.error_count -= 1
                sys.stderr.write('{}:用例正在重试中。。。'.format(test.id()) + '\n')
                # 深copy用例
                test = copy.copy(test)
                # 重试次数增加+1
                self.trys += 1
                # 测试
                test(self)
            else:
                self.istry = False
                self.trys = 0
        self.complete_output()
    def addSuccess(self, test):
        # 成功就不要重试
        self.istry = False
        self.success_count += 1
        TestResult.addSuccess(self, test)
        output = self.complete_output()
        self.result.append((0, test, output, ''))
        if self.verbosity > 1:
            sys.stderr.write('ok ')
            sys.stderr.write(str(test))
            sys.stderr.write('\n')
        else:
            sys.stderr.write('.')
    def addError(self, test, err):
        # 重试+1,错误次数+1
        self.istry = True
        self.error_count += 1
        TestResult.addError(self, test, err)
        _, _exc_str = self.errors[-1]
        output = self.complete_output()
        self.result.append((2, test, output, _exc_str))
        if self.verbosity > 1:
            sys.stderr.write('E  ')
            sys.stderr.write(str(test))
            sys.stderr.write('\n')
        else:
            sys.stderr.write('E')
    def addFailure(self, test, err):
        self.istry = True
        TestResult.startTestRun(self)
        self.failure_count += 1
        TestResult.addFailure(self, test, err)
        _, _exc_str = self.failures[-1]
        output = self.complete_output()
        self.result.append((1, test, output, _exc_str))
        if self.verbosity > 1:
            sys.stderr.write('F  ')
            sys.stderr.write(str(test))
            sys.stderr.write('\n')
        else:
            sys.stderr.write('F')
    def stop(self) -> None:
        pass


参数默认增加了默认参数。历史数据,我们在代码中,调整中增加了存储功能,我们默认存在txt文档中。我们看下存储和读取的方法。


name=os.path.join(self.filepath,self.stopTime.strftime('%Y_%m_%d_%H_%M_%S')+'.txt')
with open(name,'w+') as f:
      f.write(result.success_count.__str__()+"_"+result.error_count.__str__()+"_"+result.failure_count.__str__())
      f.close()


读取历史执行数据源


def   _readresult(self):
    namerun=[]
    faillist=[]
    success=[]
    error=[]
    for root,dirs,files in os.walk(self.filepath):
        for file in files:
            if file.endswith(".txt"):
                namerun.append(file.split(".")[0].split("/")[-1])
                with open(os.path.join(root,file),'r') as f:
                    reslut=f.readline().split('\n')[0].split("_")
                    success.append(reslut[0])
                    error.append(reslut[1])
                    faillist.append(reslut[2])
    return namerun,faillist,success,error


我们在展示的时候使用了百度的echarts,官网如下。


           echarts.apache.org/zh/index.ht…


我们在测试报告中做了展示。(代码太长,我放在github上:BSTestRunner),我们写一段代码演示下。

 

import  unittest,os
from  BSTestRunner import  BSTestRunner
BASH_DIR="history"
report_path = os.path.join(BASH_DIR,"test.html")
openone = open(report_path, 'w+')
class  Clasee(unittest.TestCase):
    def setUp(self) -> None:
        pass
    def tearDown(self) -> None:
        pass
    def testoen(self):
        self.assertEqual(1,2)
if __name__=="__main__":
    besautiful = BSTestRunner(title="报告",
                              description="测试报告",
                              stream=openone,
                              trynum=2,#重试次数
                              filepath=BASH_DIR,#根目录
                              is_show=True)#是否展示。
    test_suit = unittest.TestSuite()
    test_suit.addTests([Clasee("testoen")])
    besautiful.run(test_suit)


我们看下结果。


image.png


   看下测试报告。


image.png


完成了我们之前的设想,单独抽离到了git项目中,我贴下仓库的链接。


       最后代码放在了github。


https://github.com/liwanlei/BSTestRunner_new
复制代码


如果访问过慢,可以访问码云


https://gitee.com/liwanlei/BSTestRunner_new




相关文章
|
28天前
|
缓存 监控 网络安全
因服务器时间不同步引起的异常
因服务器时间不同步引起的异常
70 1
|
7月前
|
Java 数据库连接 API
对象变更记录objectlog工具(持续跟新)
记录单个对象属性变化的日志工具,工具采用spring切面和mybatis拦截器相关技术编写了api依赖包,以非侵入方式实现对标记的对象属性进行记录,仅需要导入依赖即可,几乎不需要对原系统代码改动.
|
SQL Java Spring
如何查询已经执行过的流程信息?
如何查询已经执行过的流程信息?
|
程序员 测试技术 数据库
实战! 项目单据确认状态未更新排查
实战! 项目单据确认状态未更新排查
删除一段时间内的记录,关键在于删除时筛选条件确定删除范围
删除一段时间内的记录,关键在于删除时筛选条件确定删除范围
98 0
|
安全 Linux
5 种方法重复执行历史命令
5 种方法重复执行历史命令
233 0
|
关系型数据库 MySQL
有数据进行更新 没有进行新增 怎么操作
有数据进行更新 没有进行新增
306 0
|
存储 算法 安全
同步工具(未完待更新)
在JDK1.7中,同步工具主要包括CountDownLatch(一次性栅栏)、Semaphore(信号量)、CyclicBarrier(循环同步栅栏)、Exchanger(线程间交换器)和Phaser。下面的篇幅中,将依次讲述每种同步工具的概念、用法和原理。
97 0
|
搜索推荐 SEO
网站内容更新频率如何控制?网站内容更新注意事项
网站更新是每个站长必做的功课,当一个网站创建完成后,开始更新网站内容。 更新内容并不是说一个月时间内,把挖掘出来的内容、关键词全部一次性用上,这样的做法是错误的,搜索引擎是非常反感的。正确的做法是循序渐进的更新网站,不是像一台机器在采集,举个例子:个人博客今天发送3篇文稿,明天也3篇,后天还是一样3篇,天天坚持持续一段时间,是被搜索引擎认可的。
247 0