标签:红色 word 支持 bsp 要求 ima inf 测试用例 login
ddt源码中有个函数用来生成用例名称, mk_test_name
它接收两个参数:name 和 value.
name:为测试用例的名字。即test_api.
value:为测试数据,ddt是处理一组测试数据。而这个value就是这一组数据中的每一个测试数据。
对value的值是有限制的:要么就是单值变量,要么就是元组或者列表并且要求元组和列表中的数据都是单值变量。如("name","port") 、["name","port"]
如果传进来的测试数据,不符合value的要求,那么测试用例名字为:name_index。
如果传进来的测试数据,符合value的要求,那么测试用例名字为:name_index_value。如果value为列表或者元组,那么将列表/元组的每个数据依次追加在末尾。
比如传进来的name值为test_login,value值为["name","port"]
。那最终的测试用例名字是:test_login_01_name_port。
如果传进来的name值为test_login,value值为{"userName":"18500384561", "password":"123456"},
那最终的测试用例名字为:test_login_1。 因为它不支持对字典类型的数据处理 。
而我的接口自动化框架中,ddt处理的数据是一列表:列表当中每个数据都为字典。ddt一遍历整个列表,那传给value的值刚好是字典。。
所以我得到的测试用例名称就是:test_login_1,test_login_2,test_login_3
处理方法:
1. 在ddt中添加对字典dict的处理,如果字典中有case_name字段,则将字典中键名为case_name的值作为测试用例名称中的value值。
2. 在ddt中添加对列表list的处理,则将列表中某一列的值作为测试用例名称中的value值。
修改后的ddt源码为(红色部分为修改的内容):
修改后输出测试报告用例名称为:
Excel测试数据 :
标签:红色 word 支持 bsp 要求 ima inf 测试用例 login
原文地址:https://www.cnblogs.com/xioawu-blog/p/12940749.html