Differences between revisions 40 and 41
Revision 40 as of 2012-03-27 15:48:33
Size: 7906
Editor: Milamber
Comment:
Revision 41 as of 2012-05-13 17:47:38
Size: 8719
Editor: Milamber
Comment:
Deletions are marked like this. Additions are marked like this.
Line 2: Line 2:

= Requirements =
 * a Java JDK in according with target JDK (java 5 for JMeter 2.7)
 * a recent ant binary (1.8+)
 * subversion (svn) installed
 * a text editor
 * hostname must resolve to ip address (not loopback)
Line 5: Line 12:
 * extract files from SVN trunk into a new temporay directory
{{{
svn co https://svn.apache.org/repos/asf/jmeter/trunk jmeter_trunk
}}}
 * Move to new directory:
{{{
cd jmeter_trunk/
}}}
Line 6: Line 21:
 * update JMeter``Version.java (version and year), build.xml (version and docversion) and NOTICE (year)  * update JMeterVersion.java (version and year), build.xml (version) and NOTICE (year)
  * (src/core/org/apache/jmeter/util/JMeterVersion.java)
  * build.xml: section: <property name="jmeter.version" value="2.7"/>
Line 8: Line 25:
  * section: <!ENTITY release '2.7'>
 * Download external jars
{{{
ant download_jars
}}}
Line 9: Line 31:
  * [clean-docs] then [docs-site]
 * update docs tree in SVN
 * build code
 * test
{{{
ant clean-docs
ant docs-site
}}}
 * Commit update version files and docs tree in SVN to prepare next release.
{{{
svn commit
}}}
 * build code to make a testing binary with this ant task:
{{{
ant -Djmeter.version=2.7 -Duser.name=username@apache.org distribution
}}}
 * test the new binaries
Line 18: Line 49:
 * tag all the files with a new RC tag, e.g. v2_5_1_RC2
   * SVN commands (example) :
{{{
svn copy https://svn.apache.org/repos/asf/jmeter/trunk https://svn.apache.org/repos/asf/jmeter/tags/v2_5_1_RC2
}}}
 * N.B. Tags must be immutable, i.e. must not be changed once created. A tag can be deleted if it is no longer needed, but must not be recreated.
   * If there is a problem with the contents of an RC tag, create a new tag, for example v2_5_1_RC3
   * If the tag is part of an ongoing release vote, do not delete it whilst the vote is ongoing, even if the vote is now using a later tag. It can be useful to be able to compare the contents of tags as part of the voting process.
   * Once the release vote is over, intermediate tags are no longer needed, and can be deleted.
   * If the tag has not been used in a release vote, it can be deleted immediately.
 * tag all the files with a new RC tag, e.g. v2_7_RC1
   * SVN commands (example from jmeter_trunk tree) :
{{{
svn copy https://svn.apache.org/repos/asf/jmeter/trunk https://svn.apache.org/repos/asf/jmeter/tags/v2_7_RC1
}}}
   * N.B. Tags must be immutable, i.e. must not be changed once created. A tag can be deleted if it is no longer needed, but must not be recreated.
     * If there is a problem with the contents of an RC tag, create a new tag, for example v2_7_RC2
     * If the tag is part of an ongoing release vote, do not delete it whilst the vote is ongoing, even if the vote is now using a later tag. It can be useful to be able to compare the contents of tags as part of the voting process.
     * Once the release vote is over, intermediate tags are no longer needed, and can be deleted.
     * If the tag has not been used in a release vote, it can be deleted immediately.
Line 30: Line 61:
svn co https://svn.apache.org/repos/asf/jmeter/tags/v2_5_1_RC2 jmeter_v2_5_1_RC2 svn co https://svn.apache.org/repos/asf/jmeter/tags/v2_7_RC1 jmeter_v2_7_RC1
Line 34: Line 65:
cd jmeter_v2_5_1_RC2/ cd jmeter_v2_7_RC1/
Line 43: Line 74:
ant distribution -Djmeter.version=2.5.1 -Duser.name=username@apache.org ant distribution -Djmeter.version=2.7 -Duser.name=username@apache.org
Line 47: Line 78:
ant _dist_maven -Djmeter.version=2.5.1 ant _dist_maven -Djmeter.version=2.7
Line 52: Line 83:
ant maven_upload -Djmeter.version=2.5.1 -DrepoType=releases ant maven_upload -Djmeter.version=2.7 -DrepoType=releases
Line 62: Line 93:
java -jar $RAT_HOME/apache-rat-0.8.jar ./apache-jmeter-2.5.1.tgz > rat-report-jmeter-2.5.1RC2.txt
unix2dos rat-report-jmeter-2.5.1RC2.txt
java -jar $RAT_HOME/apache-rat-0.8.jar ./apache-jmeter-2.7.tgz > rat-report-jmeter-2.7RC1.txt
unix2dos rat-report-jmeter-2.7RC1.txt
Line 72: Line 103:
mkdir -p ~/JMETER_2_5_1_RC2/dist/
}}}

 * '''From your computer''', upload dist files and RAT report to the temporary location (e.g. personal dir: ~/JMETER_2_5_1_RC2/dist/) in people.apache.org
mkdir -p ~/JMETER_2_7_RC1/dist/
}}}

 * '''From your computer''', upload dist files and RAT report to the temporary location (e.g. personal dir: ~/JMETER_2_7_RC1/dist/) in people.apache.org
Line 80: Line 111:
mkdir -p ~/public_html/jmeter-2.5.1RC2/dist/ mkdir -p ~/public_html/jmeter-2.7RC1/dist/
Line 84: Line 115:
cp ~/JMETER_2_5_1_RC2/dist/* ~/public_html/jmeter-2.5.1RC2/dist/ cp ~/JMETER_2_7_RC1/dist/* ~/public_html/jmeter-2.7RC1/dist/
Line 91: Line 122:
cd ~/public_html/jmeter-2.5.1RC2/
svn co https://svn.apache.org/repos/asf/jmeter/tags/v2_5_1_RC2/docs docs
cd ~/public_html/jmeter-2.7RC1/
svn co https://svn.apache.org/repos/asf/jmeter/tags/v2_7_RC1/docs docs
Line 98: Line 129:
cp ~/public_html/jmeter-2.5.1RC2/dist/apache-jmeter-2.5.1.tgz $HOME
tar xfz apache-jmeter-2.5.1.tgz
cd apache-jmeter-2.5.1/docs/
mv api ~/public_html/jmeter-2.5.1RC2/docs/api
rm -r $HOME/apache-jmeter-2.5.1
cp ~/public_html/jmeter-2.7RC1/dist/apache-jmeter-2.7.tgz $HOME
tar xfz apache-jmeter-2.7.tgz
cd apache-jmeter-2.7/docs/
mv api ~/public_html/jmeter-2.7RC1/docs/api
rm -r $HOME/apache-jmeter-2.7
Line 112: Line 143:
svn copy https://svn.apache.org/repos/asf/jmeter/tags/v2_5_1_RC2 https://svn.apache.org/repos/asf/jmeter/tags/v2_5_1 svn copy https://svn.apache.org/repos/asf/jmeter/tags/v2_7_RC1 https://svn.apache.org/repos/asf/jmeter/tags/v2_7
Line 119: Line 150:
cd ~/public_html/jmeter-2.5.1RC2/dist cd ~/public_html/jmeter-2.7RC1/dist
Line 128: Line 159:
cp apache-jmeter-2.5.1_src* /www/www.apache.org/dist/jmeter/source
cp apache-jmeter-2.5.1.zip* /www/www.apache.org/dist/jmeter/binaries
cp apache-jmeter-2.5.1.tgz* /www/www.apache.org/dist/jmeter/binaries
cp apache-jmeter-2.7_src* /www/www.apache.org/dist/jmeter/source
cp apache-jmeter-2.7.zip* /www/www.apache.org/dist/jmeter/binaries
cp apache-jmeter-2.7.tgz* /www/www.apache.org/dist/jmeter/binaries
Line 170: Line 201:
svn switch http://svn.apache.org/repos/asf/jmeter/branches/docs-2.5.1/docs svn switch http://svn.apache.org/repos/asf/jmeter/branches/docs-2.7/docs
Line 179: Line 210:
cd ~/public_html/jmeter-2.5.1RC2/docs cd ~/public_html/jmeter-2.7RC1/docs

This page is a brain dump of the various items needed for a release.

Requirements

  • a Java JDK in according with target JDK (java 5 for JMeter 2.7)
  • a recent ant binary (1.8+)
  • subversion (svn) installed
  • a text editor
  • hostname must resolve to ip address (not loopback)

Preparation

  • request Bugzilla version update (on INFRA or if you are JMeter committer, ask for sufficient Bugzilla karma to do this yourself)

  • extract files from SVN trunk into a new temporay directory

svn co https://svn.apache.org/repos/asf/jmeter/trunk jmeter_trunk
  • Move to new directory:

cd jmeter_trunk/
  • ensure changes.xml is up to date
  • update JMeterVersion.java (version and year), build.xml (version) and NOTICE (year)
    • (src/core/org/apache/jmeter/util/JMeterVersion.java)
    • build.xml: section: <property name="jmeter.version" value="2.7"/>

  • update xdocs/download_jmeter.xml to the new version
    • section: <!ENTITY release '2.7'>

  • Download external jars

ant download_jars 
  • build site documents, having first cleaned out existing files (so obsolete files will be removed):

ant clean-docs
ant docs-site
  • Commit update version files and docs tree in SVN to prepare next release.

svn commit
  • build code to make a testing binary with this ant task:

ant -Djmeter.version=2.7 -Duser.name=username@apache.org distribution
  • test the new binaries
    • GUI and non-GUI using host with graphic capability
    • non-GUI only using host with no graphic capability
    • ideally test on minimum supported Java and latest Java - especially for GUI

Generate Release

  • tag all the files with a new RC tag, e.g. v2_7_RC1
    • SVN commands (example from jmeter_trunk tree) :

svn copy https://svn.apache.org/repos/asf/jmeter/trunk https://svn.apache.org/repos/asf/jmeter/tags/v2_7_RC1
  • N.B. Tags must be immutable, i.e. must not be changed once created. A tag can be deleted if it is no longer needed, but must not be recreated.
    • If there is a problem with the contents of an RC tag, create a new tag, for example v2_7_RC2
    • If the tag is part of an ongoing release vote, do not delete it whilst the vote is ongoing, even if the vote is now using a later tag. It can be useful to be able to compare the contents of tags as part of the voting process.
    • Once the release vote is over, intermediate tags are no longer needed, and can be deleted.
    • If the tag has not been used in a release vote, it can be deleted immediately.
  • extract files from SVN using the tag into a new directory tree

svn co https://svn.apache.org/repos/asf/jmeter/tags/v2_7_RC1 jmeter_v2_7_RC1
  • Move to new directory:

cd jmeter_v2_7_RC1/
  • download jars needed to build: "ant download_jars"

ant download_jars
  • create distribution files:
    • Distribution ant task: ant distribution -lib=<libextra> -Djmeter.version=m.n -Duser.name=user-AT-apache.org

ant distribution -Djmeter.version=2.7 -Duser.name=username@apache.org
  • sign distribution files and maven files via ant tasks:

ant _dist_maven -Djmeter.version=2.7
ant sign_dist -Dgpg.keyname=<YOUR_KEY_ID> -Dgpg.secretKeyring=<path to secring.gpg i.e. ~/.gnupg/secring.gpg>
  • Upload to Maven repository:

ant maven_upload -Djmeter.version=2.7 -DrepoType=releases
  • Go to Apache Repository

    • Section Staging Repositories

    • You will receive a email with JMeter Maven Repo URLs
      • The main URL must be added to email vote.
  • Generate RAT report (example on Linux with Java)

java -jar $RAT_HOME/apache-rat-0.8.jar ./apache-jmeter-2.7.tgz > rat-report-jmeter-2.7RC1.txt
unix2dos rat-report-jmeter-2.7RC1.txt

Vote on release

  • Login to people.apache.org in SSH
  • Create temporary location to receive dist files

mkdir -p ~/JMETER_2_7_RC1/dist/
  • From your computer, upload dist files and RAT report to the temporary location (e.g. personal dir: ~/JMETER_2_7_RC1/dist/) in people.apache.org

  • Return to people.apache.org
  • Preparation RC publishing

mkdir -p ~/public_html/jmeter-2.7RC1/dist/
  • copy archives, sigs and hashes to dist

cp ~/JMETER_2_7_RC1/dist/* ~/public_html/jmeter-2.7RC1/dist/
  • check hashes (before / after uploads)
    • Install the site docs:

cd ~/public_html/jmeter-2.7RC1/
svn co https://svn.apache.org/repos/asf/jmeter/tags/v2_7_RC1/docs docs
  • Extract Javadocs: unzip -x jmeter-m.n.o.zip '*/docs/api/*' and move to docs/api

    • Example:

cd $HOME
cp  ~/public_html/jmeter-2.7RC1/dist/apache-jmeter-2.7.tgz $HOME
tar xfz apache-jmeter-2.7.tgz
cd apache-jmeter-2.7/docs/
mv api ~/public_html/jmeter-2.7RC1/docs/api
rm -r $HOME/apache-jmeter-2.7
  • send round [VOTE] e-mail to dev
  • Wait for any feedback (at least 72 hours); address any issues raised, if necessary by creating another release tag
  • If at least 3 PMC votes, then continue

After VOTE success

  • send round [VOTE] [RESULT] e-mail to same mailing lists
  • Copy the RC tag to the release tag

svn copy https://svn.apache.org/repos/asf/jmeter/tags/v2_7_RC1 https://svn.apache.org/repos/asf/jmeter/tags/v2_7

Move RC dist files to release

  • Connect to people.apache.org in SSH
  • Go to RC dist repository (e.g. personal dir)

cd ~/public_html/jmeter-2.7RC1/dist
  • Make sure that file group is set to jmeter (chgrp jmeter apache-jmeter*)

chgrp jmeter apache-jmeter*
chmod g+w apache-jmeter*
  • copy archives to /www/www.apache.org/dist/jmeter/binaries and /www/www.apache.org/dist/jmeter/source as appropriate

cp apache-jmeter-2.7_src* /www/www.apache.org/dist/jmeter/source
cp apache-jmeter-2.7.zip* /www/www.apache.org/dist/jmeter/binaries
cp apache-jmeter-2.7.tgz* /www/www.apache.org/dist/jmeter/binaries

Update Site dist

  • Checkout dist project on your computer

svn co  https://svn.apache.org/repos/asf/jmeter/dist dist-jmeter
  • Edit HEADER.html to modifiy with new version number
  • Optional, add your GPG public key to KEYS
  • Commit with svn

svn commit
  • Login to people.apache.org in SSH
    • Go to dist dir:

cd /www/www.apache.org/dist/jmeter
  • Execute a svn update

svn update

Update JMeter site

  • login to people.apache.org
  • Go to:

cd /www/jmeter.apache.org/
  • fetch site from SVN:
    • svn switch http://svn.apache.org/repos/asf/jmeter/tags/vm_n_o/docs

    • Example:

svn switch http://svn.apache.org/repos/asf/jmeter/branches/docs-2.7/docs
  • If the documentation needs to be updated between releases, create a branch docs-vm_n_o from the tag and switch to that
  • for later updates, use "svn switch" or "svn update" as appropriate (use svn info to find current setting)
  • The Javadocs are not in SVN so these need to be copied from the staging area
    • Example:

cd /www/jmeter.apache.org/
rm -r /www/jmeter.apache.org/api
cd ~/public_html/jmeter-2.7RC1/docs
cp -R api /www/jmeter.apache.org
chmod -R g+w /www/jmeter.apache.org/api
  • N.B. wait for few hours so site updates catch up

Maven Release

  • Go to Apache Repository

  • Section Staging Repositories

  • You will receive a email with JMeter Maven Repo URLs
    • The main URL can be added to email announce

Announce

Make sure: JMeter website is update AND download mirrors too.

  • update Wiki version details
  • update doap_JMeter.rdf details in trunk and commit
  • send [ANNOUNCE] e-mail to user@jmeter.a.o, dev@jmeter.a.o

    • Double check all URL in email announce!
  • also copy to announce AT ao (has to be sent from an ao e-mail address)
  • N.B. to track bounces and unsubscribes, it may be a good idea to use a separate mail to Announce

Tidy up

  • remove old archives from /www/www.apache.org/jmeter/dist

ReleaseCreation (last edited 2019-02-06 13:17:34 by Philippe Mouawad)