在设计自动化测试框架的时候,我们会经常将测试数据保存在外部的文件(如Excel、YAML、CSV),或者数据库中,实现脚本与数据解耦,方便后期维护。目前非常多的自动化测试框架采用通过Excel或者YAML文件直接编写测试用例,通过脚本读取出来驱动自动化测试代码执行。至于采用Excel还是YAML格式各位小伙伴都有不同见解,比如用Excel维护直观、修改数据方便,劣势是通过Git这样的版本控制工具不太好比较历史版本差异(因为是二进制格式);YAML的优势是支持数据格式完备、版本控制管理方便(文本格式),劣势是没有Excel这么直观。Excel这种方式大家比较熟悉了,本文带着大家来了解如何基于YAML设计自动化测试框架。
YAML格式测试用例设计
以接口自动化为例,用YAML编写测试用例要实现的基本功能需求:
- 一个YAML文件能够支持多个用例存储需求,不然几千个用例对应几千个YAML文件管理起来也受不了
- 用例中能够支持单接口测试用例也能支持业务场景用例(多个接口调用组合)
- 用例中需要包含所属模块、用例名、请求信息、断言信息、提取响应(实现接口关联)等信息
基于上述需求我们来设计一版YAML格式用例:
- casename: 登录成功
module: 用户模块
teststeps:
- name: 正确用户名、密码进行登录
request:
method: POST
url: /login
headers:
Content-Type: application/json
json:
username: lemon_auto
password: lemon123456
appType: 3
loginType: 0
extract:
token: access_token
validate:
- eq: ["status_code", 200]
- eq: ["nickName", "lemon_auto"]
casename与module字段简单,我们来看下teststeps,为什么teststeps是数组类型?
因为用例中包含一个/多个接口请求步骤,也就是一个TestCase包含了多个teststep,每一个t