自定义断言的实现方法

作者: 测试开发Kevin | 来源:发表于2020-05-23 15:44 被阅读0次

    断言定义

    熟悉单元测试的同学都知道在测试用例中,执行完测试用例后,通过断言(assert)判断测试结果是pass还是fail。不同的单元测试框架都提供了断言机制,我们这里以python为例进行说明。Python中的断言类型丰富,最常用的是基础断言和集合断言。基础断言包括的核心方法如下所示,主要功能是对两个值进行比较。

    集合断言包括的核心方法如下所示,主要功能是对多个值进行比较。

    自定义断言基础编码

    我们可以使用 ‘==’来判断两个对象的值是否相等,进而打造我们自己的断言函数。核心代码如下:

    def my_equal(p_a,p_b):

          if p_a==p_b:

              return True

          else:

              return False

    我们可以输入不同的参数进行测试

    print(my_equal('a',123)) 显示False

    print(my_equal('a', b')) 显示False

    print(my_equal('a', a')) 显示True

    print(my_equal(True,True)) 显示True

    l1=[1,2,3]

    l2=[1,2,3]

    print(my_equal(l1,l2)) 显示True

    可以看到这个简单的方法就解决了单值和多值的比较操作!

    自定义断言扩展

    因为my_equal方法是我们自己定义的方法,我们就可以对其进行扩展,比如可以把比较结果写入一个日志中!我们可以使用python的logging模块解决该问题,核心代码如下:

    import logging  # 引入logging模块

    logging.basicConfig(level=logging.DEBUG, #设置日志级别

    filename='report.log', #设置日志输出到当前py文件的report.log中

    format='%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s')  # logging.basicConfig函数对日志的输出

    修改my_equal源码,增加日志写入功能,代码如下:

    def my_equal(p_a,p_b):

          if p_a==p_b:

              logging.info(str(p_a)+'等于'+str(p_b)+'\n')#写入日志

              return True

          else:

               logging.error(str(p_a) + '不等于' + str(p_b)+'\n') #写入日志

               return False

    在此调用my_equal方法,会在report.log中输出如下内容:

    2020-05-19 15:11:10,017 - case_demo.py[line:13] - ERROR: a不等于123

    2020-05-19 15:11:10,028 - case_demo.py[line:13] - ERROR: a不等于<__main__.A object at 0x0000024D174D97C8>

    2020-05-19 15:11:10,028 - case_demo.py[line:10] - INFO: True等于True

    2020-05-19 15:11:10,028 - case_demo.py[line:10] - INFO: [1, 2, 3]等于[1, 2, 3]

    以上就是把测试校验结果写入日志的核心方法,大家也可以对其进行扩展,把日志写入到html文件中,然后在加上漂亮的样式来打造自己的测试报告,这里只是抛砖引玉,有兴趣的同学可以自己进行实践!

    总结

    现在会编码已经成了测试人员的必备技能,但是测试人员平时又很少有编码的机会,所以我们要在实际工作中自己发现可以通过编码来提升效率的点,然后不断的实践和完善,慢慢的大家的代码能力就会得到显著提升。还是那句话,代码是写出来的,所以大家一定要多动手!原创不易,如果文章帮到了你,欢迎转发,让更多的朋友受益!跟着Kevin老师一起,每天进步一点点,终会质变!让你面试拿高薪!

    相关文章

      网友评论

        本文标题:自定义断言的实现方法

        本文链接:https://www.haomeiwen.com/subject/nsflahtx.html