jmeter BeanShell断言(一)

原文地址https://blog.csdn.net/lijing742180/article/details/81157947

原文地址https://blog.csdn.net/zailushangbuting/article/details/70808612

原文地址https://blog.csdn.net/maybe_frank/article/details/79094230

原文地址https://www.cnblogs.com/vv00cc/p/7902693.html

原文地址https://www.cnblogs.com/111testing/p/10301442.html

一、响应断言
1、什么是响应断言?

​ 在jmeter中最常用的断言方法是“响应断言”,它是通过检查sampler的请求内容和响应结果中是否匹配指定的字符串来判断结果是否正确。

​ 响应断言简单实用,能够解决工作中的大部分问题。

​ 尤其是在jmeter4.0版本中在响应断言中加入了Request Headers、Request Data,使得能够对请求头和请求体进行断言,满足了多样性的断言需求,非常方便。
img

2、使用响应断言

​ 响应断言的使用非常简单,通常需要关注如下三点:

img

“要测试的响应字段”

指我们要进行断言的内容所在的位置,分为request和response两大块,根据实际情况选择即可(最常用的是响应文本)

“模式匹配规则” (此处提到的1和3对应上图中的数字)

控制上图中的“1”如何匹配“3”

"包括"-------------1包括3,支持正则;
“匹配”-------------1完全匹配3,支持正则;

“Equals”---------1完全匹配3中的文本内容,不支持正则,且大小写敏感;
“Substring”-----1包括3中的文本内容,不支持正则,且大小写敏感;

“否”、“或者”----跟前面四个选项结合使用,分别用于逻辑取反、取或。

“要测试的模式”

这里填写我们要进行断言的内容,可以添加多个模式,可以使用变量、文本、正则表达式(在“包括”和“匹配”模式下)。

二、BeanShell断言
1、什么是BeanShell断言?

​ BeanShell断言可以使用beanshell脚本来执行断言检查,可以用于更复杂的个性化需求,使用更灵活,功能更强大,但是要能够熟练使用beanshell脚本。

​ 在这里除了可以使用beanshell的内置变量外,主要通过 Failure 和 FailureMessage来设置断言结果。
img

下面看一个简单的示例:

img

其中脚本内容如下:

复制代码

if ("200".equals(""+ResponseCode) == false )
{
    // 响应码不等于200时,设置断言失败,并输出失败信息
    Failure=true ;
    FailureMessage ="Response code was not a 200 response code it was " + ResponseCode + "." ;
    print ( "the return code is " + ResponseCode);   // this goes to stdout
    log.warn( "the return code is " + ResponseCode); // this goes to the JMeter log file
} else {
    // 响应码等于200时,设置断言成功,并输出成功信息
    Failure=false;
    FailureMessage = "Return true, and the response code was " + ResponseCode;
     }
}

复制代码

Bean Shell常用内置变量

   JMeter在它的BeanShell中内置了变量,用户可以通过这些变量与JMeter进行交互,其中主要的变量及其使用方法如下:

log:写入信息到jmeber.log文件,使用方法:log.info(“This is log info!”);

ctx:该变量引用了当前线程的上下文,使用方法可参考:org.apache.jmeter.threads.JMeterContext。

vars - (JMeterVariables):操作jmeter变量,这个变量实际引用了JMeter线程中的局部变量容器(本质上是Map),它是测试用例与BeanShell交互的桥梁,常用方法:

    a) vars.get(String key):从jmeter中获得变量值

    b) vars.put(String key,String value):数据存到jmeter变量中

    更多方法可参考:org.apache.jmeter.threads.JMeterVariables

props - (JMeterProperties - class java.util.Properties):操作jmeter属性,该变量引用了JMeter的配置信息,可以获取Jmeter的属性,它的使用方法与vars类似,但是只能put进去String类型的值,而不能是一个对象。对应于java.util.Properties。

    a) props.get("START.HMS");  注:START.HMS为属性名,在文件jmeter.properties中定义

    b) props.put("PROP1","1234");

prev - (SampleResult):获取前面的sample返回的信息,常用方法:

    a) getResponseDataAsString():获取响应信息

    b) getResponseCode() :获取响应code

    更多方法可参考:org.apache.jmeter.samplers.SampleResult

sampler - (Sampler):gives access to the current sampler

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

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

img

2、编写断言判断代码:

复制代码

if("206".equals("${action_seq_1}") && "3".equals("${trans_status_1}")){
    Failure = false;
    FailureMessage = "交易成功!";
}else if(!"206".equals("${action_seq_1}")){
     Failure = true;
    FailureMessage = "交易类型不正确!";
}else if(!"3".equals("${trans_status_1}")){
    Failure = true;
    FailureMessage = "交易未成功!";
}

复制代码

img

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

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

BeanShell是jmeter的解释型脚本语言,和java语法大同小异,并有自己的内置对象和方法可供使用。

vars:操作jmeter的变量:vars.get(String parmStr) 获取jmeter的变量值;vars.put(String key,String value) 把数据存到Jmeter变量中;

prev:获取sample返回的信息,prev.getResponseDataAsString() 获取响应信息;prev.getResponseCode() 获取响应状态吗;

从这里可以参考更多:https://jmeter.apache.org/api/org/apache/jmeter/samplers/SampleResult.html

1、添加一个线程组,并依次加上需要的功能组件,右键http请求添加一个BeanShell Assertion。

2、我们把json.jar引入,可以拷贝到jmeter的lib\ext目录下,也可以在计划任务引入jar包

img

img

复制代码

import org.json.*;
String responsData = prev.getResponseDataAsString();
JSONObject responseJson = new JSONObject(responsData);
String status = responseJson.getString("code").toString();
if(!status.equals("0")){
    Falure = True;
}

复制代码

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

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

解析response中的内容,并把获取到的value传递到后续的request中,常用的方法就是在想要解析response的request上添加后置处理器
本章介绍两种常用的组件

BeanShell PostProcessor

JSON Extractor

下面是具体的操作步骤:

添加后置处理器:BeanShell PostProcessor

获取response中的字符串,并对内容进行判断,当response中包含“The wait operation timed out”或者“Oops. Something went wrong ... sorry”时,都认为该request的response不正确

复制代码

String response = prev.getResponseDataAsString();
String code = prev.getResponseCode();
log.info("Respnse is " + response);
log.info(code);
int result1 = response.indexOf("The wait operation timed out");
int result2 = response.indexOf("Oops. Something went wrong ... sorry");
if(code == "200" && result1>=0 || result2>=0){
    FailureMessage = "OK,check current";
}
else{
    Failure = true;
    FailureMessage = "ERROR,check error";
}

复制代码

解析返回的Jason数据,获取name字段的值赋给变量result

{“body”:{“apps”:[{“name”:”111”},{“name”:”222”}]}}

复制代码

import org.json.*;
脚本中的导入的json包需要自己去网络下载后放到\lib\ext下

String response_data = prev.getResponseDataAsString();
JSONObject data_obj = new JSONObject(response_data);
String apps_str = data_obj.get("body").get("apps").toString();
JSONArray apps_array = new JSONArray(apps_str);
String[] result = new String[apps_array.length()];
for(int i=0;i<apps_array.length();i++){
    JSONObject app_obj = new 
    JSONObject(apps_array.get(i).toString());
    String name = app_obj.get("name").toString();
    result[i] = name;
}
vars.put("result", Arrays.toString(result));

复制代码

添加后置处理器:JSON Extractor
解析返回的Jason数据,获取name字段的值带入参数到后边的request中

{“body”:{“apps”:[{“name”:”111”},{“name”:”222”}]}}

img

变量t1的值是111,变量t2的值是222

转载于:https://www.cnblogs.com/LOVEYU/p/11398181.html

### 回答1: JMeter Beanshell断言是一种使用Beanshell脚本语言编写的断言方式,用于在JMeter测试计划中验证响应结果是否符合预期。 Beanshell是一种动态语言,可以方便地使用Java API和JMeter内置函数。 ### 回答2: JMeter是一个功能强大的开源负载测试工具,它可以通过模拟多种负载条件对Web应用程序或服务器进行测试,以评估其性能和稳定性。BeanshellJMeter的一种断言方式,它能够实现复杂的测试逻辑和定制化断言,并且非常容易编写和使用。 首先,布尔型断言比较简单,它能够检查响应中的指定文本是否存在。例如,我们可以通过以下方式创建一个布尔型断言: 1.添加一个HTTP请求,并指定要测试的网址。 2.选择添加断言并选择“响应断言”。 3.选择“Beanshell Assertion”。 4.在Beanshell编辑器中输入以下代码: String response = new String(data); if (!response.contains("expected text")){ Failure = true; FailureMessage = "Could not find expected text"; } 这个断言逻辑非常简单,它将HTTP响应中的文本转换为字符串,然后检查它是否包含特定的预期文本。如果未找到预期文本,则会将断言标记为“失败”并显示消息“未找到预期文本”。 其次,JMeterBeanshell还支持更高级的断言,例如XPath断言JSON断言等。例如,我们可以通过以下方式创建一个XPath断言: 1.添加一个HTTP请求,并指定要测试的网址。 2.选择添加断言并选择“响应断言”。 3.选择“Beanshell Assertion”。 4.在Beanshell编辑器中输入以下代码: import javax.xml.xpath.*; DocumentBuilderFactory Factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = Factory.newDocumentBuilder(); Document doc = builder.parse(new InputSource(new StringReader(new String(data)))); doc.getDocumentElement().normalize(); XPathFactory xPathfactory = XPathFactory.newInstance(); XPath xpath = xPathfactory.newXPath(); XPathExpression expr = xpath.compile("xpath expression"); if (!Boolean.parseBoolean(expr.evaluate(doc))){ Failure = true; FailureMessage = "Could not find expected element using XPath"; } 这个断言逻辑比较复杂,它使用XPath表达式来遍历文档树并查找特定的XML元素。如果未找到预期元素,则会将断言标记为“失败”并显示消息“使用XPath无法找到预期元素”。 总的来说,JMeterBeanshell断言提供了一种非常灵活和强大的测试工具,可以轻松地实现复杂的测试逻辑和定制化断言。无论您是测试Web应用程序还是服务器,都可以使用Beanshell来创建高品质的测试和评估。 ### 回答3: JMeter是一个开源的性能测试工具,而Beanshell是一种基于Java的脚本语言,它允许开发人员在运行时编写程序代码。如果需要在JMeter中编写自定义的测试脚本或逻辑,就需要使用Beanshell来实现。 在JMeter中,Beanshell可以用于断言中,以验证测试结果。断言是用来确认请求的响应是否符合预期的工具。Beanshell断言是一种用户自定义的断言类型,利用Beanshell脚本语言编写。 要添加Beanshell断言,首先需要创建一个断言类型。在JMeter的测试计划中,右键单击线程组并选择“添加” ->“断言” ->“响应断言”。然后在“响应断言”窗口中,选择“对于响应断言的测试元素” ->“Beanshell断言”。 接下来,需要编写Beanshell脚本。Beanshell脚本根据用户需求定义,可以在测试计划中使用变量,如响应头、响应数据和URL。脚本应该返回一个Boolean类型的值。如果脚本返回true,则测试结果符合预期;否则,测试结果不符合预期。 在执行测试时,JMeter对每个响应进行断言测试。如果某个响应不符合预期,则测试计划会生成失败结果。用户可以根据断言结果来获取有关测试质量的详细信息。 总体来说,JMeter Beanshell断言是一种非常有用的测试工具,允许开发人员自定义断言逻辑,并通过脚本解决特定的测试问题。SuppressWarnings(“unchecked”)注释和其他技术可用于确保编写的脚本的正确执行,并获得名称良好和可读性良好的测试结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值