maven - Jmeter- NonGUIDriver java.lang.IllegalArgumentException 中的错误

标签 maven jmeter jmeter-plugins jmeter-maven-plugin

尝试使用 Maven 项目执行 .jmx (Jmeter)。 在 Jmeter 3.1 版本中创建了 jmx 文件。 使用 jmeter-maven-plugin 2.1.0。 使用 mvn clean verify 在命令行中执行时出现以下错误

[INFO]  P E R F O R M A N C E    T E S T S
[INFO] -------------------------------------------------------
[INFO] Invalid value detected for <postTestPauseInSeconds>.  Setting pause to 0...
[INFO]
[INFO]
[INFO] Executing test: CCMTestPlan.jmx
[INFO] Writing log file to: E:\jmeter-mvn-master\jmeter-mvn-  master\target\jmeter\logs\CCMTestPlan.jmx.log
[INFO] Error in NonGUIDriver java.lang.IllegalArgumentException: Problem loading XML from:'E:\jmeter-mvn-master\jmeter-mvn-master\target\jmeter\testFiles\CCMTestPlan.jmx', missing class com.thoughtworks.xstream.converters.ConversionException:
[INFO] ---- Debugging information ----
[INFO] cause-exception     : com.thoughtworks.xstream.converters.ConversionException
[INFO] cause-message       :
[INFO] first-jmeter-class  : org.apache.jmeter.save.converters.HashTreeConverter.unmarshal(HashTreeConverter.java:67)
[INFO] class               : org.apache.jmeter.save.ScriptWrapper
[INFO] required-type       : org.apache.jorphan.collections.ListedHashTree
[INFO] converter-type      : org.apache.jmeter.save.ScriptWrapperConverter
[INFO] path                : /jmeterTestPlan/hashTree/hashTree/hashTree/hashTree[3]/com.atlantbh.jmeter.plugins.jsonutils.jsonpathextractor.JSONPathExtractor
[INFO] line number         : 98
[INFO] version             : 3.1 r1770033
[INFO] -------------------------------

以下是我的pom.xml文件

<build>
    <plugins>
    <plugin>
        <groupId>com.lazerycode.jmeter</groupId>
        <artifactId>jmeter-maven-plugin</artifactId>
        <version>2.1.0</version>
        <configuration>
            <testResultsTimestamp>false</testResultsTimestamp>
            <jmeterPlugins>
                <plugin>
                   <groupId>kg.apc</groupId>
                   <artifactId>jmeter-plugins-extras-libs</artifactId>
                </plugin>
            </jmeterPlugins>   
            <testFilesIncluded>
                      <testFilesIncluded>CCMTestPlan.jmx</testFilesIncluded>
            </testFilesIncluded>   
            <jmeterVersion>3.1</jmeterVersion>         
        </configuration>
        <executions>
            <execution>
                <id>jmeter-tests</id>
                <phase>verify</phase>
                <goals>
                    <goal>jmeter</goal>
                </goals>                
            </execution>
        </executions>
        <dependencies>
            <dependency>
               <groupId>kg.apc</groupId>
               <artifactId>jmeter-plugins-extras-libs</artifactId>
               <version>1.3.1</version>
            </dependency>
        </dependencies>
    </plugin>
    </plugins>
</build>

有人遇到过这个问题吗?

最佳答案

插件的 2.x 版本中的依赖配置已更改(请参阅 https://github.com/jmeter-maven-plugin/jmeter-maven-plugin/wiki/Adding-additional-libraries-to-the-classpath)

Adding jar's to the /lib/ext directory

You can add any additional Java libraries to JMeter's lib/ext directory by using the <jmeterExtensions> configuration element. This uses the Eclipse Aether libraries to perform dependency resolution.

<project>
    [...]
        <build>
            <plugins>
                <plugin>
                    <groupId>com.lazerycode.jmeter</groupId>
                    <artifactId>jmeter-maven-plugin</artifactId>
                    <version>2.1.0</version>
                    <executions>
                        <execution>
                            <id>jmeter-tests</id>
                            <goals>
                                <goal>jmeter</goal>
                            </goals>
                        </execution>
                    </executions>
                    <configuration>
                        <jmeterExtensions>
                            <artifact>kg.apc:jmeter-plugins:pom:1.3.1</artifact>
                        </jmeterExtensions>
                    </configuration>
                </plugin>
            </plugins>
        </build>
    [...]
</project>
+---+

当您正确定义依赖项时,您可能会看到另一个错误,因为 jmeter-plugins 依赖于 JMeter 2.13,它具有损坏的 maven 依赖项树。这是 jmeter-plugins 团队需要解决的问题(他们需要发布一个依赖于 JMeter 3.1 的 jmeter 插件版本)。

构建将中断,因为插件正在尝试下载一些不存在的 jmeter 插件的传递依赖项,您可以通过设置来解决此问题:

<downloadExtensionDependencies>false</downloadExtensionDependencies>

然而,这确实意味着您将需要在您的 <jmeterExtensions> 中手动设置 jmeter-plugins 依赖的所有依赖项。 block 。

您可以使用 mvn dependency:tree获取 jmeter-plugins-extras-libs 包所需的完整依赖项列表。

上述信息还没有进入 Wiki(添加此信息并将所有内容移动到网站的任务正在进行中),但是在 CHANGELOG 中可用:

https://github.com/jmeter-maven-plugin/jmeter-maven-plugin/blob/master/CHANGELOG.md

关于maven - Jmeter- NonGUIDriver java.lang.IllegalArgumentException 中的错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42467401/

相关文章:

java - 在 Liferay 上部署 SpringMVC 项目。错误 : ERROR [com. liferay.portal.kernel.deploy.auto.AutoDeployScanner][AutoDeployDir:220]

maven - 将 mvn site-deploy 与 github 页面结合使用的多模块示例

gradle - 执行gradle jmeter集成时出现Jcharts错误

JMeter - 如何加载结果文件?

jmeter - 将变量从响应传递到 JMETER 中的请求

mysql - 如何在 HTTP 请求中使用来自 Jmeter JDBC 请求的响应

java - 使用 Parboiled 时出现 NoSuchMethodError : org. objectweb.asm.tree.ClassNode.<init>(I)V

java - SonarQube 本地 - 无法上传报告

testing - JMeter场景如何查找所有使用变量的地方?

maven - 从Maven执行时的JMeter插件