断言定义
熟悉单元测试的同学都知道在测试用例中,执行完测试用例后,通过断言(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老师一起,每天进步一点点,终会质变!让你面试拿高薪!
标签:logging,断言,自定义,my,equal,自动化,日志,True From: https://blog.51cto.com/liwen629/7622144