保持 JMeter 报告中请求的原始顺序
创始人
2024-11-21 13:31:41
0

要保持 JMeter 报告中请求的原始顺序,可以使用 JMeter 的事务控制器(Transaction Controller)和 Simple Data Writer 监视器。下面是一个示例代码:

  1. 添加一个事务控制器(Transaction Controller)到测试计划中,用于包含需要按原始顺序执行的请求。

  2. 在事务控制器下添加需要执行的请求。

  3. 添加一个 Simple Data Writer 监视器到测试计划中,用于将测试结果写入到文件中。

  4. 在 Simple Data Writer 监视器的配置中,指定一个文件路径和文件名来保存测试结果。

  5. 在事务控制器上右键单击,选择 "Add Parent Controller",然后选择 "Loop Controller"。这样可以确保事务控制器中的请求按照原始顺序执行。

  6. 在 Loop Controller 的配置中,将 "Loop Count" 设置为 1,这样事务控制器中的请求只会执行一次。

  7. 运行测试计划,并查看 Simple Data Writer 创建的文件,可以看到请求按照原始顺序执行的结果。

以下是示例代码:

import org.apache.jmeter.control.TransactionController;
import org.apache.jmeter.control.LoopController;
import org.apache.jmeter.engine.StandardJMeterEngine;
import org.apache.jmeter.protocol.http.sampler.HTTPSampler;
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.util.JMeterUtils;
import org.apache.jorphan.collections.HashTree;

import java.io.FileOutputStream;

public class JMeterTest {

    public static void main(String[] args) throws Exception {
        // 设置 JMeter 属性
        JMeterUtils.loadJMeterProperties("jmeter.properties");
        JMeterUtils.setJMeterHome("apache-jmeter-5.4.1");
        JMeterUtils.initLocale();

        // 创建测试计划
        TestPlan testPlan = new TestPlan();
        testPlan.setName("Test Plan");

        // 创建线程组
        SetupThreadGroup threadGroup = new SetupThreadGroup();
        threadGroup.setName("Thread Group");
        threadGroup.setNumThreads(1);
        threadGroup.setRampUp(1);
        threadGroup.setSamplerController(new LoopController());

        // 创建事务控制器
        TransactionController transactionController = new TransactionController();
        transactionController.setName("Transaction Controller");

        // 添加请求到事务控制器
        HTTPSampler sampler1 = new HTTPSampler();
        sampler1.setName("Sampler 1");
        transactionController.addTestElement(sampler1);

        HTTPSampler sampler2 = new HTTPSampler();
        sampler2.setName("Sampler 2");
        transactionController.addTestElement(sampler2);

        // 将事务控制器添加到线程组
        threadGroup.setSamplerController(transactionController);

        // 将线程组添加到测试计划
        testPlan.addThreadGroup(threadGroup);

        // 创建 Simple Data Writer 监视器
        ResultCollector resultCollector = new ResultCollector();
        resultCollector.setName("Result Collector");
        resultCollector.setFilename("result.jtl");
        resultCollector.setSaveConfig(new Summariser());

        // 创建测试计划的树状结构
        HashTree testPlanTree = new HashTree();
        testPlanTree.add(testPlan);
        HashTree threadGroupHashTree = testPlanTree.add(testPlan, threadGroup);
        threadGroupHashTree.add(transactionController);
        threadGroupHashTree.add(resultCollector);

        // 保存测试计划到文件
        SaveService.saveTree(testPlanTree, new FileOutputStream("test.jmx"));

        // 运行测试计划
        StandardJMeterEngine jmeter = new StandardJMeterEngine();
        jmeter.configure(testPlanTree);
        jmeter.run();
    }
}

以上代码示例使用 Java 编写,通过创建 JMeter 的各个组件来构建测试计划,并将其保存到文件中。然后,使用 JMeter 引擎运行测试计划。运行测试计划后,结果将保存到指定的文件中(result.jtl)。

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...