繁体   English   中英

JMeter Beanshell整数错误

[英]JMeter Beanshell Integer Error

我在JMeter Beanshell采样器/前/后处理器中遇到Integer问题。 我有一些值数组,我想使用此数组的每个值来设置JMeterProperty以供下次使用。

目标>查询中有一些N行。 例如,UPSTREAM列有diff值,我需要保存它们以供下次使用。 因为我将使用它们通过“OS Processes Sampler”调用CMD.exe作为参数。

So, if UPSTREAM_1=XXX, UPSTREAM_2=AAA, 
CMD.EXE will looks like: CMD.EXE -upstream_1 -upstream_2, etc.

从SQL我得到数组的值

COUNT=31
UPSTREAM_#=31
UPSTREAM_1=XXX
UPSTREAM_2=AAA
....

在PostProcessor中我设置:

${__setProperty(COUNT, ${COUNT_1})};

我正在尝试这个scrpit:

import java.util.*;
import java.text.*; 
import java.io.*;

int max = Integer.parseInt(vars.get(${COUNT_1})); //--COUNT=31, Integer doesnt work
int n = vars.get(${COUNT_1}); //--COUNT=31, this also doesnt work

for (int i=1;i<=n;i++)
{
   ${__setProperty(UPSTREAM_i, ${UPSTREAM_i})};
}

但JMeter日志说它不知道“INT”

2016/10/03 14:52:13 ERROR - jmeter.util.BeanShellInterpreter: Error invoking bsh method: eval   Sourced file: inline evaluation of: `` import java.util.*; import java.text.*;  import java.io.*;  int max = Integer.p . . . '' : Typed variable declaration : Error in method invocation: Method get( int ) not found in class'org.apache.jmeter.threads.JMeterVariables' 
2016/10/03 14:52:13 WARN  - jmeter.protocol.java.sampler.BeanShellSampler: org.apache.jorphan.util.JMeterException: Error invoking bsh method: eval Sourced file: inline evaluation of: `` import java.util.*; import java.text.*;  import java.io.*;  int max = Integer.p . . . '' : Typed variable declaration : Error in method invocation: Method get( int ) not found in class'org.apache.jmeter.threads.JMeterVariables' 

有人能帮助我吗? 也许我想念一些图书馆或其他东西。 我有JRE / JDK。


UPDATE_1

用户变量全部:

COUNT   ${__property(COUNT)}    Count of Rows from SQL Query

测试计划:

在此输入图像描述

后处理器日志:

SamplerProperties:
variableNames=DATE,DOWNSTREAM,UPSTREAM,COUNT,etc.

JMeterVariables:
COUNT=31
COUNT_#=31
COUNT_1=31
COUNT_2=31
.....
DATE_#=31
DATE_1=04.10.2016
DATE_2=04.10.2016
.....
DOWNSTREAM_#=31
DOWNSTREAM_1=DDD11
DOWNSTREAM_2=DDD11
.....
UPSTREAM_#=31
UPSTREAM_1=XXX
UPSTREAM_2=AAA
....
JMeterProperties:
COUNT= 31
DATE= 04.10.2016
DOWNSTREAM= DDD11
TEST= 1

调试循环日志:

SamplerProperties:
BeanShellSampler.query=import java.util.*;
 import java.text.*; 
 import java.io.*;
 int n = Integer.parseInt(vars.get("COUNT")); 
 for (int i=1;i<=n;i++)
 {
      props.setProperty("UPSTREAM_"+i, vars.get("UPSTREAM_i"));
 }
    JMeterVariables:
    COUNT=31
    COUNT_#=31
    COUNT_1=31
    COUNT_2=31
    .....
    DATE_#=31
    DATE_1=04.10.2016
    DATE_2=04.10.2016
    .....
    DOWNSTREAM_#=31
    DOWNSTREAM_1=DDD11
    DOWNSTREAM_2=DDD11
    .....
    UPSTREAM_#=31
    UPSTREAM_1=XXX
    UPSTREAM_2=AAA
    ....
    JMeterProperties:
    COUNT= 31
    DATE= 04.10.2016
    DOWNSTREAM= DDD11
    TEST= 1

这是在Jmeter日志中:

2016/10/03 17:12:24 ERROR - jmeter.util.BeanShellInterpreter: Error invoking bsh method: eval   Sourced file: inline evaluation of: ``import java.util.*;  import java.text.*;   import java.io.*;  int n = Integer.pa . . . '' : Method Invocation props.setProperty 
2016/10/03 17:12:24 WARN  - jmeter.protocol.java.sampler.BeanShellSampler: org.apache.jorphan.util.JMeterException: Error invoking bsh method: eval Sourced file: inline evaluation of: ``import java.util.*;  import java.text.*;   import java.io.*;  int n = Integer.pa . . . '' : Method Invocation props.setProperty 

UPDATE_2

UBIK LOAD PACK的解决方案有效:),GOAL更新。

您的Beanshell脚本有许多错误:

 import java.util.*;
 import java.text.*; 
 import java.io.*;
 int n = Integer.parseInt(vars.get("COUNT")); 
 for (int i=1;i<=n;i++)
 {
      props.setProperty("UPSTREAM_"+i, vars.get("UPSTREAM_"+i));
 }

请注意您正在做的是设置道具(全局)从vars(特定于每个用户)获得的内容,因此这可能是错误的。

读:

我不知道你想要实现什么,你的方法存在多个问题。

  1. ${__setProperty(COUNT, ${COUNT_1})};

      ^ here you set an extra space before the value 

    同样要完全清楚, varsprops是不同的野兽,它们没有任何共同之处。 如果通过__setProperty函数设置属性,则无法通过vars.get()访问它,您将不得不使用props.get()

  2. vars.get(${COUNT_1})无效,您必须将其更改为以下之一:

    • `vars.get( “COUNT_1”);
    • `$ {} COUNT_1

    通常,不建议将JMeter函数和变量内联到Beanshell(和其他)脚本中,因为它们的值可能会有不同的解释。

  3. 关于

    在class'org.apache.jmeter.threads.JMeterVariables'中找不到方法get(int)

    我不知道你是如何设法将一个整数放入JMeter变量的,但如果你这样做了,你应该通过vars.getObject()函数来访问它

     int n = vars.getObject("COUNT"); 
  4. 故障排除提示:使用try块包围您的代码,您将能够在jmeter.log文件中获得更多信息性错误消息,如:

     try { //your code here } catch (Throwable ex) { log.error("something wrong", ex); throw ex; } 

我还建议您熟悉JMeter指南中的调试JDBC采样器结果

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM