从java代码调用时,Jmeter函数不执行

时间:2017-04-24 00:20:21

标签: java function jmeter

我在jmx文件中使用了一些jmeter函数。 当我使用jmeter工具从命令行运行它时,它正常运行,执行该函数并返回一个值。

当我运行java代码时,它会加载相同的jmx文件,它将函数作为字符串而不返回值。

我已经测试了几个功能,结果是一样的。 在jtl文件中,我看到类似这样的内容 - $ {__ time(yyyy-MM-dd HH:mm:ss)}

<httpSample t="663" it="0" lt="631" ts="1492989803759" s="true" lb="User-getapikey   ${__time(yyyy-MM-dd HH:mm:ss)} " rc="200" rm="" tn="Thread Group 1-1" dt="text" de="UTF-8" by="528" ng="1" na="1">

它是我的java代码,当我没有函数时它正常工作:

StandardJMeterEngine jmeter = new StandardJMeterEngine();
JMeterUtils.loadJMeterProperties(jmeterPropertiesPath);
JMeterUtils.setJMeterHome(jmeterHomePath);
JMeterUtils.initLogging();
JMeterUtils.initLocale();

SaveService.loadProperties();
HashTree testPlanTree = null;
                try{
                    log.info("loading testPlanTree");
                    testPlanTree = SaveService.loadTree(jmxFile);
                    JMeter.convertSubTree( testPlanTree );
                }catch(IOException ex){
                    log.info("error loading file as tree");
                    log.info(ex.getMessage());
                    return;
                }
                jmeter.configure(testPlanTree);
                jmeter.run();

1 个答案:

答案 0 :(得分:0)

您的代码看起来不错,只需仔细检查项目类路径中是否有ApacheJMeter_functions.jar 。该文件位于&#34; lib / ext&#34; JMeter安装的文件夹。

您可能还想添加ResultCollector以将测试执行结果存储到.jtl文件中,如:

Summariser summer = null;
String summariserName = JMeterUtils.getPropDefault("summariser.name", "summary");
if (summariserName.length() > 0) {
    summer = new Summariser(summariserName);
}

ResultCollector logger = new ResultCollector(summer);
logger.setFilename("result.jtl");
testPlanTree.add(testPlanTree.getArray()[0], logger);

查看Five Ways To Launch a JMeter Test without Using the JMeter GUI以获取有关JMeter测试执行的不同方法的更多信息,包括使用Java API启动和开发测试。