NonGUIDriver中的错误 - java.lang.NullPointerException

时间:2011-08-22 17:36:29

标签: maven jmeter jmx jmeter-maven-plugin

我目前正在将jmeter与maven集成。
使用
 雅加达-Jmeter 2.4
 依赖--Jmeter2.3和所有支持的罐子  我正在通过GUI创建测试计划并将其保存为jmx  我正在使用maven-jmeter-plugin 1.0并在maven-jmeter-plugin中添加两个依赖性soap和common-logging。
 通过执行此操作,当我运行mvn verify时,它会出错:

` INFO] Executing test: C:\Documents and Settings\339298\Desktop\simple-webapp2\s
rc\test\jmeter\Graph Results.jmx
Error in NonGUIDriver java.lang.NullPointerException
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 35.156s
[INFO] Finished at: Mon Aug 22 19:17:58 IST 2011
[INFO] Final Memory: 4M/8M
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.jmeter:maven-jmeter-plugin:1.0:jmeter
(jmeter-tests) on project simple-webapp2: There were test errors -> [Help 1]
org.apache.maven.lifecycle.LifecycleExecutionException: Failed to execute goal o
rg.apache.jmeter:maven-jmeter-plugin:1.0:jmeter (jmeter-tests) on project simple
-webapp2: There were test errors
        at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor
.java:199)
        at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor
.java:148)
        at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor
.java:140)
        at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProje
ct(LifecycleModuleBuilder.java:84)
        at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProje
ct(LifecycleModuleBuilder.java:59)
        at org.apache.maven.lifecycle.internal.LifecycleStarter.singleThreadedBu
ild(LifecycleStarter.java:183)
        at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(Lifecycl
eStarter.java:161)
        at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:316)
        at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:153)
        at org.apache.maven.cli.MavenCli.execute(MavenCli.java:451)
        at org.apache.maven.cli.MavenCli.doMain(MavenCli.java:188)
        at org.apache.maven.cli.MavenCli.main(MavenCli.java:134)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.
java:39)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAcces
sorImpl.java:25)
        at java.lang.reflect.Method.invoke(Method.java:597)
        at org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced(Laun
cher.java:290)
        at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.jav
a:230)
        at org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode(La
uncher.java:409)
        at org.codehaus.plexus.classworlds.launcher.Launcher.main(Launcher.java:
352)
Caused by: org.apache.maven.plugin.MojoFailureException: There were test errors
        at org.apache.jmeter.JMeterMojo.checkForErrors(JMeterMojo.java:115)
        at org.apache.jmeter.JMeterMojo.execute(JMeterMojo.java:102)
        at org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo(Default
BuildPluginManager.java:107)
        at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor
.java:195)
        ... 19 more
[ERROR]
[ERROR]
[ERROR] For more information about the errors and possible solutions, please rea
d the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoFailureExc
eption
'

我的项目Pom是:

'<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/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>org.parveen.webExample</groupId>
  <artifactId>simple-webapp2</artifactId>
  <packaging>war</packaging>
  <version>1.0-SNAPSHOT</version>
  <name>simple-webapp Maven Webapp</name>
  <url>http://maven.apache.org</url>
  <dependencies>
    <dependency>
            <groupId>org.parveen.coreExample</groupId>
            <artifactId>simple-core</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
    <dependency>
            <groupId>ApacheJMeter_core</groupId>
            <artifactId>ApacheJMeter_core</artifactId>
            <version>1.0</version>
        </dependency>






    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.8.2</version>
      <scope>test</scope>
    </dependency>
    <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>servlet-api</artifactId>
            <version>2.5</version>
        </dependency>
  </dependencies>
  <build>
    <finalName>simple-webapp</finalName>
    <!-- <directory>C:\Documents and Settings\339298\Desktop\parveen</directory>-->
    <plugins> 
      <plugin>
        <groupId>org.mortbay.jetty</groupId> 
        <artifactId>maven-jetty-plugin</artifactId>
        <version>6.1.26</version> 
      </plugin> 

        <!--<plugin>
           <groupId>org.apache.jmeter</groupId>
           <artifactId>maven-jmeter-plugin</artifactId>
            <version>1.0</version>
     <executions>
                     <execution>
                           <phase>integration-test</phase>
                         <id>jmeter-tests</id>

                       <goals>
                             <goal>jmeter</goal>
                         </goals>
                     </execution>
                 </executions>
         </plugin>-->
         <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-plugin-plugin</artifactId>
        <version>2.8</version>
        <configuration>
          <goalPrefix>plugin</goalPrefix>
          <outputDirectory>target</outputDirectory>
        </configuration>
      </plugin>


            <plugin>         
               <groupId>org.apache.jmeter</groupId> 
               <artifactId>maven-jmeter-plugin</artifactId>     
                <version>1.0</version>         
                <executions>               
                  <execution>                  
                      <id>jmeter-tests</id>       
                      <phase>verify</phase> 
                      <goals>  
                           <goal>jmeter</goal>                  
                      </goals>                   
                      <configuration>                      
                         <reportDir>${project.build.directory}/jmeter-reports</reportDir>  
                       </configuration>               
                  </execution>          
                </executions>       
            </plugin>       
            <plugin>          
                  <groupId>org.codehaus.mojo</groupId>           
                  <artifactId>xml-maven-plugin</artifactId>          
                  <version>1.0-beta-2</version>          
                  <executions>               
                    <execution>               
                      <phase>pre-site</phase>               
                         <goals>                   
                      <goal>transform</goal>               
                      </goals>               
                      </execution>           
                   </executions>           
                   <configuration>              
                      <transformationSets>                   
                        <transformationSet>                      
                            <dir>${project.build.directory}/jmeter-reports</dir>                 
                            <stylesheet>src/test/resources/jmeter-results-detail-report_21.xsl</stylesheet>                      
                            <outputDir>${project.build.directory}/site/jmeter-results</outputDir>                       
                            <fileMappers>                           
                              <fileMapper implementation="org.codehaus.plexus.components.io.filemappers.FileExtensionMapper">   
                                <targetExtension>html</targetExtension>                        
                              </fileMapper>                      
                             </fileMappers>                  
                         </transformationSet>               
                       </transformationSets>           
                     </configuration>       
                </plugin>   
          </plugins>


  </build>
</project>
'
在网上,我有三个解决方案:

  1. java版
  2. 添加soap和common-loggin依赖
  3. 在.jmx文件中,TestPlan标记应该是根元素并保存testby右键单击TestPlan
  4. 然而,这些都不适合我。

3 个答案:

答案 0 :(得分:1)

使用最新版本(撰写本文时为1.4)。

现在可以在中央maven回购中找到,有关更多信息,请查看项目网站 - &gt; http://jmeter.lazerycode.com

答案 1 :(得分:0)

请注意,如果您使用的是JMeter 2.4中的JMeter功能(即JMeter 2.3中不存在),maven-jmeter-plugin将不会是最新的并且无法正确处理 - 因为它基于JMeter 2.3。

我还会查看你的jmeter.log以获取更多信息。

答案 2 :(得分:0)

使用版本1.10.1时遇到了同样的问题,并意识到我使用的是自定义插件。移除它们并使用jmeter测试计划开箱后解决了问题。