2016-12-28 20 views
0

ANTを使用してjMeterテストのHTML/Junitスタイルレポートを生成しようとしています。私はこのためのビルドファイルを作成しており、次のような前提条件をすべて満たしています。 java home、ant home、path variablesなどの必要な変数を設定します。 antビルドファイルと必要な.jmxファイル(jmeter実行用)をフォルダに入れ、同じフォルダを指す "ant"コマンドを呼び出します。 antant -Dtest = "Sample Workload Script"というコマンドを与えて、antビルドファイルを呼び出そうとしました。ANTを使用してHTML(junitスタイル)レポートを作成するときの問題

私は、このコマンドを実行すると、テストプランを実行する時点まで達してから、Javaプラットフォームのエラーが発生し(ビルドされたイメージに示されているように)、ビルドを停止します。これを引き起こしている可能性のあることへのあらゆる指針?

Java Platform Error when running the ANT Build file

私はANTのバージョンは、Java 1.8と互換性がないかもしれないことをどこかで読みました。そういえば、私はAntの1.9.7とJavaを使用しています1.8.73

私のビルドファイル:あなたのbuild.xmlファイルの

<?xml version="1.0"?> 
<!-- 
    Licensed to the Apache Software Foundation (ASF) under one or more 
    contributor license agreements. See the NOTICE file distributed with 
    this work for additional information regarding copyright ownership. 
    The ASF licenses this file to You under the Apache License, Version 2.0 
    (the "License"); you may not use this file except in compliance with 
    the License. You may obtain a copy of the License at 

     http://www.apache.org/licenses/LICENSE-2.0 

    Unless required by applicable law or agreed to in writing, software 
    distributed under the License is distributed on an "AS IS" BASIS, 
    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 
    See the License for the specific language governing permissions and 
    limitations under the License. 
--> 
<project name="ant-jmeter" default="all"> 
    <description> 

     Sample build file for use with ant-jmeter.jar 
     See http://www.programmerplanet.org/pages/projects/jmeter-ant-task.php 

    To run a test and create the output report: 
     ant -Dtest=script 

    To run a test only: 
     ant -Dtest=script run 

    To run report on existing test output 
     ant -Dtest=script report 

    The "script" parameter is the name of the script without the .jmx suffix. 

    Additional options: 
     -Dshow-data=y - include response data in Failure Details 
     -Dtestpath=xyz - path to test file(s) (default user.dir). 
         N.B. Ant interprets relative paths against the build file 
     -Djmeter.home=.. - path to JMeter home directory (defaults to parent of this build file) 
     -Dreport.title="My Report" - title for html report (default is 'Load Test Results') 

     Deprecated: 
     -Dformat=2.0 - use version 2.0 JTL files rather than 2.1 

    </description> 

    <property name="testpath" value="${user.dir}"/>     <!--<property name="testpath" value="${user.dir}"/>--> 
    <property name="jmeter.home" value="C:\apache-jmeter-3.0"/> 
    <property name="report.title" value="Load Test Results"/> 

    <!-- Name of test (without .jmx) --> 
    <property name="test" value="Test"/> 

    <!-- Should report include response data for failures? --> 
    <property name="show-data" value="n"/> 

    <property name="format" value="2.1"/> 

    <condition property="style_version" value=""> 
     <equals arg1="${format}" arg2="2.0"/> 
    </condition> 

    <condition property="style_version" value="_21"> 
     <equals arg1="${format}" arg2="2.1"/> 
    </condition> 

    <condition property="funcMode"> 
     <equals arg1="${show-data}" arg2="y"/> 
    </condition> 

    <condition property="funcMode" value="false"> 
     <not> 
     <equals arg1="${show-data}" arg2="y"/> 
     </not> 
    </condition> 

    <!-- Allow jar to be picked up locally --> 
    <path id="jmeter.classpath"> 
     <fileset dir="${basedir}"> 
      <include name="ant-jmeter*.jar"/> 
     </fileset> 
    </path> 

    <taskdef 
     name="jmeter" 
     classname="org.programmerplanet.ant.taskdefs.jmeter.JMeterTask"/> 
    <!--classpathref="jmeter.classpath"--> 
    <!--classpathref="C:\apache-jmeter-3.0\extras"--> 

    <target name="all" depends="run,report"/> 

    <target name="run"> 
     <echo>funcMode = ${funcMode}</echo> 
     <delete file="${testpath}/${test}.html"/> 
     <jmeter 
      jmeterhome="${jmeter.home}" 
      testplan ="${basedir}/${test}.jmx"   
      resultlog="${basedir}/${test}.jtl"> 
     <!-- 
      <jvmarg value="-Xincgc"/> 
      <jvmarg value="-Xmx128m"/> 
      <jvmarg value="-Dproperty=value"/> 
      <jmeterarg value="-qextra.properties"/> 
     --> 
      <!-- Force suitable defaults --> 
      <property name="jmeter.save.saveservice.output_format" value="xml"/> 
      <property name="jmeter.save.saveservice.assertion_results" value="all"/> 
      <property name="jmeter.save.saveservice.bytes" value="true"/> 
      <property name="file_format.testlog" value="${format}"/> 
      <property name="jmeter.save.saveservice.response_data.on_error" value="${funcMode}"/> 
     </jmeter> 
    </target> 

    <property name="lib.dir" value="${jmeter.home}/lib"/> 

    <!-- Use xalan copy from JMeter lib directory to ensure consistent processing with Java 1.4+ --> 
    <path id="xslt.classpath"> 
     <fileset dir="${lib.dir}" includes="xalan*.jar"/> 
     <fileset dir="${lib.dir}" includes="serializer*.jar"/> 
    </path> 

    <target name="report" depends="xslt-report,copy-images"> 
     <echo>Report generated at ${report.datestamp}</echo> 
    </target> 

    <target name="xslt-report" depends="_message_xalan"> 
     <tstamp><format property="report.datestamp" pattern="yyyy/MM/dd HH:mm"/></tstamp> 
     <xslt 
      classpathref="xslt.classpath" 
      force="true" 
      in="${basedir}/${test}.jtl" 
      out="${basedir}/${test}.html" 
      style="${basedir}/jmeter-results-detail-report${style_version}.xsl"> 
      <param name="showData" expression="${show-data}"/> 
      <param name="titleReport" expression="${report.title}"/> 
      <param name="dateReport" expression="${report.datestamp}"/> 
     </xslt> 
    </target> 

    <!-- Copy report images if needed --> 
    <target name="copy-images" depends="verify-images" unless="samepath"> 
     <copy file="${basedir}/expand.png" tofile="${testpath}/expand.png"/> 
     <copy file="${basedir}/collapse.png" tofile="${testpath}/collapse.png"/> 
    </target> 

    <target name="verify-images"> 
     <condition property="samepath"> 
       <equals arg1="${testpath}" arg2="${basedir}" /> 
     </condition> 
    </target> 

    <!-- Check that the xalan libraries are present --> 
    <condition property="xalan.present"> 
      <and> 
       <!-- No need to check all jars; just check a few --> 
      <available classpathref="xslt.classpath" classname="org.apache.xalan.processor.TransformerFactoryImpl"/> 
      <available classpathref="xslt.classpath" classname="org.apache.xml.serializer.ExtendedContentHandler"/> 
      </and> 
    </condition> 

    <target name="_message_xalan" unless="xalan.present"> 
      <echo>Cannot find all xalan and/or serialiser jars</echo> 
     <echo>The XSLT formatting may not work correctly.</echo> 
     <echo>Check you have xalan and serializer jars in ${lib.dir}</echo> 
    </target> 


</project> 

答えて

0

アップデート "のJMeter" セクションを次のように

<jmeter 
    jmeterhome="${jmeter.home}" 
    testplan ="${basedir}/${test}.jmx"   
    resultlog="${basedir}/${test}.jtl" 
    jmeterlogfile="${basedir}/jmeter.log"> <!-- add this line to enabled logging--> 

再あなたのテストを実行し、C:\workspace\CPTフォルダのファイルをjmeter.logファイルに調べてください。十分なトラブルシューティング情報が含まれている必要があります。ログファイルの解釈に問題がある場合は、質問に追加してください。

参考文献:

+0

私はラインを追加し、それを実行しました。ベースディレクトリにjmeter.logファイルがありません。 – MitSM

+0

ところで、私はJavaのバージョンをチェックしている間に曖昧さがあります。 – MitSM

+0

** java -version **を実行すると、Javaのバージョン1.8.0_73 " Java(TM)SEランタイム環境(ビルド1.8.0_73-b02) Java HotSpot(TM)64ビットサーバVMビルド25.73-b02、混合モード) '。 ** javac -version **を実行すると、javac 1.8.0_60が表示されます。これは中核となる問題ですか? – MitSM

関連する問題