Browse Source

Merge branch '1.9.x'

Conflicts:
	WHATSNEW
	build.xml
	manual/cover.html
	manual/credits.html
	release/ivy.xml
	src/etc/poms/ant-antlr/pom.xml
	src/etc/poms/ant-apache-bcel/pom.xml
	src/etc/poms/ant-apache-bsf/pom.xml
	src/etc/poms/ant-apache-log4j/pom.xml
	src/etc/poms/ant-apache-oro/pom.xml
	src/etc/poms/ant-apache-regexp/pom.xml
	src/etc/poms/ant-apache-resolver/pom.xml
	src/etc/poms/ant-apache-xalan2/pom.xml
	src/etc/poms/ant-commons-logging/pom.xml
	src/etc/poms/ant-commons-net/pom.xml
	src/etc/poms/ant-jai/pom.xml
	src/etc/poms/ant-javamail/pom.xml
	src/etc/poms/ant-jdepend/pom.xml
	src/etc/poms/ant-jmf/pom.xml
	src/etc/poms/ant-jsch/pom.xml
	src/etc/poms/ant-junit/pom.xml
	src/etc/poms/ant-junit4/pom.xml
	src/etc/poms/ant-launcher/pom.xml
	src/etc/poms/ant-netrexx/pom.xml
	src/etc/poms/ant-swing/pom.xml
	src/etc/poms/ant-testutil/pom.xml
	src/etc/poms/ant/pom.xml
	src/etc/poms/pom.xml
	src/etc/testcases/taskdefs/conditions/antversion.xml
master
Stefan Bodewig 9 years ago
parent
commit
cf2e984d56
3 changed files with 172 additions and 93 deletions
  1. +168
    -78
      ReleaseInstructions
  2. +0
    -10
      build.xml
  3. +4
    -5
      src/etc/testcases/taskdefs/conditions/antversion.xml

+ 168
- 78
ReleaseInstructions View File

@@ -5,103 +5,160 @@ Authors: Conor MacNeill
Magesh Umasankar
Antoine Levy-Lambert

Note: This document was updated in the context of releasing Ant 1.9.5.
Note: This document was updated in the context of releasing Ant
1.9.7 which was the first release cut from the 1.9.x branch.
Please interpret the branch names, tags, etc. according to
your context.

It reflects the way Stefan prefers to cut the release, parts of
this process haven't even been discussed on the dev list and may
change with later releases.

1. Propose a release plan for vote. This should set out the timetable for
the release under ideal circumstances.

The issue of whether to create a branch for the release should be
discussed in the release vote.
In reality, you send a note to the list that you intend to cut the
release and wait for a few days whether anybody objects.

2. We used until Ant 1.6 to create branches, for instance ANT_16_BRANCH
to allow parallel development on master and on the current branch.
Given the slow development speed we've reached with 1.9.x this
doesn't seem to be necessary anymore.
We haven't created extra branches for releases in a long time and
with out new 1.9.x LTS policy there is a permanent branch for
Java5 compatible releases anyway. So no extra branch for the
releases is needed.

For more information on performing branching and merging, please visit
http://git-scm.com/book/en/v2/Git-Branching-Branches-in-a-Nutshell
This document assumes you are familiar with git
http://git-scm.com/book/en/v2/
may be a good guide if you are not.

3. Ensure you have all the external libraries that Ant uses in your
2. Ensure you have all the external libraries that Ant uses in your
lib/optional directory. All dependencies are either provided by
JDK 1.5.0 or downloadable using
ant -f fetch.xml -Ddest=optional.
ant -f fetch.xml -Ddest=optional
To find out whether you have all the libraries you need, execute
the build with -verbose option and scan for lines beginning with
"Unable to load...".

4. Create a branch just for the release, even if you've decided to
not work with long lived branches in step 2. This branch can be
removed after the release.
3. We don't want tags for failed votes to end up on out branches so
the release is first created from a detached head.

Switch to that branch.
Checkout the HEAD of the 1.9.x branch as a detached head:

$ git checkout -b prepare_Ant_1.9.5
$ git checkout 1.9.x^0

5. Make sure that your directory tree is clean by running git status.
4. Make sure that your directory tree is clean by running git status.
Some tests leave behind leftovers which end up in the source
distribution otherwise.

6. Set the version number in several files to the required new
versions. See the end of this file for a list of files containing
version information.
5. Set the version number in several files to the required new
versions. These are:

* manual/cover.html (version should already be correct here)
* manual/credits.html (version should already be correct here)
* build.xml properties : project.version,manifest-version,pom.version
* POM files under src/etc/poms and subdirectories
if you've got mvn installed

$ mvn versions:set -DnewVersion=1.9.7 -DgenerateBackupPoms=false

inside src/etc/poms should do the trick.

7. Next bootstrap, build and run the tests. Then build the
distribution on the branch. It is important that this be a clean
build. Tag this with a tag ANT_195_RC1.
* ivy.xml in release subdirectory (version should already be correct here)
* WHATSNEW (version should already be correct here)
* src/etc/testcases/taskdefs/conditions/antversion.xml (version should already be correct here)

6. Next bootstrap, build and run the tests.

$ ./bootstrap.sh
$ ./build.sh
$ ./build.sh test
# if you've got maven installed
$ mvn -f src/etc/poms/pom.xml -DskipTests package

7. Then build the distribution. It is important that this be a clean
build.

# clean
$ rm -rf bootstrap build dist distribution java-repository target
$ ./build.sh dist-lite
$ ./dist/bin/ant -nouserlib -lib lib/optional distribution

The file release.sh gives an idea of how to do this build process.
build.xml specifies that the code should be compiled with
source=1.5 and target=1.5.

git tag -s -m "Tagging RC1 for version 1.9.5 of Ant" ANT_195_RC1
git push --tags
8. Commit your changes, tag them, push them.

$ git tag -s -m "Tagging RC1 for version 1.9.7 of Ant" ANT_197_RC1
$ git push
$ git push --tags

9. Ensure that the GPG key you use is inside the KEYS file in Ant's
git repository
<https://git-wip-us.apache.org/repos/asf?p=ant-antlibs-common.git;a=blob;f=KEYS;h=dc62b011b1b429bd6de913f8f2bce79b715f96db;hb=HEAD>
- and that you copy the KEYS file to /www/www.apache.org/dist/ant

Also make sure you have sent the key that you use to a public
keyserver.

10. Sign the distribution files

There are two aproaches, one uses Ant and a few libraries, the
other requires you to run gnupg manually. The first version didn't
work for Stefan when he built the first release candidate for
1.9.7.

8. Sign the distribution files using the script release/signit.xml
a. Using the script release/signit.xml

This script requires using commons-openpgp to sign the artefacts,

This tool can be checked out from
http://svn.apache.org/repos/asf/commons/sandbox/openpgp/trunk
You have to build it using maven
You have to build it using maven.

$ mvn install

The script assumes commons-openpgp (and bouncycastle) are in your
local maven repository.

You can create a property file gnupg.properties in your home directory
with your key id
with your key id - like

keyid=5F6B8B72

or use -Dkeyid

and pass your key passphrase on the command line with -Dpassword=****

Before you do that, ensure that the key you use is inside the KEYS
file in Ant's git repository
<https://git-wip-us.apache.org/repos/asf?p=ant-antlibs-common.git;a=blob;f=KEYS;h=dc62b011b1b429bd6de913f8f2bce79b715f96db;hb=HEAD> -
and that you copy the KEYS file to
/www/www.apache.org/dist/ant
$ ./build.sh -f release/signit.xml -Dpassword=****

Also make sure you have sent the key that you use to a public
keyserver.
b. Using gpg

9. Convert the part of the WHATSNEW file covering the changes
$ for i in distribution/*/*.zip distribution/*/*.gz distribution/*/*.bz2; do gpg --detach-sign --armor $i; done
$ for i in java-repository/org/apache/ant/ant*/*/*.jar java-repository/org/apache/ant/ant*/*/*.pom; do gpg --detach-sign --armor $i; done

11. Convert the part of the WHATSNEW file covering the changes
since the last release into HTML for the README file on the
website. See the previous release directories for examples of these files.
Add instructions and warnings (GNU tar format issues, etc).

Use the target txt2html of docs.xml

$ ./build.sh -f docs.xml txt2html

This target generates a file build/html/WHATSNEW.html

Add an html head element with a title like "Release Notes of Apache Ant
1.9.5" (from the default txt2html)
1.9.7" (from the default txt2html)

Cut all sections about previous releases to keep only the current release,
and save as RELEASE-NOTES-1.9.5.html inside the distribution folder.
and save as RELEASE-NOTES-1.9.7.html inside the distribution folder.

Copy the file RELEASE-NOTES-1.9.5.html also as README.html
Copy the file RELEASE-NOTES-1.9.7.html also as README.html

10. The distribution is now ready to go.
12. The distribution is now ready to go.
Create a SVN sandbox on your computer with https://dist.apache.org/repos/dist/dev/ant in it
Copy the distribution folder to the location of the sandbox.
svn add the files and commit into https://dist.apache.org/repos/dist/dev/ant

11. Upload the maven artifacts located under java-repository/org/apache/ant
13. Upload the maven artifacts located under java-repository/org/apache/ant
these artifacts comprise currently for each ant jar of one POM
file, the corresponding jar file and the corresponding GPG
signatures (x.pom, x.jar, x.pom.asc, x.jar.asc) MD5 and SHA1 are
@@ -111,9 +168,9 @@ Note: This document was updated in the context of releasing Ant 1.9.5.

https://repository.apache.org (nexus repository)

using the build file release/upload.xml
using the build file release/upload.xml - this requires Ivy

ant -Dupload.user=foo -Dupload.password=secret -lib location_of_ivy_jar -f upload.xml
$ ./build.sh -Dupload.user=foo -Dupload.password=secret -lib location_of_ivy_jar -f upload.xml

After the upload, you need to access the web interface of nexus
under https://repository.apache.org login using your Apache
@@ -123,8 +180,7 @@ Note: This document was updated in the context of releasing Ant 1.9.5.
"Close" on the top of the table listing the uploads make a note of
the location of the staging repository for the vote email


12. Once this is committed send a release vote email on dev@ant.
14. Once this is committed send a release vote email on dev@ant.
The email will typically mention :
- the git tag for the release including commit hash,
- the location of the tarballs, including revision number in
@@ -134,42 +190,91 @@ Note: This document was updated in the context of releasing Ant 1.9.5.
The vote will only pass if at least three PMC members have voted +1
and more +1s than -1s have been cast. The vote will run for 3 days.

13. Update the files listed at the end of the document (files containing
version information) to prepare the development of the next
version of Ant on the master branch.

14. If the vote fails, address the problems and recreate the next RC
15. If the vote fails, address the problems and recreate the next RC
build.

15. Once the vote has passed, tag the last RC created with the final tag
16. Once the vote has passed, tag the last RC created with the final tag

$ git tag -s -m "Tagging version 1.9.5 of Ant" ANT_195 HASH_OF_LAST_RC
$ git tag -s -m "Tagging version 1.9.7 of Ant" rel/1.9.7 HASH_OF_LAST_RC
$ git push --tags

15. The distrib artifacts should be published the apache dist. It is
17. The distrib artifacts should be published the apache dist. It is
managed via svnpubsub so the release should be committed to the
subversion repository
https://dist.apache.org/repos/dist/release/ant/.

In order to keep the main dist area of a reasonable size, old releases
should be removed. They will disapear from the main dist but will still be
available via the archive. To do so, just use the "svn rm" command against
the artifacts or folders to remove.

* commit the new release files to

https://dist.apache.org/repos/dist/release/ant/[source|binaries|manual].

* Make https://dist.apache.org/repos/dist/release/ant/README.html
point to the new RELEASE-NOTES or a copy of it.

* release the maven artifacts using the web interface of nexus under https://repository.apache.org
login using your Apache credentials
in the left pane, below "build promotion", click on the "Stagings Repositories" links
expand org.apache.ant
select the checkbox next to the upload that you just did
and click the button "Release".
4 hours later, the artefacts will be in the maven central repository.
4 hours later, the artifacts will be in the maven central repository.
* Make README.html point to the new RELEASE-NOTES or a copy of
it.
18. Update the Apache Reporter System

https://reporter.apache.org/addrelease.html?ant

19. Address the available version tags in BugZilla. Create new
milestone 1.9.8 and version 1.9.7.

20. Add a new release tag to doap_Ant.rdf in Ant's site.

21. checkout the 1.9.x branch, merge the tag but don't push the
commit

$ git checkout 1.9.x
$ git merge rel/1.9.7

Set the version number in several files to the required version of
the next 1.9.x release. These are:

* manual/cover.html
* manual/credits.html
* build.xml properties : project.version,manifest-version,pom.version

project.version property in build.xml gets bumped to
[newversion]alpha, for example 1.9.8alpha

manifest-version gets bumped to the exact next release number
for example 1.9.8.

pom.version gets bumped to [newversion]-SNAPSHOT
for example 1.9.8-SNAPSHOT.

* POM files under src/etc/poms and subdirectories
if you've got mvn installed

$ mvn versions:set -DnewVersion=1.9.8-SNAPSHOT -DgenerateBackupPoms=false

inside src/etc/poms should do the trick.

* ivy.xml in release subdirectory
* WHATSNEW (add a new section)
* src/etc/testcases/taskdefs/conditions/antversion.xml

Amend the merge commit

$ git add -u
$ git commit -a --amend
$ git push

22. checkout the master branch, merge the 1.9.x branch

$ git checkout master
$ git merge 1.9.x
$ git push

23. wait a few hours for the mirrors to catch up



16. Update the ant.apache.org site :

@@ -193,27 +298,12 @@ Note: This document was updated in the context of releasing Ant 1.9.5.
the production folder - since the site still uses svn and Ant
proper uses git there currently is no way to use the scm for this.

17. Address the available version tags in BugZilla. Create new
milestones and versions 1.9.6.
Assign all existing 1.9.5 bugs to 1.9.6.
Note that such changes can be done at once by choosing the
link "Change several bugs at once" at the bottom of the bug list
displaying the 1.9.5 bugs.

18. At this point in time, the release is done and announcements are made.
PGP-sign your announcement posts.

Apache mailing lists that should get the announcements:
announce@apache.org, dev@ant and user@ant.

19. Add a new release tag to doap_Ant.rdf in Ant's site.

20. Update the Apache Reporter System

https://reporter.apache.org/addrelease.html?ant

21. If you've created a temporary branch you can delete it now.

22. You can now reacquaint yourself with your family and friends.

(*) Mirrors : the srcdownload.html, bindownload.html and


+ 0
- 10
build.xml View File

@@ -497,16 +497,6 @@
</or>
</condition>

<!-- http client needs commons logging -->
<condition property="apache-httpclient.present">
<and>
<available
classname="org.apache.commons.httpclient.HttpClient"
classpathref="classpath" ignoresystemclasses="${ignoresystemclasses}"/>
<isset property="commons.logging.present"/>
</and>
</condition>

<available property="rhino.present"
classname="org.mozilla.javascript.Scriptable"
classpathref="classpath" ignoresystemclasses="${ignoresystemclasses}"/>


+ 4
- 5
src/etc/testcases/taskdefs/conditions/antversion.xml View File

@@ -36,7 +36,6 @@
</not>
</condition>
Should be exactly 1.10.0

</fail>
</target>

@@ -45,10 +44,10 @@
<fail>
<condition>
<not>
<antversion atleast="1.9.7" />
<antversion atleast="1.9.8" />
</not>
</condition>
Should be at least 1.9.7
Should be at least 1.9.8
</fail>
</target>

@@ -57,10 +56,10 @@
<fail>
<condition>
<not>
<antversion exactly="1.9.7" />
<antversion exactly="1.9.8" />
</not>
</condition>
Should be exactly 1.9.7
Should be exactly 1.9.8
</fail>
</target>
</project>

Loading…
Cancel
Save