aboutsummaryrefslogtreecommitdiffstats
path: root/build/build-properties.xml
diff options
context:
space:
mode:
Diffstat (limited to 'build/build-properties.xml')
-rw-r--r--build/build-properties.xml227
1 files changed, 175 insertions, 52 deletions
diff --git a/build/build-properties.xml b/build/build-properties.xml
index 81fa3f3cf..1353aec74 100644
--- a/build/build-properties.xml
+++ b/build/build-properties.xml
@@ -62,23 +62,33 @@
<!-- these names are known to BuildModule.java and common to all -->
<property name="aj.build.dir"
location="${aspectj.modules.dir}/aj-build"/>
- <property name="aj.failure.file"
- location="${aj.build.dir}/failures.txt"/>
- <property name="aj.temp.dir"
+ <property name="aj.temp.dir"
location="${aj.build.dir}/temp"/>
<property name="aj.jar.dir"
location="${aj.build.dir}/jars"/>
<property name="aj.dist.dir"
location="${aj.build.dir}/dist"/>
- <property name="aj.junit.dir"
- location="${aj.build.dir}/junit"/>
<property name="aj.webDeploy.dir"
location="${aj.build.dir}/webDeploy"/>
<property name="aj.install.dir"
location="${aj.build.dir}/install"/>
- <property name="aj.logs.dir"
- location="${aj.build.dir}/logs"/>
-
+
+ <property name="aj.build.allresults.dir"
+ location="${aj.build.dir}/allresults"/>
+ <property name="aj.build.allfailures.file"
+ location="${aj.build.allresults.dir}/allfailures.txt"/>
+ <property name="aj.build.results.dir"
+ location="${aj.build.dir}/results"/>
+ <property name="aj.failure.file"
+ location="${aj.build.results.dir}/failures.txt"/>
+ <property name="aj.build-id.file"
+ location="${aj.build.results.dir}/build-id.txt"/>
+ <property name="aj.junit.dir"
+ location="${aj.build.results.dir}/junit"/>
+ <property name="aj.logs.dir"
+ location="${aj.build.results.dir}/logs"/>
+
+
<!-- aspectj... names are sources, not to be mutated -->
<property name="aspectj.modules.lib.dir"
location="${aspectj.modules.dir}/lib"/>
@@ -116,14 +126,15 @@
value="tests"/>
<property name="aspectj.other.modules"
value="docs,eclipse.plugin"/>
-
+
<jar-property name="junit.jar"
location="${aspectj.modules.lib.dir}/junit/junit.jar"/>
+ <!-- TODO need version-specific JDK? -->
<guarded-property name="jdk.tools.jar"
location="${java.home}/../lib/tools.jar"/>
<guarded-property name="jdk.tools.jar"
location="${java.home}/lib/tools.jar"/>
- <guarded-property name="aspectjrt.path"
+ <guarded-property name="lib.test.aspectjrt.jar"
location="${aspectj.modules.lib.dir}/test/aspectjrt.jar"/>
<property name="init-properties.done" value="true"/>
</target>
@@ -198,16 +209,13 @@
<property name="init-filters.done" value="done"/>
</target>
- <target name="clean-directories"
- depends="init-directories"
- unless="clean-directories.done" >
- <property name="clean-directories.done" value="done"/>
+ <target name="clean-directories" depends="init-properties">
<delete quiet="on">
<fileset dir="${aj.build.dir}" includes="*,**/*"/>
</delete>
<antcall target="init-directories"/>
- </target>
-
+ </target>
+
<target name="clean-jars"
depends="init-directories"
unless="clean-jars.done" >
@@ -216,6 +224,65 @@
</delete>
<property name="clean-jars.done" value="done"/>
</target>
+
+ <target name="clean-keep-results" depends="init-properties">
+ <delete>
+ <fileset dir="${aj.build.dir}">
+ <exclude name="results/*"/>
+ <exclude name="results/**"/>
+ <exclude name="allresults/*"/>
+ <exclude name="allresults/**"/>
+ </fileset>
+ </delete>
+ </target>
+
+ <target name="clean-default-results" depends="init-properties">
+ <delete>
+ <fileset dir="${aj.build.results.dir}" includes="*,**/*"/>
+ </delete>
+ </target>
+
+ <target name="clean-result" depends="init-properties">
+ <delete quiet="on">
+ <fileset dir="${aj.build.results.dir}" includes="*,**/*"/>
+ </delete>
+ </target>
+
+ <macrodef name="save-build-id"
+ description="save ${id} to ${aj.build-id.file}">
+ <attribute name="id"/>
+ <sequential>
+ <echo message="@{id}" file="${aj.build-id.file}"/>
+ </sequential>
+ </macrodef>
+
+ <macrodef name="load-build-id">
+ <attribute name="property"/>
+ <sequential>
+ <available property="aj.build-id.file.available"
+ file="${aj.build-id.file}"/>
+ <antcall target="ensure-build-id"/>
+ <loadfile srcfile="${aj.build-id.file}" property="@{property}"/>
+ </sequential>
+ </macrodef>
+
+ <target name="ensure-build-id" unless="aj.build-id.file.available"
+ description="create datestamp build id in ${aj.build-id.file} if n/a">
+ <tstamp>
+ <format property="build.id.name"
+ timezone="GMT+10"
+ pattern="yyyyMMdd-hhmmss"
+ />
+ </tstamp>
+ <echo file="${aj.build-id.file}" message="${build.id.name}"/>
+ </target>
+
+ <target name="save-result" depends="init-properties">
+ <load-build-id property="build.id"/>
+ <copy todir="${aj.build.allresults.dir}/${build.id}">
+ <fileset dir="${aj.build.results.dir}" />
+ </copy>
+ </target>
<target name="echo-properties" depends="init-properties">
<echo>
@@ -230,22 +297,12 @@
aj.build.dir = ${aj.build.dir}
ant.home = ${ant.home}
java.home = ${java.home}
+ java11.home = ${java11.home}
+ java13.home = ${java13.home}
+ java14.home = ${java14.home}
+ java15.home = ${java15.home}
</echo>
</target>
-
- <macrodef name="jar-property">
- <attribute name="name"/>
- <attribute name="location"/>
- <sequential>
- <property name="@{name}"
- location="@{location}"/>
- <available file="${@{name}}"
- property="@{name}.available"
- value="${@{name}}"/>
- <fail unless="@{name}.available"
- message="unable to find @{name}: ${@{name}}"/>
- </sequential>
- </macrodef>
<macrodef name="guarded-property"
description="set property {name} to {location} if unset and {location} exists">
<attribute name="name"/>
@@ -276,6 +333,59 @@
</sequential>
</macrodef>
+ <!--
+ Reporting failures
+
+ Failure-reports supports running multiple build targets in sequence for a
+ configuration, saving off those results, doing it over, etc., and then
+ checking the result (of the current builds or all builds), i.e.,
+
+ # first set of builds
+ - build, report-if-failed ...
+ - build, report-if-failed ...
+ ...
+ - {save-build-id} first-set
+ - save-result
+ - clean-keep-results
+ - clean-default-results
+ # second set of builds
+ - build, report-if-failed ...
+ ...
+ - save-result
+
+ # fail build if anything in either set failed
+ - fail-if-allresults-allfailures
+
+ Clients call
+ <report-if-failed property="failed" text="JUnit failed"/>
+ to signal failure. This goes into results/failures.txt, to be read later.
+ Many clients can call this, across many (current) build invocations, so
+ results just accumulate. Clients should never call <fail> directly; while
+ the cruise-control script can handle build failures, they won't be recorded
+ in a way that supports easy evaluation.
+
+ To fail if the current builds fail, do
+ <antcall target="fail-if-results-failures"/>
+
+ You can do a sequence of builds (e.g., in 1.3), save the results off,
+ and do it again (e.g., in 1.4), save the results, and then compare them.
+ Use save-result to store the current build results in ../allresults.
+
+ Between such builds, you can do a clean-keep-results (to clear out jars
+ and such), followed by clean-default-results (to clear the current results).
+ (The normal clean also cleans out any results, so avoid that when saving
+ results from multiple builds.)
+
+ Each build can be named using save-build-id. This name must be a valid
+ directory name. When the results are saved to ../allresults, the directory
+ name will use the most recent build-id. If none has been saved, then this
+ creates a name out of the date (down to the second).
+
+ To fail if any of the saved builds has failed, do fail-if-allresults-allfailures.
+ This target ignores the current builds (if they are unsaved).
+
+ -->
+
<macrodef name="report-if-failed">
<attribute name="property"/>
<attribute name="text"/>
@@ -293,41 +403,54 @@
</macrodef>
<target name="do-report-fail"
if="failed">
- <echo level="debug" message="do-report-fail - failed=${failed}"/>
- <echo level="debug" message="do-report-fail - text=${text}"/>
<echo append="true" file="${aj.failure.file}">${text}
</echo>
</target>
- <target name="fail-if-failures"
- description="fail if ${aj.failure.file} exists and is not empty">
+ <target name="fail-if-results-failures" depends="init-properties">
+ <fail-if-failures failureFile="${aj.failure.file}"/>
+ </target>
+
+ <target name="fail-if-allresults-allfailures" depends="init-properties">
+ <concat destfile="${aj.build.allfailures.file}">
+ <fileset dir="${aj.build.allresults.dir}"
+ includes="*/failures.txt"/>
+ </concat>
+ <fail-if-failures failureFile="${aj.build.allfailures.file}"/>
+ </target>
+
+ <macrodef name="fail-if-failures"
+ description="fail if ${failureFile} exists and is not empty">
+ <attribute name="failureFile"/>
+ <sequential>
<loadfile
failonerror="false"
property="failures"
- srcfile="${aj.failure.file}"/>
+ srcfile="@{failureFile}"/>
<fail>
<condition>
- <length file="${aj.failure.file}"
+ <length file="@{failureFile}"
when="greater" length="0"/>
</condition>
+# @{failureFile} failures:
${failures}
</fail>
- <!--
- <loadfile
- failonerror="false"
- property="failures"
- srcfile="${aj.failure.file}"/>
- <condition property="failure">
- <equals arg1="${failures}" arg2="${failure}"/>
- </condition>
- <condition property="passed">
- <equals arg1="${failures}" arg2=""/>
- </condition>
- <fail unless="passed">${failures}
-</fail>
- -->
- </target>
-
+ </sequential>
+ </macrodef>
+ <macrodef name="jar-property">
+ <attribute name="name"/>
+ <attribute name="location"/>
+ <sequential>
+ <property name="@{name}"
+ location="@{location}"/>
+ <available file="${@{name}}"
+ property="@{name}.available"
+ value="${@{name}}"/>
+ <fail unless="@{name}.available"
+ message="unable to find @{name}: ${@{name}}"/>
+ </sequential>
+ </macrodef>
+
<macrodef name="set-available"
description="set property and property.available if path exists">
<attribute name="property"/>