当我提交开发内容时,我正在设置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
正如您所看到的,单元测试被发现但是它们被忽略了。我怎么能不跳过它们?
答案 0 :(得分:3)
这是文档所说的:
该插件仅考虑自构建开始以来更新的文件(通过上一个修改文件时间戳确定)。
有两种方法可以设置报告处理。通过build features或service 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