【问题标题】:Conversion error com.thoughtworks.xstream.converters.ConversionException转换错误 com.thoughtworks.xstream.converters.ConversionException
【发布时间】:2020-07-27 09:57:19
【问题描述】:

我正在尝试自动运行 JMeter 脚本。但我收到以下错误。

INFO 2020-07-27 15:17:27.723 [jmeter.e] ():监听器将在启用运行版本后启动 INFO 2020-07-27 15:17:27.751 [jmeter.e] ():要恢复到早期的行为,请定义 jmeterengine.startlistenerslater=false INFO 2020-07-27 15:17:29.094 [jmeter.u] ():将语言环境设置为 en_US 线程“主”java.lang.NullPointerException 中的异常 在 org.apache.jmeter.engine.StandardJMeterEngine.configure(StandardJMeterEngine.java:176) 在 com.apache.maven.ApacheMavenJmeterIntegration.main(ApacheMavenJmeterIntegration.java:28)

代码

package com.apache.maven;

import java.io.FileInputStream;

import org.apache.jmeter.engine.StandardJMeterEngine;
import org.apache.jmeter.save.SaveService;
import org.apache.jmeter.util.JMeterUtils;
import org.apache.jorphan.collections.HashTree;

public class ApacheMavenJmeterIntegration {

    public static void main(String[] args) throws Exception {
        // TODO Auto-generated method stub

        StandardJMeterEngine jmeter = new StandardJMeterEngine();

        JMeterUtils.loadJMeterProperties("F:/apache-jmeter-5.3/bin/jmeter.properties");
        JMeterUtils.setJMeterHome("F:/apache-jmeter-5.3");
        JMeterUtils.initLocale();
        JMeterUtils.initLogging();

        SaveService.loadProperties();
        FileInputStream in = new FileInputStream("F:\\apache-maven-3.6.3\\bin\\src\\test\\jmeter\\PlanPackage.jmx");

        HashTree testPlanTree = SaveService.loadTree(in);
        in.close();

        jmeter.configure(testPlanTree);
        jmeter.run();

    }
}

pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.apache.maven</groupId>
    <artifactId>com.apache.maven</artifactId>
    <version>0.0.1-SNAPSHOT</version>

    <dependencies>
        <!-- https://mvnrepository.com/artifact/org.apache.maven.plugins/maven-dependency-plugin -->
        <dependency>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-dependency-plugin</artifactId>
            <version>3.1.1</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.apache.jmeter/ApacheJMeter_core -->
        <dependency>
            <groupId>org.apache.jmeter</groupId>
            <artifactId>ApacheJMeter_core</artifactId>
            <version>2.6</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.apache.jmeter/ApacheJMeter_http -->
        <dependency>
            <groupId>org.apache.jmeter</groupId>
            <artifactId>ApacheJMeter_http</artifactId>
            <version>2.8</version>
        </dependency>

    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>com.lazerycode.jmeter</groupId>
                <artifactId>jmeter-maven-plugin</artifactId>
                <version>3.1.0</version>
            </plugin>
            <plugin>
                <groupId>org.codehaus.mojo</groupId>
                <artifactId>exec-maven-plugin</artifactId>
                <version>3.0.0</version>
                <executions>
                    <execution>
                        <goals>
                            <goal>java</goal>
                        </goals>
                    </execution>
                </executions>
                <configuration>
                    <mainClass>com.apache.maven.ApacheMaven</mainClass>
                    <arguments>
                        <argument>foo</argument>
                        <argument>bar</argument>
                    </arguments>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

jmeter.log

2020/07/27 15:17:35 INFO  - jmeter.save.SaveService: Testplan (JMX) version: 2.2. Testlog (JTL) version: 2.2 
2020/07/27 15:17:35 INFO  - jmeter.save.SaveService: Using SaveService properties file encoding UTF-8 
2020/07/27 15:17:35 INFO  - jmeter.save.SaveService: Using SaveService properties version 5.0 
2020/07/27 15:17:35 WARN  - jmeter.save.SaveService: Bad _version - expected 2.2, found 5.0. 
2020/07/27 15:17:35 INFO  - jmeter.save.SaveService: All converter versions present and correct 
2020/07/27 15:17:37 ERROR - jmeter.save.SaveService: Conversion error com.thoughtworks.xstream.converters.ConversionException: org/apache/jmeter/testelement/TestStateListener : org/apache/jmeter/testelement/TestStateListener
---- Debugging information ----
message             : org/apache/jmeter/testelement/TestStateListener
cause-exception     : java.lang.NoClassDefFoundError
cause-message       : org/apache/jmeter/testelement/TestStateListener
first-jmeter-class  : org.apache.jmeter.protocol.http.sampler.HTTPSamplerBaseConverter.canConvert(HTTPSamplerBaseConverter.java:52)
class               : org.apache.jmeter.save.ScriptWrapper
required-type       : org.apache.jmeter.save.ScriptWrapper
path                : /jmeterTestPlan/hashTree
line number         : 3
------------------------------- 

【问题讨论】:

    标签: java maven jmeter jmeter-plugins


    【解决方案1】:

    如果您需要在 JMeter Maven Plugin 的帮助下运行 JMeter 测试 - 您无需编写任何代码,只需使用以下 pom.xml 文件:

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
    
        <groupId>org.example</groupId>
        <artifactId>jmeter-maven</artifactId>
        <version>1.0-SNAPSHOT</version>
    
        <build>
            <plugins>
                <plugin>
                    <groupId>com.lazerycode.jmeter</groupId>
                    <artifactId>jmeter-maven-plugin</artifactId>
                    <version>3.1.1</version>
                    <executions>
                        <!-- Generate JMeter configuration -->
                        <execution>
                            <id>configuration</id>
                            <goals>
                                <goal>configure</goal>
                            </goals>
                        </execution>
                        <!-- Run JMeter tests -->
                        <execution>
                            <id>jmeter-tests</id>
                            <goals>
                                <goal>jmeter</goal>
                            </goals>
                        </execution>
                        <!-- Fail build on errors in test -->
                        <execution>
                            <id>jmeter-check-results</id>
                            <goals>
                                <goal>results</goal>
                            </goals>
                        </execution>
                    </executions>
                    <!-- Generate HTML Reporting Dashboard -->
                    <configuration>
                        <generateReports>true</generateReports>
                    </configuration>
                </plugin>
            </plugins>
        </build>
    
    
    </project>
    

    并将您的 .jmx 测试脚本放在相对于 pom.xmlsrc/test/jmeter 文件夹下,这样您的项目将如下所示:

    - pom.xml
    - src
      - test
         - jmeter
           - your-test.jmx
    

    更多信息:How to Use the JMeter Maven Plugin

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2018-09-11
      • 1970-01-01
      • 2012-05-07
      • 1970-01-01
      • 2021-12-20
      相关资源
      最近更新 更多