diff options
author | wisberg <wisberg> | 2003-05-28 08:23:42 +0000 |
---|---|---|
committer | wisberg <wisberg> | 2003-05-28 08:23:42 +0000 |
commit | a0d2d2d0de4ab0e67a714d3fec46d96b268ca1e4 (patch) | |
tree | 6b38d40626bd61f4dcf82390438eb1e45862c15a | |
parent | 5b02912cdc2f785de337ceedcac1c4ee4e921eda (diff) | |
download | aspectj-a0d2d2d0de4ab0e67a714d3fec46d96b268ca1e4.tar.gz aspectj-a0d2d2d0de4ab0e67a714d3fec46d96b268ca1e4.zip |
Script is usable!
- lots of rearranging and cleanup, docs
- now doing 1.3 and 1.4 testing
- more harness tests (some unverified)
- workaround OOM in examples
- cleanup after building-aspectj-with-aspectj
need more integration with manual process
-rw-r--r-- | build/release/build.xml | 542 | ||||
-rw-r--r-- | build/release/readme.txt | 58 |
2 files changed, 377 insertions, 223 deletions
diff --git a/build/release/build.xml b/build/release/build.xml index 73fcb23dc..e3bea48bb 100644 --- a/build/release/build.xml +++ b/build/release/build.xml @@ -10,86 +10,101 @@ <!-- Wes Isberg initial implementation --> <!-- ========================================================================= --> -<project name="build" default="test" basedir="."> +<project name="build" default="all" basedir="."> <!-- ========================================================================= --> - <target name="info"> + <target name="info" depends="init-variables"> <echo> - This downloads and builds the AspectJ source tree: + Build and test the AspectJ source tree. Targets: - - checkout entire tree - - build distribution - - install distribution - - test - - ajcTests.xml ajc/harness tests in the build - - junitModules.xml junit tests in the build - - build installed examples - ... and more - - Targets of note: + all (default) + install # install distribution + build + build-release # build distribution + build-tests # build test classes + test + test-sources # - requires only sources + test-harness-tests # run tests/{suite}.xml's + test-junit-modules # tests/junitModules.xml + test-install # - requires distribution + test-build-examples # install/docs/examples + test-ajc-aspectj # ajc compiles aspectj + + Normally this builds with Java 1.3 and tests with both + Java 1.3 and 1.4, so define both as properties. You + can select any target (not prefixed "do-" or "init-"). + The leaf targets will run with Java version set in + ${java.home.file} + When running non-leaf targets, if you want to test + only in 1.3 or 1.4, set property "run.1[3|4].only". + + Properties to consider setting on the command-line: + + -- required + java13.home JAVA_HOME for latest J2SE 1.3 + java14.home JAVA_HOME for latest J2SE 1.4 + + -- flags to control + run.13.only only use Java 1.3 + run.14.only only use Java 1.4 + skip.cvs no CVS checkout (true) + skip.build no build (done already) + skip.test no tests + skip.build.release no build of release + skip.build.tests no build of tests + version set if not DEVELOPMENT(?) + + -- locations to re-use existing tree or install + aspectj.workspace location for new cvs tree + aspectj.modules.dir ... for existing cvs tree + aj.build.install.dir ... for installed dist - install checkout, build, and install AspectJ - test (default) test AspectJ sources and installation + Example command lines for using this script: - Properties of note (flags and default values): - - -- flags to control - skip.cvs no CVS checkout (done already) - skip.build no build (done already) - skip.build.release no build of release - skip.build.tests no build of tests - version set if not DEVELOPMENT - - -- locations to re-use existing tree or install - aspectj.workspace location for new cvs tree - aspectj.modules.dir location for existing cvs tree - aj.build.install.dir location for installed distribution - - Trails - - clean first - - cd build - ant clean - - - test only sources in local tree (junit and harness tests): + - define variable for standard properties - cd build/release - ant test-sources \ - -Dskip.cvs=true \ - -Daspectj.modules.dir=../.. + sp="-Djava13.home=d:/j13 -Djava14.home=d:/j14" + sp="$${sp} -Daspectj.modules.dir=../.." - - build local tree and install distribution: - - cd build/release - ant install \ - -Dskip.cvs=true \ - -Daspectj.modules.dir=../.. + - clean first + + cd build + ant clean + + - test only sources in local tree - - test installation and sources in local tree: + cd build/release + ant test-sources $${sp} + + - build and install distribution: + + cd build/release + ant install $${sp} - cd build/release - ant test \ - -Dskip.cvs=true \ - -Daspectj.modules.dir=../.. \ - -Dskip.build=true + - test installation and sources in local tree: - - do everything but checkout from cvs: + cd build/release + ant test $${sp} -Dskip.build=true - cd build - ant clean - cd release - ant all \ - -Dskip.cvs=true \ - -Daspectj.modules.dir=../.. + - do everything but checkout from cvs: - </echo> + cd build + ant clean + cd release + ant all $${sp} + +</echo> </target> - <target name="init-variables"> + <target name="init-variables" > + + <!-- re-enable when tested --> + <property name="skip.cvs" value="true"/> <property name="version" value="DEVELOPMENT"/> <property name="ant.verbose" value=""/> + <property name="failonerror" value="true"/> <property name="aspectj.workspace" location="${basedir}/aspectj-workspace"/> @@ -97,6 +112,8 @@ location="${aspectj.workspace}/org.aspectj/modules"/> <property name="aspectj.build.dir" location="${aspectj.modules.dir}/build"/> + <property name="aspectj.build.release.dir" + location="${aspectj.build.dir}/release"/> <property name="aspectj.tests.dir" location="${aspectj.modules.dir}/tests"/> <property name="aspectj.lib.dir" @@ -118,14 +135,21 @@ <property name="aj.build.log.dir" location="${aj.build.dir}/logs"/> + <!-- todo: clean-up file created as side-effect --> + <property name="java.home.file" + location="${aspectj.build.release.dir}/javahome.props.tmp"/> + <property name="aspectj.jar" location="${aj.build.dist.dir}/aspectj-${version}.jar"/> <property name="harness.jar" location="${aj.build.jar.dir}/testing-drivers-all.jar"/> - <property name="java.command" - location="${java.home}/bin/java"/> + <property name="java13.command" + location="${java13.home}/bin/java"/> + + <property name="java14.command" + location="${java14.home}/bin/java"/> <mkdir dir="${aj.build.log.dir}"/> @@ -165,14 +189,14 @@ </target> - <target name="sources-available" depends="init-variables" + <target name="init-sources-available" depends="init-variables" unless="sources.available"> <available property="sources.available" file="${aspectj.modules.dir}/build/build.xml"/> <fail unless="sources.available" message="checkout first"/> </target> - <target name="aspectj-available" depends="init-variables" + <target name="init-aspectj-available" depends="init-variables" unless="aspectj.available"> <available property="aspectj.available" file="${aj.build.install.dir}" type="dir"/> @@ -180,7 +204,7 @@ message="install first in ${aj.build.install.dir}"/> </target> - <target name="harness-available" depends="init-variables" + <target name="init-harness-available" depends="init-variables" unless="harness.available"> <available property="harness.available" classname="org.aspectj.testing.drivers.Harness" @@ -189,7 +213,7 @@ message="harness not found - first build-tests"/> </target> - <target name="tests-available" depends="init-variables" + <target name="init-junitTests-available" depends="init-variables" unless="tests.available"> <available property="tests.available" classname="AjbrowserModuleTests"> @@ -199,13 +223,30 @@ </classpath> </available> <fail unless="tests.available" - message="test classe not found - first build-tests"/> + message="test classes not found - first build-tests"/> </target> <!-- ========================================================================= --> + <target name="all"> + <antcall target="install"/> + <antcall target="test"/> + </target> + + <target name="build" unless="skip.build" + description="build an AspectJ release and tests"> + <antcall target="build-release"/> + <antcall target="build-tests"/> + </target> + + <target name="test" unless="skip.test" + description="test AspectJ source and distribution"> + <antcall target="test-sources"/> + <antcall target="test-install"/> + </target> + <target name="install" depends="build,init-variables" - description="create an AspectJ source tree"> + description="install AspectJ distribution using current java"> <fail unless="aspectj.jar" message="define aspectj.jar"/> <fail unless="aj.build.install.dir" message="define aj.build.install.dir"/> <mkdir dir="${aj.build.install.dir}"/> @@ -215,61 +256,6 @@ <arg line="-to ${aj.build.install.dir}"/> </java> </target> - - <target name="build" depends="init-variables" - description="build an AspectJ release and tests" - unless="skip.build"> - <antcall target="build-release"/> - <antcall target="build-tests"/> - </target> - - <target name="build-release" depends="init-variables,create-tree" - description="build an AspectJ release" - unless="skip.build.release"> - - <antcall target="run-ant"> - <param name="ant.dir" location="${aspectj.build.dir}"/> - <param name="run.ant.file" value="build.xml"/> - <param name="ant.target" value="clean"/> - <param name="ant.output" - location="${aj.build.log.dir}/build-clean.txt"/> - </antcall> - - <!-- product built without testing classes --> - <antcall target="run-ant"> - <param name="ant.dir" location="${aspectj.build.dir}"/> - <param name="run.ant.file" value="build.xml"/> - <param name="ant.target" value="aspectj"/> - <param name="ant.output" - location="${aj.build.log.dir}/build-aspectj.txt"/> - </antcall> - - </target> - - <target name="build-tests" depends="init-variables,create-tree" - description="build AspectJ tests" - unless="skip.build.tests"> - - <!-- now build with testing classes in jars --> - <antcall target="run-ant"> - <param name="ant.dir" location="${aspectj.build.dir}"/> - <param name="run.ant.file" value="build.xml"/> - <param name="ant.target" value="clean-jars"/> - <param name="ant.output" - location="${aj.build.log.dir}/build-clean-jars.txt"/> - </antcall> - - <antcall target="run-ant"> - <param name="ant.dir" location="${aspectj.build.dir}"/> - <param name="run.ant.file" value="build.xml"/> - <param name="ant.target" value="build-testing-jars"/> - <param name="ant.output" - location="${aj.build.log.dir}/build-testing-jars.txt"/> - <param name="ant.properties" - value="-Dtrim.testing.default=false"/> - </antcall> - - </target> <target name="create-tree" depends="init-variables" unless="skip.cvs" @@ -285,140 +271,167 @@ failonerror="on" command="checkout -P" /> </target> - -<!-- ========================================================================= --> - <target name="all"> - <antcall target="install"/> - <antcall target="test"/> + <target name="build-release" depends="init-variables,create-tree" + description="build an AspectJ release under Java 1.3" + unless="skip.build.release"> + + <!-- release build destroys test build, but not vice-versa --> + <antcall target="do-aspectj-build"> + <param name="do.ant.target" value="clean"/> + <param name="do.ant.props" value=""/> + </antcall> + <antcall target="do-aspectj-build"> + <param name="do.ant.target" value="aspectj"/> + <param name="do.ant.props" value=""/> + </antcall> </target> - <target name="test" depends="test-sources,test-install"/> - - <target name="test-sources" - depends="init-variables,tests-available"> - <!-- these require only sources and built tree --> - <antcall target="junit-module-tests"/> - <antcall target="run-harness-tests"/> + <target name="build-tests" depends="init-variables,create-tree" + description="build AspectJ tests under Java 13" + unless="skip.build.tests"> + + <antcall target="do-aspectj-build"> + <param name="do.ant.target" value="clean-jars"/> + <param name="do.ant.props" value=""/> + </antcall> + <antcall target="do-aspectj-build"> + <param name="do.ant.target" value="build-testing-jars"/> + <param name="do.ant.props" value="-Dtrim.testing.default=false"/> + </antcall> </target> - - <target name="test-install" - depends="init-variables,aspectj-available"> - <antcall target="compile-aspectj-using-aspectj"/> - <antcall target="build-examples"/> + + <!-- ==== install tests ==== --> + <target name="test-install"> + <antcall target="do-13-target"> + <param name="do.target" value="do-test-install-sequence"/> + </antcall> + <antcall target="do-14-target"> + <param name="do.target" value="do-test-install-sequence"/> + </antcall> </target> - - <target name="junit-module-tests" - depends="init-variables,aspectj-available"> - <echo message="need to build all with -Dtrim.testing.default=false"/> - <antcall target="run-ant"> - <param name="run.ant.file" value="junitModules.xml"/> - <param name="ant.target" value=""/> - <param name="ant.dir" - location="${aspectj.modules.dir}/tests"/> - <param name="ant.output" - location="${aj.build.log.dir}/build-junitModules.txt"/> - </antcall> - - <mkdir dir="${aj.build.log.dir}/junitXmlOutput"/> - <delete quiet="on"> - <fileset dir="${aj.build.log.dir}/junitXmlOutput" - includes="*"/> - </delete> - <property name="xmlSrcDir" - location="${aspectj.tests.dir}/bin/junitXmlOutput"/> - <copy todir="${aj.build.log.dir}/junitXmlOutput" - filtering="off"> - <fileset dir="${xmlSrcDir}" includes="**/*"/> - </copy> + + <target name="do-test-install-sequence" + depends="init-variables,init-aspectj-available"> + <antcall target="test-build-examples"/> + <antcall target="test-ajc-aspectj"/> </target> - <target name="build-examples" - depends="init-variables,aspectj-available"> - <antcall target="build-one-example"> + <target name="test-build-examples" + depends="init-variables,init-aspectj-available"> + <antcall target="do-build-installed-example"> <param name="example.target" value="nonGui"/> </antcall> - <antcall target="build-one-example"> + <antcall target="do-build-installed-example"> <param name="example.target" value="tracing-bc"/> </antcall> <echo message="Also setup and run compiler adapter example"/> </target> - <target name="build-one-example" depends="init-variables"> - <ant dir="${aj.build.install.dir}/doc/examples" - inheritAll="false" - target="${example.target}" - output="${aj.build.log.dir}/example-${example.target}.txt" - /> - </target> - - <target name="compile-aspectj-using-aspectj" - depends="init-variables,sources-available"> - <echo message="WARNING: output dir created in tests/product/build-aspectj"/> - <antcall target="run-ant"> + <target name="test-ajc-aspectj" + depends="init-variables,init-aspectj-available,init-sources-available"> + <antcall target="do-run-ant"> <param name="ant.dir" location="${aspectj.modules.dir}/tests/product/build-aspectj"/> <param name="run.ant.file" value="build.xml"/> <param name="ant.target" value=""/> <param name="ant.output" - location="${aj.build.log.dir}/build-aspectj-using-aspectj.txt"/> + location="${aj.build.log.dir}/test-ajc-aspectj"/> </antcall> + <delete quiet="on" dir="${aspectj.modules.dir}/tests/product/build-aspectj/output"/> </target> - <target name="run-harness-tests" depends="aspectj-available"> + <!-- ==== source tests ==== --> + <target name="test-sources"> + <antcall target="do-13-target"> + <param name="do.target" value="do-test-sources-sequence"/> + </antcall> + <antcall target="do-14-target"> + <param name="do.target" value="do-test-sources-sequence"/> + </antcall> + </target> + + <target name="do-test-sources-sequence"> + <antcall target="test-harness-tests"/> + <antcall target="test-junit-modules"/> + </target> + + <target name="test-junit-modules" + depends="init-variables,init-junitTests-available"> + <antcall target="do-run-ant"> + <param name="run.ant.file" value="junitModules.xml"/> + <param name="ant.target" value=""/> + <param name="ant.dir" + location="${aspectj.modules.dir}/tests"/> + <param name="ant.output" + location="${aj.build.log.dir}/test-junitModules"/> + </antcall> + + <property file="${java.home.file}"/> + <property name="tjm.copy.todir" + location="${aj.build.log.dir}/junitXmlOutput-${build.java.version}"/> + <mkdir dir="${tjm.copy.todir}"/> + <delete quiet="on"> + <fileset dir="${tjm.copy.todir}" includes="**/*"/> + </delete> + <property name="xmlSrcDir" + location="${aspectj.tests.dir}/bin/junitXmlOutput"/> + <move todir="${tjm.copy.todir}" > + <fileset dir="${xmlSrcDir}" includes="**/*"/> + </move> + </target> + + <target name="test-harness-tests" depends="init-harness-available"> <!-- we could use harness variants, e.g., "-emacssym-", but separating runs puts each variant in a different output file, which makes them easier to analyze. --> - <antcall target="run-harness-once"> + <antcall target="do-run-harness"> <param name="suite.filename" value="ajcHarnessTests"/> - <param name="harness.args" value=""/> - <param name="harness.suffix" value=""/> + <param name="harness.args" value="-ajctestSkipKeywords=expect-fail"/> + <param name="harness.suffix" value="-pass"/> </antcall> - - <antcall target="run-harness-once"> + <antcall target="do-run-harness"> <param name="suite.filename" value="ajcTestsFailing"/> <param name="harness.args" value=""/> <param name="harness.suffix" value=""/> </antcall> - <antcall target="run-harness-once"> + <antcall target="do-run-harness"> <param name="suite.filename" value="ajcTestsFailing"/> <param name="harness.args" value="-emacssym"/> <param name="harness.suffix" value="-emacssym"/> </antcall> - <antcall target="run-harness-once"> + <antcall target="do-run-harness"> <param name="suite.filename" value="ajcTests"/> <param name="harness.args" value=""/> <param name="harness.suffix" value=""/> </antcall> - <antcall target="run-harness-once"> + <antcall target="do-run-harness"> <param name="suite.filename" value="ajcTests"/> <param name="harness.args" value="-emacssym"/> <param name="harness.suffix" value="-emacssym"/> </antcall> - <antcall target="run-harness-once"> + <antcall target="do-run-harness"> <param name="suite.filename" value="ajcTests"/> <param name="harness.args" value="-ajctaskCompiler -ajctestSkipKeywords=knownLimitations-ajctaskCompiler"/> <param name="harness.suffix" value="-ajctaskCompiler"/> </antcall> - </target> - <!-- move when tested --> - <target name="run-harness-ajctaskCompiler" - depends="init-variables"> - <antcall target="run-harness-once"> + <antcall target="do-run-harness"> <param name="suite.filename" value="ajcTests"/> - <param name="harness.args" value="-ajctaskCompiler -ajctestSkipKeywords=knownLimitation-ajctaskCompiler"/> - <param name="harness.suffix" value="-ajctaskCompiler"/> + <param name="harness.args" value="-ajdeCompiler -ajctestSkipKeywords=knownLimitations-ajdeCompiler"/> + <param name="harness.suffix" value="-ajdeCompiler"/> </antcall> </target> - <target name="run-harness-once" - depends="init-variables,harness-available"> + <!-- ======= do-{...} tasks are called only by other tasks ======== --> + + <target name="do-run-harness" + depends="init-variables,init-harness-available"> <fail unless="suite.filename" message="define suite.filename"/> <fail unless="harness.args" @@ -426,61 +439,108 @@ <fail unless="harness.suffix" message="define harness.suffix"/> - <property name="rho.default.options" + <property name="drho.default.options" value="-release -logFail -killTemp"/> + <property file="${java.home.file}"/> + <fail unless="build.java.home" + message="failed to read ${build.java.home} from ${java.home.file}"/> + <fail unless="build.java.version" + message="failed to read ${build.java.version} from ${java.home.file}"/> + <property name="harness.output.file" - location="${aj.build.log.dir}/${suite.filename}${harness.suffix}.txt"/> + location="${aj.build.log.dir}/test-${suite.filename}${harness.suffix}-${build.java.version}.txt"/> <echo> - run-harness-once ${suite.filename}.xml - with options ${rho.default.options} ${harness.args} + do-run-harness ${suite.filename}.xml + with options ${drho.default.options} ${harness.args} to ${harness.output.file} </echo> <java fork="true" dir="${aspectj.tests.dir}" jar="${harness.jar}" - maxmemory="250m" + jvm="${build.java.command}" + maxmemory="250m" output="${harness.output.file}"> <arg value="${suite.filename}.xml"/> - <arg line="${rho.default.options} ${harness.args}"/> + <arg line="${drho.default.options} ${harness.args}"/> </java> </target> + + <target name="do-build-installed-example" depends="init-variables"> + <antcall target="do-run-ant"> + <param name="ant.dir" + location="${aj.build.install.dir}/doc/examples"/> + <param name="run.ant.file" value="build.xml"/> + <param name="ant.target" value="${example.target}"/> + <param name="ant.output" + location="${aj.build.log.dir}/test-example-${example.target}"/> + <param name="ant.properties" value=""/> + <!-- XXX getting OOMemory - permit and investigate --> + <param name="failonerror" value="false"/> + </antcall> + </target> + + <target name="do-aspectj-build" depends="init-variables" + description="build targets in ../build.xml using Java 1.3"> + <fail unless="do.ant.target" message="caller sets do.ant.target"/> + <fail unless="do.ant.props" message="caller sets do.ant.props"/> + <antcall target="do-java13-setup"/> + <antcall target="do-run-ant"> + <param name="ant.dir" location="${aspectj.build.dir}"/> + <param name="run.ant.file" value="build.xml"/> + <param name="ant.target" value="${do.ant.target}"/> + <param name="ant.output" + location="${aj.build.log.dir}/build-${do.ant.target}"/> + <param name="ant.properties" value="${do.ant.props}"/> + </antcall> + </target> - <target name="run-ant" depends="init-variables" + <target name="do-run-ant" depends="init-variables" description="the ant we use to build"> - <!-- we could use normal ant, but we enforce using ours - <ant dir="${aspectj.build.dir}" - target="clean" - inheritAll="false"/> + <!-- we could use normal ant, but we enforce using + our ant libraries and the specified java runtime --> <fail unless="ant.target" message="define ant.target"/> <fail unless="run.ant.file" message="define run.ant.file"/> - <!-- fail unless="ant.properties" message="define ant.properties"/--> - <!-- set if not defined --> + <!-- don't fail - set if not defined --> <property name="ant.properties" value=""/> - <echo message="ant output for ${run.ant.file} ${ant.target} goes to ${ant.output}"/> + + <property file="${java.home.file}"/> + <fail unless="build.java.home" + message="failed to read ${build.java.home} from ${java.home.file}"/> + <fail unless="build.java.version" + message="failed to read ${build.java.version} from ${java.home.file}"/> + + <property name="ant.output.file" + location="${ant.output}-${build.java.version}.txt"/> + <echo> + do-run-ant dir ${ant.dir} + file/target -f ${run.ant.file} ${ant.target} + options ${ant.verbose} ${ant.properties} + output ${ant.output.file} +</echo> + <java fork="true" dir="${ant.dir}" - jvm="${java.command}" + jvm="${build.java.command}" classname="org.apache.tools.ant.Main" maxmemory="350m" - failonerror="true" + failonerror="${failonerror}" newenvironment="true" - output="${ant.output}"> + output="${ant.output.file}"> <classpath> <fileset dir="${aspectj.ant.lib.dir}"> <include name="*.jar"/> </fileset> - <pathelement path="${aspectj.lib.dir}/junit/junit.jar"/> - <pathelement path="${java.home}/lib/tools.jar"/> - <pathelement path="${java.home}/../lib/tools.jar"/> + <pathelement location="${aspectj.lib.dir}/junit/junit.jar"/> + <pathelement location="${build.java.home}/lib/tools.jar"/> </classpath> <!-- urk - all properties for any client --> <!-- for any build --> - <sysproperty key="JAVA_HOME" path="${java.home}"/> + <sysproperty key="JAVA_HOME" path="${build.java.home}"/> <sysproperty key="ANT_HOME" path="${aspectj.ant.home}"/> @@ -495,9 +555,45 @@ file="${aspectj.modules.dir}"/> <sysproperty key="ASPECTJ_HOME" file="${aj.build.install.dir}"/> - <arg line="-f ${run.ant.file} ${ant.target} ${ant.verbose} ${ant.properties}"/> </java> </target> + <target name="do-13-target" unless="run.14.only"> + <antcall target="do-java13-setup"/> + <antcall target="${do.target}"/> + </target> + + <target name="do-14-target" unless="run.13.only"> + <antcall target="do-java14-setup"/> + <antcall target="${do.target}"/> + </target> + + <target name="do-java14-setup"> + <antcall target="do-write-javahome-file"> + <param name="build.java.version" value="14"/> + <param name="build.java.home" value="${java14.home}"/> + </antcall> + </target> + + <target name="do-java13-setup"> + <antcall target="do-write-javahome-file"> + <param name="build.java.version" value="13"/> + <param name="build.java.home" value="${java13.home}"/> + </antcall> + </target> + + <target name="do-write-javahome-file" depends="init-variables" + description="save global build.java.[version,command,home]"> + <fail unless="build.java.version"/> + <fail unless="build.java.home"/> + <property name="wjf.bjh" location="${build.java.home}"/> + <property name="wjf.cmd" location="${wjf.bjh}/bin/java"/> + <propertyfile file="${java.home.file}"> + <entry key="build.java.version" value="${build.java.version}"/> + <entry key="build.java.home" value="${wjf.bjh}"/> + <entry key="build.java.command" value="${wjf.cmd}"/> + </propertyfile> + </target> + </project>
\ No newline at end of file diff --git a/build/release/readme.txt b/build/release/readme.txt new file mode 100644 index 000000000..b23769e31 --- /dev/null +++ b/build/release/readme.txt @@ -0,0 +1,58 @@ + +This script builds and tests an AspectJ release. +Use the info target to emit details. + +At the bottom is a bash script to run it. + +---- Evaluating the results of a build cycle + +There is a ../release-checklist.txt which has steps for a release, some of +which are automated in this script. Try the others ;). + +Known issues with these tests + +- ajc compile of tjp example as part of nonGui target + runs out of memory. Reproducible on the command-line: + [ajc] Running in-process using -verbose -d R:\home\wes\ec\aj- +build\install\doc\examples\classes -classpath R:\home\wes\ec\aj-buil +d\install\lib\aspectjrt.jar -argfile R:\home\wes\ec\aj-build\install +\doc\examples\tjp\files.lst +Exception reading component R:\home\wes\ec\aj-build\install\lib\aspe +ctjtools.jar +java.lang.OutOfMemoryError + <<no stack trace available>> +Exception in thread "main" java.lang.OutOfMemoryError + <<no stack trace available>> + + This target is run without failonerror="true" to complete + the testing. + +Known imperfect results in the AspectJ 1.1 release: + +- ajdeCompiler tests will have five known fails, listed + in releases/aspectj1.1/ajcTests-ajdeCompiler-FAIL.txt + +- under 1.4, the junit module test output for the weaver + module is corrupted - the last two characters are + duplicated, which cause the junit reporting task to + not pick up the weaver tests. Verify that the + weaver XML file lists no JUnit failures or errors. + + +------ untested bash/sh script +#!/bin/sh +sp="-Dskip.cvs=true -Daspectj.modules.dir=../.." +sp="$${sp} -Djava13.home=d:/jdk13 -Djava14.home=d:/jdk14" +alias myant="../../lib/ant/bin/ant" + +# clean +cd `dirname "$0"` +cd .. +myant clean + +# build local tree and install distribution: +cd release +myant install ${sp} + +# test installation and sources in local tree: +myant test ${sp} -Dskip.build=true |