前言
本文适合已经掌握 `Postman` 基本用法的读者,即对接口相关概念有一定了解、已经会使用 `Postman` 进行模拟请求等基本操作。
工作环境与版本:
* Window 7(64位)
* Postman (Chrome App v5.5.3)
_P.S. 不同版本页面 UI 和部分功能位置会有点不同,不过影响不大。_
首先我们来思考一下,如果要达到自动化接口测试效果,在基本的模拟请求上还需要做哪些呢?
我粗略概括为 3 个问题( _欢迎在评论区留言更多补充建议_ ):
1\. 如何判断接口是否请求成功?
2\. 如何进行接口批量、定期测试?
3\. 如何处理依赖接口问题(比如商品下单的接口必须要求先登录)?
所以,接下来就主要分为 3 个部分,介绍如何解决这 3 个问题。
### 1 接口结果判断
首先,既然是自动化测试,那么我们肯定需要通过工具 `Postman` 或者代码,帮我们直接判断结果是否符合预期。那么在接口测试上,大体就两个思路:
1. 判断请求返回的 `code` 是否符合预期
2. 判断请求返回的内容中是否包含预期的内容(关键字)
接下来我们看看如何利用 `Postman` 来解决上述的问题:
#### 1.1 功能区
在 `Postman` 中相关的功能在非常显眼的地方,`Tests` 功能的使用需要我们有一定的编程语言基础,目前支持的脚本语言即为
`JavaScript` 。但比较好的一点是,我们不需要再去考虑上下文问题以及运行环境的问题 ,也就是说我们只需要在这边完成结果逻辑判断的代码块即可。
而 `Postman` 还为我们提供了一些常用的代码模板,在 `Tests` 面板右边的 `SNIPPETS` 功能区中,所以对 `JavaScript`
不大了解问题也不大。代码编写相关将在下文进行具体介绍。
#### 1.2 脚本相关
先看上图的代码部分,我们可以发现 `responseCode` 、 `responseBody` 和 `tests` 三个变量(可直接使用) :
* `responseCode` :包含请求的返回的状态信息(如:code)。
* `responseBody`:为接口请求放回的数据内容(类型为字符串)。
* `tests` :为键值对形式,用于表示我们的测试结果是成功与否,最终展示在 `Test Results` 中。
* key :(如:code 200)我们可以用来当做结果的一个描述。
* value:其值为布尔型,`ture` 表示测试通过, `false` 表示测试失败。
所以上述代码应该不难理解了,而有了返回结果的数据以及表示结果成功与否的方式,那么我们“接口结果判断”的问题也就基本解决了。
另外还有几个比较常用的:
* `responseTime` :请求所耗时长
* `postman` :可以做的比较多,比如
* 获取返回数据的头部信息:
`postman.getResponseHeader("")`
* 设置全局变量:
`postman.setGlobalVariable("variable_key", "variable_value");`
更多功能可以查看官方文档。
#### 1.3 代码模板
`Postman` 在 `SNIPPETS` 功能区中为我们提供的代码模板已经能解决大部分情况了,以下先挑几个跟结果判断相关的进行讲解:
**Status code : Code is 200**
//根据返回的 Code 判断请求情况