Jmeter(六):断言

目录

JMeter(一):基础概念
JMeter(二):配置元件
JMeter(三):变量参数化
JMeter(四):监听器
JMeter(五):脚本录制

断言:验证服务器返回的数据是否满足我们的要求
即LR中的检查点,是对响应结果做一个判断,我们在请求一个网址时会有返回数据,那怎么判断请求是正确的呢,就需要对某一字段或内容进行匹配,如果跟预想的一样就认为请求是正确的,否则是失败的

使用断言的目的:在request的返回层面增加一层判断机制(因为request成功了,并不代表结果一定正确)

针对何时使用JMeter断言,下面给出了一些建议:
(1)请求使用的是来自“CSV数据集配置”的数据
(2)使用的HTTP的POST、PUT、PATCH方法
(3)登录和注销后
(4)当2xx status codes同时在正面测试和负面测试中返回
(5)在API性能测试中
(6)在功能测试中
(7)有SOAP / XML-RPC请求
需要注意:断言消耗内存,谨慎使用

断言类型

如果没有断言只能人工对比对接口返回的数据,接口很多时,比对数据的过程就会非常耗时,而且也容易出错,可以通过Fiddler抓包http请求来设置

1、响应断言

在使用该断言时,需要熟练使用正则表达式,如果请求中使用了变量,响应内容里写${variable}

抓包查看Resopnse.png

允许用户通过添加模式字符串来比较验证服务器返回的响应,Jmeter提供了很多种匹配规则,断言中设置要测试的模式,实际响应的内容与设计的字符串进行匹配,如果返回的内容包含了字符串,则认为该次测试通过,否则就是失败(模式中的内容也可以参数化)

对断言做判断,只需添加【监听器--断言结果】
1)如果断言成功,显示的是HTTP请求名称
2)若失败,则会显示请求名称和失败的原因(“Test failed XXXXXX”内容)

PS:一个Sampler可以添加多个断言,根据你的检查需求来添加相应的断言,当Sampler下所有的断言都通过了,才算成功
比如在测接口时,返回值是True,只能说明接口是通的,还得继续验证返回的data值是否正确

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

如下常见类似是响应信息,即http响应头信息,主要用于断言当响应头带有唯一或特定意义

      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: 260Connection: close
      Location: http://www.baidu.com/404.html
      Response Headers
  • 模式匹配规则:支持正则表达式
    • 包括:返回结果包括指定的内容,当返回值固定时,可以使用返回值做断言,效果和equals相同
    • 匹配:用正则表达式必须能匹配整个返回值,而不是返回值的一部分
    • Equals:返回结果与你指定结果完全一致
    • Substring:返回结果是指定结果的字串,不支持正则字符串
    • 否:相当于取反,即如果上述断言结果为true,勾选“否”选项后,则最终断言结果为false
  • 要测试的模式:要匹配的响应值(字符串或正则表达式),即接口测试结果的期望值或者其他期望值
2、断言持续时间

持续时间(uration in milliseconds):单位是毫秒,如果响应时间大于设置的响应时间,则断言失败,否则成功!

断言持续时间.png
3、XPath Assertion

适用情况:服务器返回的响应内容是xml格式

XPath Assertion.png
  • Apple to
    一般选择Main sample only即可。如果一次发送多个请求,则需要根据实际断言需要选择其他选项了。(例如一个ajax请求,会发送多个GET或POST时。)
  • XML Parsing Options
    Use Tidy(tolerant parser):使用Tidy(容错解析器),默认选择quiet
    Quiet:不显示
    Report errors:错误报告
    Show warnings:显示错误
    Use Namespaces:使用名称空间
    Validate XML:验证XML(文件包/数据)
    Ignore Whitespace:忽略空格(允许指定语法分析器可以忽略哪个空格,而哪个空格是重要的)
    Fetch external DTDs:获取外部DTDs(一些XML元素具有属性,属性包含应用程序使用的信息,属性仅在程序对元素进行读、写操作时,提供元素的额外信息,这时候需要在DTDs中声明)
  • Path Assertion
    输入框中写入xpath断言,点击Validate验证其正确性
  • True if nothing matches
    确认都不匹配
4、按照字节断言
按照字节断言.png
  • APPly to:应用范围(返回内容的断言范围)
    Main sample and sub-samples:作用于父节点取样器及对应子节点取样器
    Main sample only:仅作用于父节点取样器
    Sub-samples only:仅作用于子节点取样器
    JMeter Variable:作用于jmeter变量(输入框内可输入jmeter的变量名称)

  • Response Size Field to Test:响应字节的测试范围(可以选择用于判断的响应范围)
    Full Response:全部响应
    Response Headers:响应头部
    Response Body:响应主体
    响应代码:响应报文相关的代码
    响应信息:响应报文的信息

  • Size to Assert:断言字节范围
    字节大小:单位是字节;比较顺序是①返回内容的大小②比较类型③指定字节大小

若未填值运行时会报错


image.png
5、jp@gc - JSON Path Assertion

Jmeter4.0版本已增加JSON Assertion插件,如果是3.2以上版本的话也可以在插件管理里面进行下载,插件下载地址:https://jmeter-plugins.org/?search=jpgc-json
适用情况:服务器返回的响应内容是json格式
PS:点击apply按钮时,请记得保存测试计划,因为安装后会进行重启

插件安装.png

参数说明:

  • JSON Path:json提取表达式,用于提取目标json串节点值
  • Validate against expected value:勾选该选项,则验证目标期望结果,不勾选可以填写 Expected Value
  • Match as regular expression:支持正则表达式
  • Expected Value:自定义期望值
  • Expect null:期望值为null,勾选该选项,则会断言结果为null的情况
  • Invert assertion(will fail if above condition met):取反,如果上述两种期望值断言为true,勾选该选项,则断言结果为fail;如果上述期望值断言为fail,勾选该选项,则断言结果为true。
jp@gc - JSON Path Assertion.png

PS:若断言成功,查看结果树中是看不到的,若失败,则会显示错误信息(如图中提示天气质量预期值是良,但实际是优)

也可以通过监听器-断言结果来查看

断言结果.png


PS:一个断言在测试树中是分等级的,如果父元件是请求,它就仅被应用于那个请求。如果它的父元件是控制器,它就影响所有那个控制器下的所有请求。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,012评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,628评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,653评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,485评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,574评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,590评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,596评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,340评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,794评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,102评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,276评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,940评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,583评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,201评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,441评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,173评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,136评论 2 352

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,647评论 18 139
  • JMeter有两种类型的控制器:取样器和逻辑控制器。 取样器指示JMeter向一个服务器发送请求。例如,如果你想让...
    七月尾巴_葵花阅读 1,674评论 0 3
  • 主要文体来自 CDNS:https://www.cnblogs.com/ceshisanren/p/5639895...
    Amano阅读 10,986评论 3 27
  • 此刻我的心在莫名慌乱的快速跳动,双臂已经失去了力量,只剩下手指机械地敲着手机屏幕。压抑的情感好像影响了我的内分泌,...
    寒石居士阅读 216评论 0 0
  • 培训第二天,感觉挺好的,虽然听着某些无聊的言论,但是能够暂时脱离上班的环境也是挺好的。况且今晚还拔草了心仪已久的烧...
    简单的诗句阅读 163评论 0 1