问题
I have following script:
<?xml version="1.0" encoding="UTF-8"?>
<taskdef resource="emma_ant.properties">
<classpath>
<pathelement location="lib/emma.jar" />
<pathelement location="lib/emma_ant.jar" />
</classpath>
</taskdef>
<target name="compile">
<mkdir dir="build"/> <!-- vytvori adresar build -->
<mkdir dir="build/classes"/>
<mkdir dir="build/test"/>
<javac destdir="build/classes" srcdir="src" debug="true" /> <!-- prelozi zdrojove kody -->
<javac destdir="build/test" srcdir="test"> <!-- prelozi testy -->
<classpath> <!-- pro prelozeni testu je potreba junit a prelozena aplikace -->
<pathelement location="lib/junit-4.5.jar" />
<pathelement location="build/classes" />
</classpath>
</javac>
</target>
<target name="build" depends="compile">
<jar destfile="tetris.jar" basedir="build/classes"> <!-- zabali aplikaci do jaru -->
<manifest>
<attribute name="Main-Class" value="tetris.Main"/>
<attribute name="Class-Path" value="lib/mysql-connector-java-5.1.6-bin.jar lib/derbyclient.jar"/>
</manifest>
</jar>
</target>
<target name="jar" depends="build"></target>
<target name="run" depends="compile">
<java classname="tetris.Main" classpath="build/classes"> <!-- spusti aplikaci -->
<classpath>
<pathelement location="lib/mysql-connector-java-5.1.6-bin.jar" />
<pathelement location="lib/derbyclient.jar" />
</classpath>
</java>
</target>
<target name="instrument" depends="compile">
<mkdir dir="build/instrumented"/>
<emma verbosity="verbose"> <!-- vytvori tridy upravene pro sledovani coverage -->
<instr instrpath="build/classes"
destdir="build/instrumented"
metadatafile="build/metadata.emma"
merge="true" />
</emma>
</target>
<target name="test" depends="instrument">
<mkdir dir="reports" />
<mkdir dir="reports/junit" />
<junit printsummary="yes" haltonfailure="no" fork="true"> <!-- pusti JUnit testy -->
<classpath>
<pathelement location="build/test" />
<pathelement location="build/classes" />
<pathelement location="build/instrumented" />
<pathelement location="lib/junit-4.5.jar" />
<pathelement location="lib/emma.jar" />
<pathelement location="lib/emma_ant.jar" />
</classpath>
<formatter usefile="false" type="brief" />
<formatter type="plain"/>
<batchtest fork="yes" todir="reports/junit"> <!-- reporty budou v adresari reports/junit -->
<fileset dir="test">
<include name="**/TetrisSuite.java"/>
</fileset>
</batchtest>
<jvmarg value="-Demma.coverage.out.file=build/coverage.emma"/>
<jvmarg value="-Demma.coverage.out.merge=true" />
</junit>
<emma enabled="true" verbosity="verbose"> <!-- vygeneruje report emmy -->
<report sourcepath="src">
<fileset dir="build" includes="*.emma" />
<html outfile="reports/coverage.html" />
</report>
</emma>
</target>
<target name="clean">
<delete dir="build"/> <!-- smaze adresar build -->
<delete dir="reports"/>
<delete file="tetris.jar"/>
</target>
It outputs this message:
processing input file [...NetBeansProjects/Tetris3/build/metadata.emma] ...
loaded 25 metadata entries
1 file(s) read and merged in 5 ms
nothing to do: no runtime coverage data found in any of the data files
What's wrong and how to fix it?
回答1:
It looks like you're picking up the non-instrumented classes.
Could be because the classpath
in your junit
task has the compiled classes (build/classes
) ahead of the instrumented (build/instrumented
). Maybe reverse these in that classpath?
EDIT
I downloaded emma and set up a basic project with one source class and one test class. I tried to run it using the build provided in the question. The only change I made was to wrap the body in a <project>
with test
as the default target. When run I got a similar message to in the question:
[report] processing input file [/Users/mjc/stack_overflow/emma/build/metadata.emma] ...
[report] loaded 1 metadata entries
[report] 1 file(s) read and merged in 6 ms
[report] nothing to do: no runtime coverage data found in any of the data files
I then set the junit classpath to put the instrumented classes ahead of the vanilla:
<classpath>
<pathelement location="build/test" />
<pathelement location="build/instrumented" />
<pathelement location="build/classes" />
<pathelement location="lib/junit.jar" />
<pathelement location="lib/emma.jar" />
<pathelement location="lib/emma_ant.jar" />
</classpath>
And reran:
[report] processing input file [/Users/mjc/stack_overflow/emma/build/coverage.emma] ...
[report] loaded 1 coverage data entries
[report] processing input file [/Users/mjc/stack_overflow/emma/build/metadata.emma] ...
[report] loaded 1 metadata entries
[report] 2 file(s) read and merged in 4 ms
[report] merged metadata contains 1 entries
[report] merged coverage data contains 1 entries
[report] writing [html] report to [/Users/mjc/stack_overflow/emma/reports/coverage.html] ...
[report] report: processing package [default package] ...
Looks like that fixed it for me. I had one test that ran:
[junit] Running SoTest
[junit] Testsuite: SoTest
[junit] Tests run: 1, Failures: 0, Errors: 0, Time elapsed: 0.081 sec
[junit] Tests run: 1, Failures: 0, Errors: 0, Time elapsed: 0.081 sec
[junit]
[junit] ------------- Standard Output ---------------
[junit] EMMA: collecting runtime coverage data ...
[junit] ------------- ---------------- ---------------
If you're not seeing any lines like that in the ant output perhaps you have no tests that match the **/TetrisSuite.java
pattern?
来源:https://stackoverflow.com/questions/2317679/how-to-change-ant-script-with-emma-code-coverage-so-it-can-find-runtime-coverage