si configura il compito Sonar per caricare rapporti di prova dell'unità e COBERTURA generati da altre parti della vostra logica build.
Ciò è in contrasto con Maven che ha un ciclo di vita di build standard che Sonar è in grado di sfruttare.
Unità di prova e la copertura del codice
La seguente logica esegue i test di unità con cobertura strumentati classi.Un rapporto di copertura XML è generato dal cobertura alla fine:
<target name="instrument-classes" depends="compile-tests">
<taskdef resource="tasks.properties" classpathref="test.path"/>
<cobertura-instrument todir="${instrumented.classes.dir}" datafile="${build.dir}/cobertura.ser">
<fileset dir="${classes.dir}"/>
</cobertura-instrument>
</target>
<target name="junit" depends="instrument-classes">
<junit printsummary="yes" haltonfailure="yes">
<classpath>
<path refid="test.path"/>
<pathelement path="${instrumented.classes.dir}"/>
<pathelement path="${test.classes.dir}"/>
</classpath>
<formatter type="xml"/>
<batchtest fork="yes" todir="${test.reports.dir}">
<fileset dir="${test.src.dir}">
<include name="**/*Test*.java"/>
<exclude name="**/AllTests.java"/>
</fileset>
</batchtest>
</junit>
</target>
<target name="test" depends="junit">
<cobertura-report format="xml" datafile="${build.dir}/cobertura.ser" destdir="${cobertura.reports.dir}"/>
</target>
Invocare Sonar
Io di solito uso un semplice obiettivo di Sonar:
<target name="sonar" depends="test">
<taskdef uri="antlib:org.sonar.ant" resource="org/sonar/ant/antlib.xml" classpathref="sonar.path"/>
<sonar:sonar key="${sonar.project.key}" version="${sonar.project.version}" xmlns:sonar="antlib:org.sonar.ant"/>
</target>
e utilizzare un file di proprietà per controllare tutti gli aspetti del comportamento di Sonar:
sonar.project.key=org.demo:demo
sonar.project.version=1.0-SNAPSHOT
sonar.projectName=Demo project
sonar.host.url=http://myserver:9000
sonar.jdbc.url=jdbc:mysql://myserver:3306/sonar?useUnicode=true&characterEncoding=utf8
sonar.jdbc.driverClassName=com.mysql.jdbc.Driver
sonar.jdbc.username=sonar
sonar.jdbc.password=sonar
sonar.sources=${src.dir}
sonar.tests=${test.src.dir}
sonar.binaries=${classes.dir}
sonar.dynamicAnalysis=reuseReports
sonar.surefire.reportsPath=${test.reports.dir}
sonar.java.coveragePlugin=cobertura
sonar.cobertura.reportsPath=${cobertura.reports.dir}/coverage.xml
dimostra come Sonar può essere configurato per raccogliere i rapporti sui test unitari creati da junit e il rapporto sulla copertura del codice generato da cobertura.
La build non deve essere eseguita sullo stesso server di Sonar. In tal caso è necessario fornire l'URL del Sonar remoto e le credenziali JDBC.
fonte
2011-10-13 22:03:23
Aggiornamento su questo argomento: esempi possono essere trovati sul nostro repository esempio-sonar => https://github.com/SonarSource/sonar-examples/tree/master/projects/code-coverage –