Guy*_*ond 15 ant build deferred-execution
我有一个Ant构建文件,我尝试使用以下命令在命令行中执行它:
$ C:\Program Files (x86)\.....>ant -f C:\Silk4J\Automation\iControlSilk4J\build.xml
Run Code Online (Sandbox Code Playgroud)
但没有任何反应,结果是:
BUILD SUCCESSFUL
Total time: 0 seconds
Run Code Online (Sandbox Code Playgroud)
我的环境变量是正确的.
问题是什么?这是我的构建文件:
<?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="iControlSilk4J">
<property environment="env"/>
<property name="ECLIPSE_HOME" value="../../../Program Files (x86)/Silk/SilkTest/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="Silk Test JTF 13.5.0 Library.libraryclasspath">
<pathelement location="../../../Program Files (x86)/Silk/SilkTest/ng/JTF/silktest-jtf-nodeps.jar"/>
</path>
<path id="JUnit 4.libraryclasspath">
<pathelement location="${ECLIPSE_HOME}/plugins/org.junit_4.8.2.v4_8_2_v20110321-1705/junit.jar"/>
<pathelement location="${ECLIPSE_HOME}/plugins/org.hamcrest.core_1.1.0.v20090501071000.jar"/>
</path>
<path id="iControlSilk4J.classpath">
<pathelement location="bin"/>
<pathelement location="lib/apache-log4j.jar"/>
<pathelement location="lib/commons-io-2.4.jar"/>
<pathelement location="lib/commons-lang3-3.1.jar"/>
<pathelement location="lib/junit.jar"/>
<pathelement location="lib/org.hamcrest.core_1.1.0.v20090501071000.jar"/>
<pathelement location="lib/silktest-jtf-nodeps.jar"/>
<path refid="Silk Test JTF 13.5.0 Library.libraryclasspath"/>
<path refid="JUnit 4.libraryclasspath"/>
<pathelement location="../../../Users/Admin/Desktop/java-mail-1.4.4.jar"/>
<pathelement location="../../../Users/Admin/Desktop/javax.activation.jar"/>
<pathelement location="lib/joda-time-2.3.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" source="${source}" target="${target}">
<src path="src"/>
<classpath refid="iControlSilk4J.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"/>
...
Run Code Online (Sandbox Code Playgroud)
Dav*_* W. 21
转到Ant网站下载.这样,您就可以在 Eclipse 之外获得Ant的副本.我建议把它放在C:\ant目录下.这样,它在目录名称中没有任何空格.在"系统控制面板"中,将"环境变量" ANT_HOME设置为此目录,然后预先挂起到"系统" PATH变量%ANT_HOME%\bin.这样,您就不必输入整个目录名称.
假设您执行了以上操作,请尝试以下操作:
C:\> cd \Silk4J\Automation\iControlSilk4J
C:\Silk4J\Automation\iControlSilk4J> ant -d build
Run Code Online (Sandbox Code Playgroud)
这将做几件事:
build.xml在目录中执行它,因此您最终可能无法找到Ant构建无法找到的特定目录.该-d会打印出大量的输出,所以你可能想捕捉它,或者你的终端缓冲区设置类似99999,然后运行cls首先要清除缓冲区.这样,您将捕获终端缓冲区中开头的所有输出.
让我们看看Ant应该如何执行.您没有指定要执行的任何目标,因此Ant应该采用默认build目标.这里是:
<target depends="build-subprojects,build-project" name="build"/>
Run Code Online (Sandbox Code Playgroud)
该build目标不执行任何操作本身.但是,它取决于另外两个目标,因此将首先调用这些目标:
第一个目标是build-subprojects:
<target name="build-subprojects"/>
Run Code Online (Sandbox Code Playgroud)
这什么都不做.它甚至没有依赖性.
指定的下一个目标build-project是否有代码:
<target depends="init" name="build-project">
Run Code Online (Sandbox Code Playgroud)
此目标确实包含任务和一些依赖目标.在build-project执行之前,它将首先运行init目标:
<target name="init">
<mkdir dir="bin"/>
<copy includeemptydirs="false" todir="bin">
<fileset dir="src">
<exclude name="**/*.java"/>
</fileset>
</copy>
</target>
Run Code Online (Sandbox Code Playgroud)
此目标创建一个名为的目录bin,然后将src带有后缀的树下的所有文件复制*.java到该bin目录.的includeemptydirs,如果没有非Java代码目录不会被创建平均值.
Ant使用一种方案来完成最少的工作.例如,如果bin创建了目录,<mkdir/>则不执行任务.此外,如果先前已复制文件,或者src目录树中没有非Java文件,则该<copy/>任务将不会运行.但是,init目标仍将执行.
接下来,我们回到之前的build-project目标:
<target depends="init" name="build-project">
<echo message="${ant.project.name}: ${ant.file}"/>
<javac debug="true" debuglevel="${debuglevel}" destdir="bin" source="${source}" target="${target}">
<src path="src"/>
<classpath refid="iControlSilk4J.classpath"/>
</javac>
</target>
Run Code Online (Sandbox Code Playgroud)
看看这一行:
<echo message="${ant.project.name}: ${ant.file}"/>
Run Code Online (Sandbox Code Playgroud)
应该总是执行.你的输出打印出来了:
[echo] iControlSilk4J: C:\Silk4J\Automation\iControlSilk4J\build.xml
Run Code Online (Sandbox Code Playgroud)
也许你没有意识到那是你的构建.
之后,它运行<javac/>任务.也就是说,如果有任何文件要实际编译.同样,Ant试图避免它不必做的工作.如果*.java以前编译过所有文件,<javac/>则不会执行任务.
而且,这是构建的结束.你的构建可能没有做任何事情只是因为无事可做.您可以尝试运行clean任务,然后build:
C:\Silk4J\Automation\iControlSilk4J> ant -d clean build
Run Code Online (Sandbox Code Playgroud)
但是,Ant通常会打印正在执行的目标.你应该看到这个:
init:
build-subprojects:
build-projects:
[echo] iControlSilk4J: C:\Silk4J\Automation\iControlSilk4J\build.xml
build:
Build Successful
Run Code Online (Sandbox Code Playgroud)
请注意,目标都是按照执行顺序打印出来的,并且任务在执行时打印出来.但是,如果没有要编译的内容,或者没有要复制的内容,那么您将看不到正在执行的这些任务.这看起来像你的输出?如果是这样,那可能就是无所事事.
bin目录已存在,<mkdir/>则不会执行.src,或者它们已被复制到bin,则该<copy/>任务将不会执行.src目录中没有Java文件,或者它们已经编译过,则该<java/>任务将不会运行.如果查看-d调试的输出,您将看到Ant查看任务,然后解释未执行特定任务的原因.另外,调试选项将解释Ant如何决定要执行的任务.
看看是否有帮助.
这仍然是真实的吗?
正如我所看到的,你写了<target depends="build-subprojects,build-project" name="build"/>,然后你写了<target name="build-subprojects"/>(它什么也没做)。这能是一个理由吗?这是否<echo message="${ant.project.name}: ${ant.file}"/>打印适当的消息?如果否,则目标未运行。看看下一个链接http://www.sqaforums.com/showflat.php?Number=623277