Как изменить скрипт Ant с охватом кода EMMA, чтобы он мог найти данные покрытия во время выполнения? - PullRequest
1 голос
/ 23 февраля 2010

У меня есть следующий скрипт:

<?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>

Выводит это сообщение:

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

Что не так и как это исправить?

1 Ответ

3 голосов
/ 24 февраля 2010

Похоже, вы выбираете неинструментированные классы.

Возможно, потому что classpath в вашей задаче junit имеет скомпилированные классы (build/classes) впереди инструментальных (build/instrumented). Может быть, поменять их в этом classpath?

EDIT

Я скачал emma и настроил базовый проект с одним исходным классом и одним тестовым классом. Я попытался запустить его, используя сборку, представленную в вопросе. Единственное изменение, которое я сделал, заключалось в том, чтобы обернуть тело в <project> с test в качестве цели по умолчанию. При запуске я получил похожее сообщение в вопросе:

[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

Затем я установил путь к классу junit, чтобы поставить инструментальные классы впереди ванили:

<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>

и реран:

[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] ...

Похоже, это исправило это для меня. У меня был один тест, который побежал:

[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] ------------- ---------------- ---------------

Если вы не видите таких строк в выводе ant, возможно, у вас нет тестов, соответствующих шаблону **/TetrisSuite.java?

...