本文基于robot framework框架,支持http api,robot framework如何使用请参考光毅的另一篇文章

基于RF框架的接口自动化

(脚本做了一些修改和更新,更新内容请看part2)

本文主要讲,如何分离测试用例和参数

目标:缩减用例编写成本;提高用例可维护性

参数通过csv表格编写和维护

背景(可不看)

用robot framework编写用例的构成:用例+keyword+json结构参数

keyword: 处理逻辑

json文件:存请求数据和预期返回数据

基于如上背景,我们写一条用例,需要有一个用例代码,一个json的请求和预期返回

例如,我们的请求有10个参数,一个参数编写五种不同的测试值,我们需要编写50个用例,写50个json请求和返回

上述过程种,存在大量重复工作,且不方便维护,如果请求增加字段,则需要修改全部json体

所以想到了用例和参数分离的方式:模版用例+参数,生成可执行用例

效果:请求有五种预期返回码,只需要写一个json请求模版和5个预期返回模版

(流程图在最后)

(文章末尾更新了使用步骤,可以直接看简化步骤,细节可以回来看这里)

1.下载代码到本地(robot framework如何使用请参考文章开头附的文章)

link: https://git.garena.com/arrow.zhang/httpapiautotest.git

2.编写一个成功用例 (包含用例和一个json请求体和一个预期json返回体)

3.GenerateTest.py是生成,robot用例的脚本,可以copy一个或者在上边改

4.需要修改内容,是步骤4和步骤5

将TestCaseHeader和TestCaseBody替换成自己用例(写用例时也按照这个格式写),红框处为替换参数名字需要保持不变

5.填写apilist参数,参数是一个多元数组 ,一个值表示一个api,一个api包含了api_name,json_file_path,parameter_file_path三个参数

api_name:API的名称,决定了你生成robot文件的名称

json_file_path:存储json请求模版和json预期返回模版的路径

parameter_file_path:参数文件的路径

(到这里代码部分的逻辑已经修改完成,下边讲参数文件的编写规范)

6.参数文件编写规范

格式:csv格式,名称和apilist里的名称一致,在file文件夹下

参数包含六列:

case_id: 数据的键值,不可重复

case_name: 用例名称

request_template: 请求的模版名称(与json文件中的模版对应)

request_key:当前需要测试的字段

request_value: 测试字段的值

response_exp: 预期的返回模版

例如:t002号用例,替换请求字段里的signature为“SDFGHJKLTYUIOFGHJK”,预期结果的模版名称是E103 response

tips:

给request_value做了一些自定义的判断:

0XRight表示正确请求,不需要替换参数

0XMissing 表示没有这个字段

int–开头 表示这个字段要传int类型

PS:参数文件是要手动编写,并放入到对应目录下

整理流程图:

完成了上边所有步骤后,后续增加和修改用例,只需要维护csv的表格

如果请求体结构有变化,只需要修改模版文件的json结构体就ok

功能还没那么完善,有什么意见或者建议请联系我~~~如果文档看不明白也请私戳我~

~~~~~~~~~~~~~~~~~~~~~~~~(以下是新修改内容,7月3日)~~~

1.生成脚本做了修改,参数文件格式做了修改

https://docs.google.com/spreadsheets/d/1T48OAyGviZpF3exAQlVZ393gP8H_kU7qN8MHYsyXqo8/edit?usp=sharing

新支持内容:

1.请求可以修改多个字段

2.支持不同格式

3.返回校验,不用写Json返回体,直接输入预期校验的key和value即可

2.简化了接入步骤:

a.下载代码

https://git.garena.com/arrow.zhang/httpapiautotest.git

(因为不能直接设置pulich权限,需要权限的同学私戳我就好)

b.写一个Json请求体,(参数均正确)

c.按照上述格式编写用例

d.填写,Json请求体文件路径,用例csv.文件路径,run即可

生成用例脚本如下图路径

keyword路径(处理请求参数替换和返回验证逻辑)