在 Postman 里面写接口测试用例其实就是写测试脚本。下面我们来学习如何写一个简单的接口测试用例。
1、获取 API 信息
以获取实时天气作为示例:
1、API 的方法:GET
2、API 的 URL: https://api.seniverse.com/v3/weather/now.json
3、API 的参数:
-
请求参数:
参数名 参数类型 参数意义 是否必选 key string 你的API密钥(需要自主到心知天气平台获取) true location string 查询的地理位置 true language string 结果表示的语言 false,默认简体中文 unit string 结果表示的单位(华氏度,摄氏度) false,默认摄氏度 -
响应参数:
参数名 参数类型 参数意义 location 对象:包括id, name, country, time_zone, time_zone_offset now 对象:包括 text,code, temperature, feel_like last_update 日期
2、编写用例脚本
首先创建一个测试脚本。
在右侧的 New Tab 中输入方法和 URL
-
点击 Params 设置参数
3、运行用例脚本
点击右侧的 Send 按钮发送请求运行脚本。
运行后查看测试结果。
从结果可以看到脚本运行是成功的,响应状态是200。
4、用例断言
上面用例脚本已经执行成功了,但大家想一个问题:脚本执行成功就代表用例通过吗?
答案是否定的。
脚本运行成功返回200的状态码只能说明发送请求和接收响应没有问题,但响应内容不一定是我们想要的。这个时候要拿响应内容与 API 文档的响应参数做对比,响应内容与 API 文档的响应参数符合则用例测试通过,否则用例测试失败。例如上面返回 Body 结果中,location 的 path 字段就不是 API 文档中期望的响应参数。
一个测试用例中没有断言就不是测试用例,所以接口测试用例中也要添加断言。下面我们以断言城市名称 name 参数为例为这个测试用例添加一个断言。
编写断言
切换页面到 Tests 栏,编写断言的 JavaScript 脚本。
var jsonData = JSON.parse(responseBody);
tests["检查城市名称"] = jsonData.results[0].location.name === "深圳";
查看断言结果
重新发送一次请求,查看 Test Results 栏,PASS 状态代表断言通过。
为了看断言失败的效果,故意改错断言的参数值,再发送一次请求。