断言定义

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

 

自动化测试中自定义断言的实现方法_测试用例

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

 

自动化测试中自定义断言的实现方法_python_02

自定义断言基础编码

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

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老师一起,每天进步一点点,终会质变!让你面试拿高薪!