TeamCity Ant Junit 2报告被忽略为过时

时间:2014-02-23 10:27:27

标签: ant junit teamcity

当我提交开发内容时,我正在设置TeamCity来执行自动构建。问题是,在尝试进行构建时,我收到了reports skipped as out-of-date消息。

这是我的build.xml

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!-- WARNING: Eclipse auto-generated file.
              Any modifications will be overwritten.
              To include a user specific buildfile here, simply create one in the same
              directory with the processing instruction <?eclipse.ant.import?>
              as the first entry and export the buildfile again. -->
<project basedir="." default="build" name="RNS-Reader-v0.1">
    <property environment="env"/>
    <property name="ECLIPSE_HOME" value="../../../../../../../Applications/eclipse"/>
    <property name="junit.output.dir" value="junit"/>
    <property name="debuglevel" value="source,lines,vars"/>
    <property name="target" value="1.6"/>
    <property name="source" value="1.6"/>
    <path id="RNS-Reader-v0.1.classpath">
        <pathelement location="bin"/>
        <pathelement location="src/libraries/cron4j-2.2.5.jar"/>
        <pathelement location="src/libraries/dom4j-1.6.1.jar"/>
        <pathelement location="src/libraries/jaxen-1.1.3.jar"/>
        <pathelement location="src/libraries/joda-time-2.3.jar"/>
        <pathelement location="src/libraries/mysql-connector-java-5.1.25-bin.jar"/>
        <pathelement location="src/libraries/javax.mail.jar"/>
        <pathelement location="src/libraries/jsoup-1.7.3.jar"/>
        <pathelement location="src/libraries/commons-io-2.4.jar"/>
        <pathelement location="src/libraries/twitter4j-async-3.0.5.jar"/>
        <pathelement location="src/libraries/twitter4j-core-3.0.5.jar"/>
        <pathelement location="src/libraries/twitter4j-examples-3.0.5.jar"/>
        <pathelement location="src/libraries/twitter4j-media-support-3.0.5.jar"/>
        <pathelement location="src/libraries/twitter4j-stream-3.0.5.jar"/>
        <pathelement location="src/libraries/hamcrest-core-1.3.jar"/>
        <pathelement location="src/libraries/junit-4.11.jar"/>
    </path>
    <target name="init">
        <mkdir dir="bin"/>
        <copy includeemptydirs="false" todir="bin">
            <fileset dir="src">
                <exclude name="**/*.java"/>
            </fileset>
        </copy>
    </target>
    <target name="clean">
        <delete dir="bin"/>
    </target>
    <target depends="clean" name="cleanall"/>
    <target depends="build-subprojects,build-project" name="build"/>
    <target name="build-subprojects"/>
    <target depends="init" name="build-project">
        <echo message="${ant.project.name}: ${ant.file}"/>
        <javac debug="true" debuglevel="${debuglevel}" destdir="bin" includeantruntime="false" source="${source}" target="${target}">
            <src path="src"/>
            <classpath refid="RNS-Reader-v0.1.classpath"/>
        </javac>
    </target>
    <target description="Build all projects which reference this project. Useful to propagate changes." name="build-refprojects"/>
    <target description="copy Eclipse compiler jars to ant lib directory" name="init-eclipse-compiler">
        <copy todir="${ant.library.dir}">
            <fileset dir="${ECLIPSE_HOME}/plugins" includes="org.eclipse.jdt.core_*.jar"/>
        </copy>
        <unzip dest="${ant.library.dir}">
            <patternset includes="jdtCompilerAdapter.jar"/>
            <fileset dir="${ECLIPSE_HOME}/plugins" includes="org.eclipse.jdt.core_*.jar"/>
        </unzip>
    </target>
    <target description="compile project with Eclipse compiler" name="build-eclipse-compiler">
        <property name="build.compiler" value="org.eclipse.jdt.core.JDTCompilerAdapter"/>
        <antcall target="build"/>
    </target>
    <target name="RNSReader">
        <java classname="RNSReader" failonerror="true" fork="yes">
            <classpath refid="RNS-Reader-v0.1.classpath"/>
        </java>
    </target>
    <target name="SubscriberTest">
        <mkdir dir="${junit.output.dir}"/>
        <junit fork="yes" printsummary="withOutAndErr">
            <formatter type="xml"/>
            <test name="tests.domainObjectsTest.SubscriberTest" todir="${junit.output.dir}"/>
            <classpath refid="RNS-Reader-v0.1.classpath"/>
        </junit>
    </target>
    <target name="DayTradeTest">
        <mkdir dir="${junit.output.dir}"/>
        <junit fork="yes" printsummary="withOutAndErr">
            <formatter type="xml"/>
            <test name="tests.domainObjectsTest.DayTradeTest" todir="${junit.output.dir}"/>
            <classpath refid="RNS-Reader-v0.1.classpath"/>
        </junit>
    </target>
    <target name="junitreport">
        <junitreport todir="${junit.output.dir}">
            <fileset dir="${junit.output.dir}">
                <include name="TEST-*.xml"/>
            </fileset>
            <report format="frames" todir="${junit.output.dir}"/>
        </junitreport>
    </target>
</project>

这是我的输出

[10:09:12]Checking for changes
[10:09:13]Ant JUnit report watcher
[10:09:13][Ant JUnit report watcher] Watching paths:
[10:09:13][Ant JUnit report watcher] src/**/*Test*.java
[10:09:13]Publishing internal artifacts
[10:09:13]Clearing temporary directory: /Users/christianmacedo/Documents/TeamCity/buildAgent/temp/buildTmp
[10:09:13]Checkout directory: /Users/christianmacedo/Documents/TeamCity/buildAgent/work/ec7b4331d9c6af60
[10:09:13]Updating sources: server side checkout
[10:09:13]Step 1/1: Ant (2s)
[10:09:16]Ant JUnit report watcher
[10:09:16][Ant JUnit report watcher] 2 reports found for paths:
[10:09:16][Ant JUnit report watcher] src/**/*Test*.java
[10:09:16][Ant JUnit report watcher] 2 reports skipped as out-of-date
[10:09:16]Publishing internal artifacts
[10:09:16][Publishing internal artifacts] Sending using WebPublisher
[10:09:16][Publishing internal artifacts] Sending using ArtifactsCachePublisher
[10:09:16]Build finished

正如您所看到的,单元测试被发现但是它们被忽略了。我怎么能跳过它们?

2 个答案:

答案 0 :(得分:3)

这是文档所说的:

  

该插件仅考虑自构建开始以来更新的文件(通过上一个修改文件时间戳确定)。

有两种方法可以设置报告处理。通过build featuresservice messages。 如果通过服务消息执行此操作,则可以将parseOutOfDate='true'设置为忽略文件上的时间戳。

##teamcity[importData type='typeID' path='<path>' parseOutOfDate='true']

答案 1 :(得分:0)

确保您的服务器上已同步时间。在我的情况下(Debian 8.5),通过设置ntpdate daily cron修复了同样的问题:

sudo apt-get install ntpdate
sudo ln -s /usr/sbin/ntpdate-debian /etc/cron.daily/ntpdate-debian