aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--build/readme-build-and-test-aspectj.html8
-rw-r--r--build/release-checklist.txt159
-rw-r--r--tests/product/build-aspectj/build.xml219
3 files changed, 306 insertions, 80 deletions
diff --git a/build/readme-build-and-test-aspectj.html b/build/readme-build-and-test-aspectj.html
index e7829c658..6a9880bd7 100644
--- a/build/readme-build-and-test-aspectj.html
+++ b/build/readme-build-and-test-aspectj.html
@@ -307,8 +307,12 @@ For bug fixes, associated tests in
<p>Before a release, run the release tests as described in
<a href="../tests/readme-release-tests.html">
- ../tests/readme-release-tests.html</a>.
-
+ ../tests/readme-release-tests.html</a>
+ (deprecated? using:
+ <a href="../build/release-checklist.txt">
+ ../build/release-checklist.txt</a>).
+
+
<h4>Release completion</h4>
When the release build is accepted,
tag the tree with the release version
diff --git a/build/release-checklist.txt b/build/release-checklist.txt
index 68b77ea41..47dd2cb15 100644
--- a/build/release-checklist.txt
+++ b/build/release-checklist.txt
@@ -8,25 +8,25 @@ save it as part of the release notes on completion.
Before you begin... you will need:
================================================================================
-* A JDK v1.4.x java -fullversion : [ ]
-* A JDK v1.3.x java -fullversion : [ ]
-* A 1.1.8 JRE version : [ ]
-* A Windoze box OS version : [ ]
-* A Linux box distribution : [ ]
-* An iMac (nice-to-have) JDK 1.4.x : [ ]
-* Eclipse version : [ ]
-
+* A JDK v1.4.x java -fullversion : [ ]
+* A JDK v1.3.x java -fullversion : [ ]
+* A 1.1.8 JRE version : [ ]
+* A Windoze box OS version : [ ]
+* A Linux box distribution : [ ]
+* An iMac (nice-to-have) JDK 1.4.x : [ ]
+* Eclipse version : [ ]
+
* A pair of scissors (get an adult to help you with these)
* Some sticky-backed plastic
-OK, so the last two aren't strictly necessary, but they always seem to come in
+OK, so the last three aren't strictly necessary, but they always seem to come in
useful on the telly.
Extraction:
================================================================================
* Full CVS extract of org.aspectj/modules [ ]
- date and time of extract : [ ]
+ date and time of extract : [ ]
Preparation:
================================================================================
@@ -35,7 +35,7 @@ Preparation:
(e.g. releases/aspectj-1.1rc1)
* Save a copy of this file there as package-and-test-notes.txt [ ]
-
+
* Edit build/build-properties.xml and set the version properties for this
release [ ]
@@ -45,7 +45,7 @@ Preparation:
<property name="build.version.base" value="1.1"/>
<property name="build.version.long" value="1.1 release candidate 1"/>
<property name="build.version.short" value="1.1rc1"/>
-
+
* Edit org.aspectj.ajdt.core/src/org.aspectj.ajdt.ajc/messages.properties and
set the version properties for this release [ ]
@@ -58,15 +58,15 @@ Preparation:
### miscellaneous
misc.usage = AspectJ Compiler 1.1 release candidate 1\n\
...
-
+
Build:
================================================================================
* Ensure JAVA_HOME is set to point to your 1.3 JDK [ ]
- echo $JAVA_HOME [ ]
-
- (even when you "Run Ant..." from eclipse, the value of JAVA_HOME is
- used rather than the JRE specified in your Eclipse settings).
+ echo $JAVA_HOME [ ]
+
+ (even when you "Run Ant..." from eclipse, the value of JAVA_HOME is
+ used rather than the JRE specified in your Eclipse settings).
* When running ant, use the version in modules/lib/ant,
i.e., modules/lib/ant/bin/ant [ ]
@@ -74,17 +74,17 @@ Build:
* Run ant on build/build.xml :
$ cd build
- $ ant clean [ ]
- $ ant fail-unless-boot-libraries-uptodate [ ]
- $ ant [ ]
-
+ $ ant clean [ ]
+ $ ant fail-unless-boot-libraries-uptodate [ ]
+ $ ant [ ]
+
* Save the build output (console log) as build-<version>.log.txt [ ]
- (e.g. build-1.1rc1.log.txt)
-
+ (e.g. build-1.1rc1.log.txt)
+
* Save the built jar to the releases directory [ ]
(releases/aspectj-<version>)
-* Verify name is aspectj-<version>.jar [ ]
+* Verify name is aspectj-<version>.jar [ ]
Pre-installation tests:
@@ -117,20 +117,20 @@ Pre-installation tests:
Do:
- $ {harness} -release -logFail ajcTests.xml [ ]
+ $ {harness} -release -logFail ajcTests.xml [ ]
-- save results in ajcTests-result-<version>-JDK13.txt [ ]
- (e.g. ajcTests-result-1.1rc1-JDK13.txt)
+ (e.g. ajcTests-result-1.1rc1-JDK13.txt)
- -- record any failures (should be none) inline here.
-
- $ {harness} -release -logFail -emacssym ajcTests.xml [ ]
+ -- record any failures (should be none) inline here.
+
+ $ {harness} -release -logFail -emacssym ajcTests.xml [ ]
-- save results in ajcTests-result-<version>-emacssym-JDK13.txt [ ]
- (e.g. ajcTests-result-1.1rc1-emacssym-JDK13.txt)
+ (e.g. ajcTests-result-1.1rc1-emacssym-JDK13.txt)
- -- record any failures (should be none) inline here.
-
+ -- record any failures (should be none) inline here.
+
* run Harness tests on the 1.4 vm:
Where {harness} is
@@ -140,20 +140,20 @@ Pre-installation tests:
Do:
- $ {harness} -release -logFail ajcTests.xml [ ]
+ $ {harness} -release -logFail ajcTests.xml [ ]
-- save results in ajcTests-result-<version>-JDK14.txt [ ]
- (e.g. ajcTests-result-1.1rc1-JDK14.txt)
+ (e.g. ajcTests-result-1.1rc1-JDK14.txt)
- -- record any failures (should be none) inline here.
-
- $ {harness} -release -logFail -emacssym ajcTests.xml [ ]
+ -- record any failures (should be none) inline here.
+
+ $ {harness} -release -logFail -emacssym ajcTests.xml [ ]
-- save results in ajcTests-result-<version>-emacssym-JDK14.txt [ ]
- (e.g. ajcTests-result-1.1rc1-emacssym-JDK14.txt)
+ (e.g. ajcTests-result-1.1rc1-emacssym-JDK14.txt)
- -- record any failures (should be none) inline here.
-
+ -- record any failures (should be none) inline here.
+
* run Harness on ajcTestsFailing.xml
Where {harness} is
@@ -163,26 +163,26 @@ Pre-installation tests:
Do:
- $ {harness} -release -logFail ajcTestsFailing.xml [ ]
+ $ {harness} -release -logFail ajcTestsFailing.xml [ ]
-- save results in ajcTestsFailing-result-<version>-JDK13.txt [ ]
- (e.g. ajcTestsFailing-result-1.1rc1-JDK13.txt)
+ (e.g. ajcTestsFailing-result-1.1rc1-JDK13.txt)
- -- record any failures inline here (should be none. ajcTestsFailing
- should be empty for a final release. Known exceptions are
- permissible for a non-final release.)
-
-
+ -- record any failures inline here (should be none. ajcTestsFailing
+ should be empty for a final release. Known exceptions are
+ permissible for a non-final release.)
+
+
Installation & Verification Tests
================================================================================
* install from aspectj-<version>.jar as built above
- - verify version number and build date on splash screen [ ]
-
- - save screenshot of splash screen (not essential) as [ ]
- Installer-Splash-Screen.bmp (file format may vary)
-
+ - verify version number and build date on splash screen [ ]
+
+ - save screenshot of splash screen (not essential) as [ ]
+ Installer-Splash-Screen.bmp (file format may vary)
+
* verify directory structure created ok [ ]
* check version in README-AspectJ.html [ ]
@@ -198,34 +198,34 @@ Installation & Verification Tests
* from doc/examples, run "ant", verify spacewar builds and runs ok [ ]
* in doc/examples, build ant targets as follows:
- - bean [ ]
- - intro [ ]
- - intro-clone [ ]
- - intro-compare [ ]
- - intro-hash [ ]
- - observer [ ]
- - spacewar [ ]
- - spacewar-demo [ ]
- - telecom [ ]
- - telecom-billing [ ]
- - telecom-timing [ ]
- - tjp [ ]
- - tracing-1 [ ]
- - tracing-2 [ ]
- - tracing-3 [ ]
- - tracing-bc [ ]
- - tracing-none [ ]
+ - bean [ ]
+ - intro [ ]
+ - intro-clone [ ]
+ - intro-compare [ ]
+ - intro-hash [ ]
+ - observer [ ]
+ - spacewar [ ]
+ - spacewar-demo [ ]
+ - telecom [ ]
+ - telecom-billing [ ]
+ - telecom-timing [ ]
+ - tjp [ ]
+ - tracing-1 [ ]
+ - tracing-2 [ ]
+ - tracing-3 [ ]
+ - tracing-bc [ ]
+ - tracing-none [ ]
* With aspectjtools.jar in the ant/lib directory, also build
- - tracing-adapter [ ]
- - tracing-adapter-ajc [ ]
+ - tracing-adapter [ ]
+ - tracing-adapter-ajc [ ]
* run pre-compiled version of spacewar on a 1.1.8 vm [ ]
* verify debug info included in class files
- - "javap -l org.aspectj.tools.ajc.Main" under jdk 1.4 or later [ ]
-
+ - "javap -l org.aspectj.tools.ajc.Main" under jdk 1.4 or later [ ]
+
* verify manual dates correct in docs [ ]
* verify api docs present and correct [ ]
@@ -236,7 +236,10 @@ Product Testing
These tests are a bit more rigorous and time-consuming.
Run at your discretion
-* Build AspectJ using AspectJ [ ]
+* Compile AspectJ sources using AspectJ [ ]
+
+ cd tests/product/build-aspectj
+ ant
* Perform steps specified in the Development Guide on AJBrowser [ ]
@@ -260,12 +263,12 @@ Cross-Platform Testing
Bug database
================================================================================
-* No P1 or P2 bugs, and no lower bugs that should be P1/P2 [ ]
+* No P1 or P2 bugs, and no lower bugs that should be P1/P2 [ ]
-* All fixed bugs verified (at least by fixing developer, [ ]
+* All fixed bugs verified (at least by fixing developer, [ ]
though preferably with a test case)
-* Please comment if there are compiler fixes without test cases [ ]
+* Please comment if there are compiler fixes without test cases [ ]
Other Release Objectives
@@ -296,6 +299,6 @@ Once developer consensus is reached on the build:
* post link on download page [ ]
* post announce message to aspectj-users, aspectj-announce,
- aosd-discuss, aosd-announce [ ]
+ aosd-discuss, aosd-announce [ ]
* buy beer [ ]
diff --git a/tests/product/build-aspectj/build.xml b/tests/product/build-aspectj/build.xml
new file mode 100644
index 000000000..e1007c2bd
--- /dev/null
+++ b/tests/product/build-aspectj/build.xml
@@ -0,0 +1,219 @@
+
+<!-- ========================================================================= -->
+<!-- Copyright (c) 2003 Contributors. -->
+<!-- All rights reserved. -->
+<!-- This program and the accompanying materials are made available -->
+<!-- under the terms of the Common Public License v1.0 -->
+<!-- which accompanies this distribution and is available at -->
+<!-- http://www.eclipse.org/legal/cpl-v10.html -->
+<!-- -->
+<!-- Contributors: -->
+<!-- Isberg initial implementation -->
+<!-- ========================================================================= -->
+
+<project name="build-aspectj-using-aspectj" default="all" basedir=".">
+
+ <target name="info" >
+ <echo>
+ This script tests the AspectJ tools and runtime
+ by building the AspectJ sources. When run, this should
+ finish by emitting the ajc help message.
+
+ Relevant targets:
+ all build and test runtime and tools
+ tools build output/aspectjtools.jar
+ runtime build output/aspectjrt.jar
+ build-tools-javac build using javac to output
+
+ Setup:
+
+ Variables ASPECTJ_HOME and ASPECTJ_SRC refer to the
+ base of an AspectJ install and the modules directory
+ of the AspectJ source tree. By default they are
+
+ ASPECTJ_SRC: $${basedir}/../..
+ ASPECTJ_HOME: $${basedir}/../../aj-build/dist/tools
+
+ which assumes the tools dist is built and this
+ runs from modules/tests/product/build-aspectj
+
+ You can also define the properties to run on any
+ distribution from anywhere:
+
+ ant -DASPECTJ_HOME=dev/tools/aj -DASPECTJ_SRC=ec
+
+ </echo>
+ </target>
+
+ <!-- ============================================================= -->
+ <!-- setup and cleanup targets -->
+ <!-- ============================================================= -->
+
+ <target name="clean" depends="init"
+ description="clean and create output dir">
+ <delete quiet="on" dir="${output.dir}"/>
+ <mkdir dir="${output.dir}"/>
+ </target>
+
+ <target name="init" depends="init.variables,init.taskdefs"/>
+
+ <target name="init.variables"
+ description="init variables">
+
+ <property name="verbose" value="false"/>
+
+ <!-- build.compiler value to pick up our CompilerAdapter for javac -->
+ <property name="ajc.adapter"
+ value="org.aspectj.tools.ant.taskdefs.Ajc11CompilerAdapter"/>
+
+ <!-- required directories - run from examples or predefine -->
+ <property name="ASPECTJ_SRC"
+ location="${basedir}/../../.."/>
+
+ <property name="ASPECTJ_HOME"
+ location="${basedir}/../../../aj-build/dist/tools"/>
+
+ <property name="aspectj.lib.dir"
+ location="${ASPECTJ_HOME}/lib"/>
+
+ <!-- required libraries - install or predefine -->
+ <property name="aspectjrt.jar"
+ location="${aspectj.lib.dir}/aspectjrt.jar"/>
+ <property name="aspectjtools.jar"
+ location="${aspectj.lib.dir}/aspectjtools.jar"/>
+
+ <!-- created directories -->
+ <property name="output.dir"
+ location="${basedir}/output"/>
+
+ <!-- checking required libraries -->
+ <available file="${aspectjtools.jar}"
+ property="aspectjtools.jar.available"/>
+ <available file="${aspectjrt.jar}"
+ property="aspectjrt.jar.available"/>
+
+ <property name="aspectj.src"
+ location="${ASPECTJ_SRC}"/>
+
+ <property name="output.aspectjtools"
+ location="${output.dir}/aspectjtools.jar"/>
+
+ <property name="output.aspectjrt"
+ location="${output.dir}/aspectjrt.jar"/>
+
+ <available file="${aspectj.src}"
+ property="aspectj.src.available"/>
+
+ <path id="runtime.roots">
+ <pathelement path="${aspectj.src}/runtime/src"/>
+ </path>
+
+ <path id="tools.roots">
+ <pathelement path="${aspectj.src}/ajbrowser/src"/>
+ <pathelement path="${aspectj.src}/ajde/src"/>
+ <pathelement path="${aspectj.src}/asm/src"/>
+ <pathelement path="${aspectj.src}/bridge/src"/>
+ <pathelement path="${aspectj.src}/org.aspectj.ajdt.core/src"/>
+ <pathelement path="${aspectj.src}/taskdefs/src"/>
+ <pathelement path="${aspectj.src}/util/src"/>
+ <pathelement path="${aspectj.src}/weaver/src"/>
+ </path>
+
+ <path id="tools.libs">
+ <pathelement path="${aspectj.src}/lib/ant/lib/ant.jar"/>
+ <pathelement path="${aspectj.src}/lib/bcel/bcel.jar"/>
+ <pathelement path="${aspectj.src}/org.eclipse.jdt.core/jdtcore-for-aspectj.jar"/>
+ </path>
+ </target>
+
+ <target name="init.taskdefs" depends="init.variables,
+ aspectjtools.jar.available,
+ aspectjrt.jar.available,
+ aspectj.src.available"
+ unless="taskdefs.init">
+ <taskdef resource="org/aspectj/tools/ant/taskdefs/aspectjTaskdefs.properties">
+ <classpath>
+ <pathelement path="${aspectjtools.jar}"/>
+ </classpath>
+ </taskdef>
+ <property name="taskdefs.init" value="true"/>
+ </target>
+
+ <!-- targets to fail unless required libraries available -->
+
+ <target name="aspectjrt.jar.available" depends="init.variables"
+ unless="aspectjrt.jar.available" >
+ <fail message="expecting aspectjrt.jar at ${aspectjrt.jar}"/>
+ </target>
+
+ <target name="aspectjtools.jar.available" depends="init.variables"
+ unless="aspectjtools.jar.available" >
+ <fail message="expecting aspectjtools.jar at ${aspectjtools.jar}"/>
+ </target>
+
+ <target name="aspectj.src.available" depends="init.variables"
+ unless="aspectj.src.available" >
+ <fail message="expecting aspectj sources at ${aspectj.src}"/>
+ </target>
+
+ <target name="all">
+ <antcall target="clean" />
+ <antcall target="runtime"/>
+ <antcall target="tools"/>
+ </target>
+
+ <target name="runtime">
+ <antcall target="build-runtime"/>
+ <antcall target="test-runtime"/>
+ </target>
+
+ <target name="tools">
+ <antcall target="build-tools"/>
+ <antcall target="test-tools"/>
+ </target>
+
+ <target name="build-runtime" depends="init">
+ <iajc outjar="${output.aspectjrt}"
+ classpath="${aspectjrt.jar}"
+ sourcerootsref="runtime.roots"/>
+ </target>
+
+ <target name="test-runtime" depends="init">
+ <echo message="test-runtime not implemented"/>
+ </target>
+
+ <target name="build-tools" depends="init">
+ <iajc outjar="${output.aspectjtools}"
+ verbose="${verbose}"
+ sourcerootsref="tools.roots"
+ sourcerootcopyfilter="**/CVS/*,**/*.java,**/*.aj">
+ <classpath>
+ <pathelement path="${aspectjrt.jar}"/> <!-- bootstrap problem... -->
+ <path refid="tools.libs"/>
+ </classpath>
+ </iajc>
+ </target>
+
+ <target name="test-tools" depends="init">
+ <java classname="org.aspectj.tools.ajc.Main">
+ <classpath>
+ <path refid="tools.libs"/>
+ <pathelement path="${output.aspectjtools}"/>
+ </classpath>
+ <arg value="-help"/>
+ </java>
+ </target>
+
+ <target name="build-tools-javac" depends="init">
+ <javac verbose="${verbose}" includes="**/*.java"
+ destdir="${output.dir}">
+ <src>
+ <path refid="tools.roots"/>
+ </src>
+ <classpath>
+ <pathelement path="${aspectjrt.jar}"/>
+ <path refid="tools.libs"/>
+ </classpath>
+ </javac>
+ </target>
+</project>