调试收集运行

有时,即使您希望所有这些测试都通过,您的收集测试也会失败。

发生故障时,可以通过两种方式调试请求:

让我们在使用Postman Echo集合的示例中探讨调试请求

要将Postman Echo添加到Postman构建器视图中,请转至Postman Echo

单击屏幕右上方“在邮递员中运行”按钮。Postman Echo集合显示在Postman构建器的侧边栏中。

在您的Postman构建器视图中,单击标题栏左侧Runner按钮。

在“收集运行器”中,选择“邮递员回声”,然后单击“ 运行邮递员回声”按钮。(您也可以选择“环境”,“迭代”,“延迟”(时间),“日志记录”,“数据”和“持久变量”。

但是此示例不是必需的。)下图显示了收集运行的结果。

postman——集合——执行集合——调试、诊断集合运行结果_数据

Delete Cookies请求中,我们希望服务器返回某个cookie。

Postman Echo的Cookies端点返回发送给它的任何cookie。它还在响应主体中发送这些的JSON表示形式。我们正在使用它来检查是否返回了某些cookie。

如您所见,该测试失败。让我们调查原因。

使用请求和响应主体进行调试

postman——集合——执行集合——调试、诊断集合运行结果_工具提示_02 postman——集合——执行集合——调试、诊断集合运行结果_数据_03

正如测试所言,我们希望将一个名为cookie的消息foo1作为响应的一部分返回。

如果您在收集运行中单击任何请求名称,您会注意到出现一个工具提示。该工具提示包含有关您的请求的有用信息,您可能需要找出可能出了问题的信息。

展开该Response Body部分,我们可以清楚地看到响应中不包含我们期望的cookie。

而且,当我们扩展该Response Headers部分时,我们看到cookie根本没有发送。我们推断Postman Echo处理Cookie的方式一定有问题。

现在,我们可以继续并在我们的API中对此进行修补,然后重试。

请注意,仅尝试显示小于300KB的响应正文。出于安全原因,您的响应标头和正文永远不会同步。

您可以通过Log responses开始收集运行使用下拉列表来控制在此工具提示中显示哪些实体

使用Postman控制台进行调试

使用Postman控制台进行调试时,需要先打开控制台,然后再开始运行。

有关Postman控制台的更多信息,请参见调试和日志

postman——集合——执行集合——调试、诊断集合运行结果_用例_04

邮递员控制台记录所有请求并将它们显示在列表中。

让我们在这里找到引起问题的请求,并扩展其响应头。在这里,我们也看到Postman Echo端点没有返回cookie,并指出了测试失败的原因。然后,我们可以推断出端点行为异常,需要进行检查。

任何console.log你在你的测试脚本有也出现在这里,所以你可以登录控制台,如果你正在调试一个复杂的测试脚本,也可以提前打开控制台。

 

 

 

 

 

==============================================================================================================

 

 

 

 

 

设置好 Collection Runner 中的各项配置参数后可以运行整个 Collection 中的所有请求。

在运行过程中,总是有这样或那样的问题导致断言失败。比如网络导致请求发送不成功、变量值错误、接口本身的 Bug 等。

遇到失败的情况,我们肯定需要分析到底是不是 Bug 了。在 Collection Runner 运行后的测试结果中,可以查看运行的详细记录,以分析断言失败的原因。

通过结果日志分析

在运行的结果中,我们可以通过左侧的绿色和红色方块筛选器,筛选失败的断言。然后点击请求名称(用例名称),查看详细信息,如下图:

 
 

比如上图中的Delete Cookies是一个请求的标题,点击后可以看到请求和响应的详细记录。

  • Request URL:请求发送的 URL,可以查看 Get / Delete 等类型的请求参数是否正确;
  • Request Headers:请求头部,可以查看请求中的 cookie / token 等认证信息或者 UserAgent 等头部字段的数据是否正确;
  • Request Body:请求数据,针对 Post / Put等类型的请求 Boby 中传递的数据是否正常,这是一个很重要的观察点
  • Response Headers:响应头部,用于观察响应头部字段数据是否正确;
  • Response Body:响应数据,这是最重要的观察点,断言如果失败,大概率是因为响应数据的问题。这有可能是断言设置没有考虑到可能变化的数据,也可能是返回的数据不符合要求(Bug)。

当然这里主要记录的是响应中的数据,如果是在 Tests 或 Pre-requests 中的代码异常,这里就无法查看到了。

如果想要顺带查看代码问题,需要使用 Postman Console,也就是 Postman 的控制台,这里可以查看代码报错和使用 console.log() 函数打印的值。

使用 Postman Console 分析

要打开 Postman Console 可以通过左下角的按钮或者快捷方式Ctrl + Alt + C

 
 

注意,必须要先开启 Postman Console 再运行 Runner ,否则 Postman Console 捕获不到结果。

打开 Postman Console 后,通过 Runner 运行 Collection,在 Postman Console 界面就可以看到运行的所有请求信息:

 
 

Postman 会记录所有运行的用例,所以筛选起来不是很方便。

Postman Console 不止可以用来分析结果,还可以用来调试 Pre-requests 和 Tests 中的代码。