第十二节 JMeter基础-中级地址信息【IF控制器】

声明:本文所记录的仅本次操作学习到的知识点,其中商城IP错误,请自行更改。

背景:提交订单前,我们需要核对一些信息,比如商品信息,收货地址,支付方式等。现在核对一下收货地址信息。

思路

1、前提条件:A用户登录。

2、先判断地址列表是否有收货地址

3、如果没有收货地址,则新增默认收货地址。

4、如果有收货地址,全部删除后再新增默认收货地址(先这样粗暴的简单处理)。

1.认识JMeter

(1)逻辑控制器【IF控制器

可以通过条件来控制是否运行其下面的测试元件(子元素)。只有结果为True时才会执行层级下的测试元件。

(2)选项【日志】

提供了关于测试执行情况的详细信息,‌帮助用户分析和优化测试策略,‌确保测试的有效性和准确性,是测试过程中不可或缺的一部分。

2.【HTTP请求默认值】

3.【登录】

4.【查看地址列表】

(1)查看地址列表

(2)获取全部地址

5.【IF控制器-删除】

(1)所有地址不为空

(2)删除所有地址

(3)查看地址列表

6.【IF控制器-新增】

(1)所有地址为空

(2)新增默认地址

(3)查看地址列表

7.【调试取样器】

8.【查看结果树】

9.【日志】

我是被【IF控制器】中的**__groovy()**方法给弄得快崩溃了,之前花了很多时间百度找原因,一直找不到是什么原因导致判断失败后面的操作都不执行。最后是想通过日志看看能不能找到原因(因为对JMeter工具不太熟悉,日志打印那块有很多模块也是一个一个的试),公司的日志也没有这么多模式。

10.【认识IF控制器】

(1)界面

For performance it is advised to check "Interpret Condition as Variable Expression" and use__jexl3 or __groovy evaluating to true or false or a variable that contains true or false 为了提高性能,建议勾选"将条件解释为变量表达式",并使用 __jexl3或__groovy 求值为真或假,或者使用包含真或假的变量。

Expression (must evaluate to true or false):表达式(必须求值为真或假)。在右边文本框中输入的条件值必须是 true 或 false,例如:${__jexl3("address_id_all_matchNr" != "0" or "1" and "address_id_all_matchNr" != "",)}。

Use status of last sample:上次样品的使用情况。使用执行该IF控制器前的最后一个取样器结果作为判断,如果最后一个取样器通过就返回true,如果失败就返回false。点击一下按钮即可,表达式输入框里自动添加:${JMeterThread.last_sample_ok}

Interpret Condition as Variable Expression :将条件解释为变量表达式,默认勾选,需要使用 **{__jexl3()}**或**{__groovy()}**表达式。例如:{__groovy("{address_id_all1}"=="")}。

Evaluate for all children:条件作用域所有子元素。

(2) 区别

我把遇到的区别给总结一下(目前就2个),没遇到的就只能等以后再补充了,可以去官网看看(太简洁了):++https://jmeter.apache.org/usermanual/functions.html#__groovy++ , ++https://jmeter.apache.org/usermanual/functions.html#__jexl3++

字段上区别

{__groovy()}**表达式里面的参数**一定要有英文的双引号**,例如{__groovy(${address_id_all_matchNr} == "0" or {address_id_all1_matchNr} == "0",)},字段{address_id_all_matchNr}没有加上双引号 ,JMeter运行日志就报错**。

例如:{__groovy("{address_id_all_matchNr}" == "0" },字段${address_id_all_matchNr}加上双引号,JMeter运行日志就不会报错

{__jexl3()}**表达式里面的参数**可以没有英文的双引号**,{__jexl3("{address_id_all_matchNr}" == "0" or "{address_id_all1_matchNr}" == "0",)},字段${address_id_all_matchNr}没有双引号,JMeter运行日志也不会报错**。

OR语法区别

{__groovy()}**表达式里面有**OR逻辑判断**时,运行结果一定是failed,例如{__groovy(${address_id_all_matchNr} == "0" or {address_id_all1_matchNr} == "0",)},字段{address_id_all_matchNr}没有加上双引号,JMeter运行日志就报错**。

${__jexl3()}表达式里面有OR逻辑判断时就不会报错。

其它还没遇到

百度的内容

Groovy和Jexl3都是可以在Java平台上运行的表达式语言,‌但它们在设计目标、‌功能和使用场景上存在一些区别。

设计目标与功能:‌Groovy是一种动态编程语言,‌设计用于增强Java平台的开发体验,‌提供了丰富的特性如动态类型、‌闭包等,‌旨在提供一种更简洁、‌灵活的方式来编写代码。‌它支持与Java的无缝集成,‌允许开发者使用Groovy编写代码,‌同时也能调用Java库和类。‌相比之下,‌Jexl3(‌JEXL是Java Expression Language的扩展)‌更专注于提供一种轻量级的、‌易于嵌入的表达式语言,‌用于在运行时动态地解析和执行表达式。‌

使用场景:‌Groovy适合于需要快速原型设计、‌脚本编写或者需要利用其提供的丰富特性来简化Java开发的场景。‌它特别适合与Spring等框架一起使用,‌提供了一种更加敏捷的开发方式。‌而Jexl3则更适合于需要在Java应用程序中嵌入简单的表达式解析和执行功能的场景,‌比如在规则引擎、‌业务逻辑快速调整等场合。

语法与特性:‌Groovy的语法更加接近自然语言,‌提供了闭包、‌元编程等高级特性,‌使得代码更加简洁易读。‌而Jexl3的语法相对更加精简,‌专注于表达式的快速解析和执行,‌不包含Groovy那样的高级特性。‌

总的来说,‌Groovy和Jexl3都是为了在Java平台上提供表达式语言的解决方案,‌但Groovy 作为一个完整的编程语言,‌提供了更多的特性和灵活性, ‌适合于需要更复杂逻辑和快速开发的场景 ;‌而Jexl3 则更加轻量级‌专注于表达式的解析和执行,‌适合于简单的逻辑调整和嵌入使用。‌

(3)函数助手

一个工具,感觉了解_jexl3()与__groovy()后用处不大。

页面输入表达式的值,然后点击【生成】自动拷贝函数字符串。然后输出当前JMeternal变量,JMeterTread.last_sample_ok就是IF控制器之前的HTTP请求结果。其它的信息就没有了。

但是,这里没有任何语法校验,没有提示报错或者是IF控制器的结果是True还是False,还没有日志好用。对于熟悉{__jexl3()}或{__groovy()}写法的人来说,这个助手好像没什么用。

最上面的【帮助】,能够跳转到JMeter官网关于函数的介绍页面。

相关推荐
tester Jeffky1 天前
全面解析 JMeter 前置处理器:概念、工作原理与应用场景
jmeter
hopetomorrow2 天前
学习路之压力测试--jmeter安装教程
学习·jmeter·压力测试
tester Jeffky2 天前
JMeter 性能测试计划深度解析:构建与配置的树形结构指南
jmeter
tester Jeffky2 天前
深入探索JMeter逻辑控制器:构建复杂测试场景的利器
jmeter
tester Jeffky2 天前
深入探索JMeter的执行器时间线:从CLArgsParser到JmeterEngine
jmeter
惜.己2 天前
Jmeter中的断言(二)
测试工具·jmeter·1024程序员节
tester Jeffky2 天前
深入探索JMeter bin目录中的Properties文件:优化性能测试的关键
jmeter
tester Jeffky3 天前
掌握移动端性能测试利器:深入JMeter手机录制功能
jmeter·智能手机
惜.己3 天前
Jmeter中的断言(四)
测试工具·jmeter·1024程序员节
凌云行者3 天前
JMeter的简单使用
jmeter·性能测试