JMeter 断言最佳实践

打印 上一主题 下一主题

主题 916|帖子 916|积分 2748

JMeter 断言最佳实践

一、弁言

在利用 JMeter 进行性能测试或功能测试时,断言是非常重要的一部门。断言可以帮助我们验证接口返回的效果是否符合预期,确保测试的正确性和可靠性。本文将先容 JMeter 中常见的断言范例、利用这些断言的最佳实践,并给出实际例子。
二、JMeter 常见断言范例及实际例子

2.1 相应断言(Response Assertion)



  • 功能:用于验证相应内容是否包含、不包含特定的文本,或者是否与特定的模式匹配。
  • 适用场景:适用于验证接口返回的文本信息,如登录乐成提示、错误信息等。
  • 示例配置

    • 要测试的相应字段:选择“相应文本”。
    • 模式匹配规则:选择“包含”。
    • 测试模式:填写“登录乐成”。

  • 实际例子:假设我们有一个登录接口 /login,发送用户名和暗码后,若登录乐成,相应文本会包含“登录乐成”字样。在 JMeter 中添加一个 HTTP 请求采样器用于模拟登录请求,然后在该采样器下添加相应断言,按上述配置进行设置。当运行测试时,如果相应文本包含“登录乐成”,则断言通过;否则,断言失败。
2.2 连续时间断言(Duration Assertion)



  • 功能:用于验证请求的相应时间是否在指定的范围内。
  • 适用场景:性能测试中,验证接口的相应时间是否满足性能指标要求。
  • 示例配置

    • 最大相应时间:设置为 500(毫秒)。

  • 实际例子:对于一个商品查询接口 /products,业务要求该接口的相应时间不能凌驾 500 毫秒。在 JMeter 中添加该接口的 HTTP 请求采样器,然后添加连续时间断言,将最大相应时间设置为 500 毫秒。运行测试时,如果该接口的相应时间凌驾 500 毫秒,断言失败,表明该接口的性能不满足要求。
2.3 大小断言(Size Assertion)



  • 功能:用于验证相应数据的大小是否在指定的范围内。
  • 适用场景:验证接口返回的数据量是否符合预期,避免返回过大或过小的数据。
  • 示例配置

    • 相应数据的大小:选择“小于”,并设置具体的大小值为 1024(字节)。

  • 实际例子:有一个图片缩略图获取接口 /thumbnails,预期返回的缩略图数据大小不凌驾 1024 字节。在 JMeter 中添加该接口的 HTTP 请求采样器,接着添加大小断言,设置相应数据大小小于 1024 字节。运行测试时,若返回的缩略图数据大小凌驾 1024 字节,断言失败,说明返回的数据量不符合预期。
2.4 JSON 断言(JSON Assertion)



  • 功能:用于验证 JSON 格式的相应数据是否符合预期。可以验证 JSON 节点的值、节点是否存在等。
  • 适用场景:当接口返回 JSON 数据时,利用 JSON 断言可以方便地验证数据的正确性。
  • 示例配置

    • JSON 路径表达式:填写 $.user.name。
    • 预期值:填写“John Doe”。
    • 比力方式:选择“相等”。

  • 实际例子:假设一个用户信息查询接口 /users/1 返回的 JSON 数据如下:
  1. {
  2.     "user": {
  3.         "name": "John Doe",
  4.         "age": 30
  5.     }
  6. }
复制代码
在 JMeter 中添加该接口的 HTTP 请求采样器,然后添加 JSON 断言,按上述配置进行设置。运行测试时,若返回的 JSON 数据中 $.user.name 的值为“John Doe”,则断言通过;否则,断言失败。
2.5 XML 断言(XML Assertion)



  • 功能:用于验证 XML 格式的相应数据是否符合预期。可以验证 XML 节点的值、节点是否存在、XML 结构是否正确等。
  • 适用场景:当接口返回 XML 数据时,利用 XML 断言可以确保数据的正确性。
  • 示例配置

    • 验证 XML 结构:勾选该选项。
    • XPath 查询:填写 //product/name。
    • 预期值:填写“Smartphone”。

  • 实际例子:一个商品信息接口 /products/1 返回的 XML 数据如下:
  1. <products>
  2.     <product>
  3.         <name>Smartphone</name>
  4.         <price>999</price>
  5.     </product>
  6. </products>
复制代码
在 JMeter 中添加该接口的 HTTP 请求采样器,然后添加 XML 断言,按上述配置进行设置。运行测试时,若 XML 结构正确且 //product/name 节点的值为“Smartphone”,则断言通过;否则,断言失败。
三、断言的最佳实践

3.1 合理选择断言范例

根据接口返回的数据范例和验证需求,选择合适的断言范例。例如:


  • 如果接口返回文本信息,优先利用相应断言。
  • 对于 JSON 数据,利用 JSON 断言可以更精准地验证数据。
  • 在性能测试中,利用连续时间断言和大小断言来验证性能指标。
3.2 明确断言的预期值

在配置断言时,要明确预期值。预期值应该基于接口文档或业务需求,避免利用模糊或不确定的值。例如,在验证登录接口时,明确登录乐成的提示信息,而不是利用一个宽泛的“乐成”字样。
3.3 避免过度断言

虽然断言可以提高测试的正确性,但过度利用断言大概会导致测试用例过于脆弱。只对关键的、影响业务逻辑的部门进行断言,避免对一些无关紧急的细节进行断言。例如,对于接口返回的时间戳,只需要验证其格式是否正确,而不需要验证具体的值。
3.4 联合多个断言

在某些环境下,单一的断言大概无法满足验证需求。可以联合多个断言来进行更全面的验证。例如,在验证一个订单接口时,可以同时利用相应断言验证订单状态信息,利用 JSON 断言验证订单金额是否正确。
3.5 断言的位置和作用域



  • 位置:断言应该添加在需要验证的采样器之后,确保对该采样器的相应进行验证。
  • 作用域:可以设置断言的作用域,包括当前采样器、当火线程组、所有采样器等。根据实际需求选择合适的作用域。
3.6 断言的错误处理

在断言失败时,JMeter 会将该请求标志为失败。可以通过添加监听器(如“聚合陈诉”)来查看断言失败的环境。同时,在测试陈诉中明确记录断言失败的缘故原由,方便后续的问题排查。
四、示例代码(利用 BeanShell 断言进行复杂验证)

有时候,现有的断言范例无法满足复杂的验证需求,这时可以利用 BeanShell 断言。以下是一个利用 BeanShell 断言验证 JSON 相应中某个字段值范围的示例:
  1. import org.json.JSONObject;
  2. // 获取响应数据
  3. String response = prev.getResponseDataAsString();
  4. try {
  5.     // 解析 JSON 数据
  6.     JSONObject json = new JSONObject(response);
  7.    
  8.     // 获取要验证的字段值
  9.     int fieldValue = json.getInt("fieldName");
  10.    
  11.     // 验证字段值的范围
  12.     if (fieldValue >= 10 && fieldValue <= 100) {
  13.         Failure = false;
  14.         FailureMessage = "";
  15.     } else {
  16.         Failure = true;
  17.         FailureMessage = "字段值不在 10 到 100 的范围内";
  18.     }
  19. } catch (Exception e) {
  20.     Failure = true;
  21.     FailureMessage = "解析 JSON 数据时出错:" + e.getMessage();
  22. }
复制代码
在这个示例中,我们利用 BeanShell 断言验证 JSON 相应中名为 fieldName 的字段值是否在 10 到 100 的范围内。如果不在该范围内,断言失败并记录错误信息。
五、总结

JMeter 断言是包管测试正确性和可靠性的重要工具。通过合理选择断言范例、明确预期值、避免过度断言、联合多个断言等最佳实践,可以提高测试的效率和质量。同时,对于复杂的验证需求,可以利用 BeanShell 断言进行灵活处理。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

正序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

反转基因福娃

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表