开源优测Apache JMeter程序员

JMeter断言07

2017-04-24  本文已影响773人  苦叶子

前言

在jmeter中断言用于验证服务器返回的数据是否满足我们的要求。

jmeter提供了以下断言类型:

1.png

下面我们主要对响应断言、XPath Assertion、jp@gc - JSON Path Assertion进行分享,这几个断言类型也是日常压测过程中最常用的,对于其他的断言类型,请大家去看官方文档。

jmeter提供了多大十几种断言方式,但合理利用好常用的几种断言就足以在驰骋于实际的项目应用了。

响应断言

响应断言允许用户通过添加模式字符串来比较验证服务器返回的响应。

例如对响应返回的状态码进行验证,或是对响应返回的本文内容验证等等。

下面我们对响应断言进行详细的说明:

2.png
  1. 响应文本
    服务器响应文本,一般情况下,我们都是勾选改选项,用于验证服务器返回值。
  2. Document(text)
    通过Apache Tika从各种的文档中提取的文本进行验证,包括响应文本,pdf、word等等各种格式。jmeter会用Apache Tika去解析服务器响应内容,耗内存、也耗时间,解析易失败,尽量少用或不用。多用响应文本方式来进行断言验证
  3. URL样本
    对请求的url进行断言,如果请求没有重定向(302),那么该url即为请求的url;如果有重定向(切跟随重定向),那么url则包含了请求url和重定向url。
  4. 响应代码
    即http响应代码,例如200,404等等,需要注意:
    由于jmeter默认情况下认为4xx,5xx时该请求失败,所以在断言这类响应代码时,需要同时勾选Ingore Status,才能正常去做断言。
  5. 响应信息
    即响应代码对应的信息,例如OK, Not Found等等这类的。

如下常见类似是响应信息:

HTTP/1.1 200 Ok
HTTP/1.1 302 Found
Response Header : 响应头信息,例如
Server: Tengine
Date: Thu, 12 Mar 2015 09:43:52 GMT
Content-Type: text/html
Content-Length: 260
Connection: close
Location: http://www.baidu.com/404.html
  1. Response Headers
    即http响应头信息,主要用于断言当响应头带有唯一或特定意义时。
  2. Ingore Status
    请参见4响应代码的使用说明。
  1. 包括: 指返回结果包含要测试的模式中指定的内容,支持正则表达式
  2. 匹配:(1)相当于equals。返回值是固定的,可以以返回值做断言,效果同equals;(2)正则表达式匹配。用正则表达式来匹配返回结果,但必须全部匹配。即正则表达式必须能匹配整个返回值,而不是返回部分值,注意与包括模式的区别(包括是支持模糊匹配的)。
  3. Equals:指返回结果与指定的测试模式完全一致。
  4. Substring:与“包括”模式差不多,都是指返回结果包括指定的内容,但Substring不支持正则表达式。
  5. 否:相当于取反。即如果上述断言结果为true,勾选“否”选项后,则最终断言结果为false。

注:在使用该断言时,熟练掌握正则表达式是必备的能力。

XPath Assertion

如果服务器响应返回的是xml格式的内容,这时最佳的断言验证类型就是使用XPath Assertion。

3.png

jp@gc - JSON Path Assertion

如果服务器响应返回的是json格式的内容,这时最佳的断言验证类型就是使用jp@gc - JSON Path Assertion。

4.png

注: 默认下载的jmeter是不支持该方式的,需要安装json plugins,在选项-Plugins Manager-Available Plugins找到JSON Plugins安装好即可。

下面对json path assertion进行说明

总结

本次分享主要就响应断言、XPath断言、JSON断言三种常用的断言类型进行了说明,对于具体的示例,后续在实践篇章会结合其他基础功能一一进行分享,这三种断言应该说满足日常压测过程断言的大部分场景,大家需要深入理解其各个选项的含义。

上一篇 下一篇

猜你喜欢

热点阅读