java - 在 Java 代码中运行 JMeter - JMeterThread 不运行采样器

标签 java jmeter

所以我在我的maven项目中使用这个例子:

public class JMeterFromScratch {

public static void main(String[] argv) throws Exception {

    //JMeter Engine
    StandardJMeterEngine jmeter = new StandardJMeterEngine();

    //JMeter initialization (properties, log levels, locale, etc)
    JMeterUtils.loadJMeterProperties("C:/git/my-project/src/main/resources/config/jmeter.properties");
    //JMeterUtils.initLogging();// you can comment this line out to see extra log messages of i.e. DEBUG level
    JMeterUtils.initLocale();

    // JMeter Test Plan
    HashTree testPlanTree = new HashTree();

    // HTTP Sampler
    HTTPSampler httpSampler = new HTTPSampler();
    httpSampler.setDomain("example.com");
    httpSampler.setPort(80);
    httpSampler.setPath("/");
    httpSampler.setMethod("GET");

    // Loop Controller
    TestElement loopController = new LoopController();
    ((LoopController)loopController).setLoops(1);
    loopController.addTestElement(httpSampler);
    ((LoopController)loopController).setFirst(true);
    ((LoopController)loopController).initialize();

    // Thread Group

    SetupThreadGroup threadGroup = new SetupThreadGroup();
    threadGroup.setNumThreads(1);
    threadGroup.setRampUp(1);
    threadGroup.setSamplerController(((LoopController)loopController));

    // Test Plan
    TestPlan testPlan = new TestPlan("Create JMeter Script From Java Code");

    // Construct Test Plan from previously initialized elements
    testPlanTree.add("testPlan", testPlan);
    testPlanTree.add("loopController", loopController);
    testPlanTree.add("threadGroup", threadGroup);
    testPlanTree.add("httpSampler", httpSampler);

    // Run Test Plan
    jmeter.configure(testPlanTree);
    jmeter.run();

}

其中我有以下依赖项:

    <dependency>
        <groupId>org.apache.jmeter</groupId>
        <artifactId>ApacheJMeter_core</artifactId>
        <version>3.1</version>
    </dependency>
    <dependency>
        <groupId>org.apache.jmeter</groupId>
        <artifactId>ApacheJMeter_http</artifactId>
        <version>2.13</version>
    </dependency>

奇怪的是,我看到在 ThreadGroup 类中,在 makeThread() 方法中,有这一行:

JMeterThread jmeterThread = new JMeterThread(this.cloneTree(threadGroupTree), this, notifier);

cloneTree 的调用似乎确实克隆了树,但在 LoopController 中缺少采样器。所以当 JMeterThread 到达这里时:

Sampler sampler = this.threadGroupLoopController.next(); // returns null

            while(true) {
                while(this.running && sampler != null) {

sampler 为空,因此没有可执行的内容。

那我做错了什么?

谢谢。

最佳答案

  1. 我不喜欢你的 pom.xml 版本不匹配, 我相信你应该使用 <version>3.1</version>对于两个组件
  2. 我不喜欢您构建测试计划的方式,它应该是这样的:

    testPlanTree.add(testPlan);
    HashTree threadGroupHashTree = testPlanTree.add(testPlan, threadGroup);
    threadGroupHashTree.add(httpSampler);
    
  3. 我认为你应该添加登录 .jtl文件以便能够看到结果

完整代码以防万一:

import org.apache.jmeter.config.Arguments;
import org.apache.jmeter.config.gui.ArgumentsPanel;
import org.apache.jmeter.control.LoopController;
import org.apache.jmeter.control.gui.LoopControlPanel;
import org.apache.jmeter.control.gui.TestPlanGui;
import org.apache.jmeter.engine.StandardJMeterEngine;
import org.apache.jmeter.protocol.http.control.gui.HttpTestSampleGui;
import org.apache.jmeter.protocol.http.sampler.HTTPSamplerProxy;
import org.apache.jmeter.reporters.ResultCollector;
import org.apache.jmeter.reporters.Summariser;
import org.apache.jmeter.save.SaveService;
import org.apache.jmeter.testelement.TestElement;
import org.apache.jmeter.testelement.TestPlan;
import org.apache.jmeter.threads.SetupThreadGroup;
import org.apache.jmeter.threads.gui.SetupThreadGroupGui;
import org.apache.jmeter.util.JMeterUtils;
import org.apache.jorphan.collections.HashTree;

import java.io.FileOutputStream;

public class JMeterFromScratch {

    public static void main(String[] args) throws Exception {
        //JMeter Engine
        StandardJMeterEngine jmeter = new StandardJMeterEngine();

        //JMeter initialization (properties, log levels, locale, etc)
        JMeterUtils.loadJMeterProperties("/path/to/jmeter/bin/jmeter.properties");
        JMeterUtils.setJMeterHome("/path/to/jmeter/");            
        JMeterUtils.initLocale();

        // JMeter Test Plan
        HashTree testPlanTree = new HashTree();

        // HTTP Sampler
        HTTPSamplerProxy httpSampler = new HTTPSamplerProxy();
        httpSampler.setName("HTTP Request");
        httpSampler.setDomain("example.com");
        httpSampler.setPort(80);
        httpSampler.setPath("/");
        httpSampler.setMethod("GET");
        httpSampler.setProperty(TestElement.TEST_CLASS, HTTPSamplerProxy.class.getName());
        httpSampler.setProperty(TestElement.GUI_CLASS, HttpTestSampleGui.class.getName());


        // Loop Controller
        TestElement loopController = new LoopController();
        ((LoopController) loopController).setLoops(1);
        loopController.addTestElement(httpSampler);
        ((LoopController) loopController).setFirst(true);
        loopController.setProperty(TestElement.TEST_CLASS, LoopController.class.getName());
        loopController.setProperty(TestElement.GUI_CLASS, LoopControlPanel.class.getName());
        ((LoopController) loopController).initialize();

        // Thread Group

        SetupThreadGroup threadGroup = new SetupThreadGroup();
        threadGroup.setNumThreads(1);
        threadGroup.setRampUp(1);
        threadGroup.setName("setUp Thread Group");
        threadGroup.setSamplerController(((LoopController) loopController));
        threadGroup.setProperty(TestElement.TEST_CLASS, SetupThreadGroup.class.getName());
        threadGroup.setProperty(TestElement.GUI_CLASS, SetupThreadGroupGui.class.getName());

        // Test Plan
        TestPlan testPlan = new TestPlan("Create JMeter Script From Java Code");
        testPlan.setProperty(TestElement.TEST_CLASS, TestPlan.class.getName());
        testPlan.setProperty(TestElement.GUI_CLASS, TestPlanGui.class.getName());
        testPlan.setUserDefinedVariables((Arguments) new ArgumentsPanel().createTestElement());

        // Construct Test Plan from previously initialized elements
        testPlanTree.add(testPlan);
        HashTree threadGroupHashTree = testPlanTree.add(testPlan, threadGroup);
        threadGroupHashTree.add(httpSampler);


        // save generated test plan to JMeter's .jmx file format
        SaveService.saveTree(testPlanTree, new FileOutputStream("test.jmx"));

        //add Summarizer output to get test progress in stdout like:
        // summary =      2 in   1.3s =    1.5/s Avg:   631 Min:   290 Max:   973 Err:     0 (0.00%)
        Summariser summer = null;
        String summariserName = JMeterUtils.getPropDefault("summariser.name", "summary");
        if (summariserName.length() > 0) {
            summer = new Summariser(summariserName);
        }


        // Store execution results into a .jtl file
        String logFile = "test.jtl";
        ResultCollector logger = new ResultCollector(summer);
        logger.setFilename(logFile);
        testPlanTree.add(testPlanTree.getArray()[0], logger);

        // Run Test Plan
        jmeter.configure(testPlanTree);
        jmeter.run();

        System.out.println("Test completed. See test.jtl file for results");
        System.out.println("Open test.jmx file in JMeter GUI to validate the code");
        System.exit(0);
    }
}

您可以使用 https://bitbucket.org/blazemeter/jmeter-from-code/ Five Ways To Launch a JMeter Test without Using the JMeter GUI 中提到的 repo文章以获取引用工作代码。

关于java - 在 Java 代码中运行 JMeter - JMeterThread 不运行采样器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42244208/

相关文章:

java - JMeter 对文件的响应(仅将其附加到一个文件)

jmeter - 将 Jmeter 结果保存到 csv 的正确方法 - 如何最终确定结果文件

java - 在 JMeter Java MD5 哈希函数中并不总是有一个正确的 secret

java - 自己插入 LeafElement

java - 如何在Java中制作圆角图像

java - 如何提高PostgreSQL数据库中海量数据的查询效率?

java - 扩展 JMeter 还是编写复杂的场景?

java - 从 Android 异步嵌套类返回值

java - 自定义 primefaces 日历 以自定义样式显示假期

java - 如何在jmeter中通过restful api上传文件zip