Skip to main content
Jump to: navigation, search

Difference between revisions of "Gemini/Blueprint/Releasing"

(Release Instructions)
(Release Instructions)
Line 29: Line 29:
 
# collect sources into JARs - mvn source:jar (outputDirectory doesn't work)
 
# collect sources into JARs - mvn source:jar (outputDirectory doesn't work)
 
# generate documentation - cd docs; mvn clean pre-site; cd .. (used to be docbkx:generate-html docbkx:generate-pdf) // output in docs/target/site/
 
# generate documentation - cd docs; mvn clean pre-site; cd .. (used to be docbkx:generate-html docbkx:generate-pdf) // output in docs/target/site/
 +
## switch to Java 5
 
# generate Maven repo (when the Gemini maven repo is open for business):
 
# generate Maven repo (when the Gemini maven repo is open for business):
 
## For full releases (not milestone or RC) may be necessary to change distributionManagement repository to point at release repository
 
## For full releases (not milestone or RC) may be necessary to change distributionManagement repository to point at release repository
## switch to Java 5
 
 
## mvn -P equinox -Dmaven.test.skip=true deploy -DperformRelease -DaltDeploymentRepository=local::default::file:/tmp/gemini-blueprint/1.0.1.M01/repo
 
## mvn -P equinox -Dmaven.test.skip=true deploy -DperformRelease -DaltDeploymentRepository=local::default::file:/tmp/gemini-blueprint/1.0.1.M01/repo
## switch back to Java 6 or later
+
# run release project - cd release; rm -rf target; mvn -P equinox package -Dmaven.test.skip=true
 
+
# run the mvn deploy target above but this time without the altDeploymentRepository (for milestones) to get the same binaries in the zip and in the repo
 
+
# switch back to Java 6 or later
<work in progress>
+
# tag the git repo
 
+
# increase version to 1.0.2.BUILD-SNAPSHOT
The following are old notes for Spring DM. Need to update them for Gemini Blueprint!
+
 
+
Spring Dynamic Modules release procedure
+
-----
+
 
+
Step 2: Generate release artifacts
+
 
+
# run release project - cd release; rm -rf target; mvn -o -P equinox package -Dmaven.test.skip=true
+
# check version and format on both javadocs & docs
+
# update maven archetype
+
# update readme.txt/readme-libraries.txt
+
# final search for XXX-SNAPSHOT to see whether it is referred to somewhere
+
 
+
# the assembly already created the artifacts under release/target. You just need to add the sources under src/ folder.
+
# add Incubator in the name
+
# commit sources with stable revisions
+
# do SVN export to provide the sources (should find a better way) and add them to the with-dependencies archive. Check what modules should be excluded (docs/release/lib) - archive the sources into a zip (since building causes leftovers)
+
# delete local maven repo
+
# try to build the project from the sources
+
# if everything works out okay, put the sources in the archive,make tag and increase version to 1.1.X-SNAPSHOT tag
+
 
+
# run the mvn deploy target above but this time w/o the altDeploymentRepository (for milestones)
+
## to get the same binaries in the zip and in the repo // Which step created the ZIP?
+
 
+
Step 3 - upload artifacts:
+
 
# upload ZIP to Eclipse
 
# upload ZIP to Eclipse
# create zip for javadocs, docs, and *.txt
 
# update online schemas at ???
 
 
# tag git repository for the version
 
# increment project version to n.n.n.BUILD-SNAPSHOT and commit
 
 
 
# update the downloads page
 
# update the downloads page
 
# announce forums and mailing list
 
# announce forums and mailing list
  
 
[[Category:Gemini Blueprint|Blueprint]]
 
[[Category:Gemini Blueprint|Blueprint]]

Revision as of 08:58, 31 May 2012

Building Gemini Blueprint

Release Instructions

Pre-req's: Java 5 in addition to preferred Java version. Maven 2.0.x has worked in the past; now using 3.0.3.

For example, for 1.0.1.M01:

Step 1 - update version, build, test:

  1. mvn versions:set -DnewVersion=1.0.1.M01
  2. find . -name "*.versionsBackup" -exec rm {} \;
  3. check Spring version properties in main pom.xml
  4. update changelog and its version/date
  5. find . -name "boot-bundles.properties" and update ignore.gemini.blueprint.version to 1.0.1.M01
  6. if blueprint schema needs to be changed:
    1. add the file gemini-blueprint-<version>.xsd to core/src/main/resources/org/eclipse/gemini/blueprint/config
    2. update the version attribute of the xsd:schema element of the above file
    3. update core/src/resources/main/resources/META-INF/schema (especially the aliases)
    4. update xml files in META-INF/spring which refer to the latest version of the eclipse-gemini-blueprint.xsd schema
  7. switch to Java 5
  8. Build and test using:
    1. mvn clean install -Pit,felix
    2. mvn clean install -Pit,knopflerfish // a few integration tests currently fail, but this could be KF setup problem
    3. mvn clean install -Pit,equinox
  9. switch back to Java 6 or later

Step 2 - generate release artifacts:

  1. generate javadocs - mvn javadoc:aggregate javadoc:jar - aggregated javadoc in target/site/apidocs/
  2. collect sources into JARs - mvn source:jar (outputDirectory doesn't work)
  3. generate documentation - cd docs; mvn clean pre-site; cd .. (used to be docbkx:generate-html docbkx:generate-pdf) // output in docs/target/site/
    1. switch to Java 5
  4. generate Maven repo (when the Gemini maven repo is open for business):
    1. For full releases (not milestone or RC) may be necessary to change distributionManagement repository to point at release repository
    2. mvn -P equinox -Dmaven.test.skip=true deploy -DperformRelease -DaltDeploymentRepository=local::default::file:/tmp/gemini-blueprint/1.0.1.M01/repo
  5. run release project - cd release; rm -rf target; mvn -P equinox package -Dmaven.test.skip=true
  6. run the mvn deploy target above but this time without the altDeploymentRepository (for milestones) to get the same binaries in the zip and in the repo
  7. switch back to Java 6 or later
  8. tag the git repo
  9. increase version to 1.0.2.BUILD-SNAPSHOT
  10. upload ZIP to Eclipse
  11. update the downloads page
  12. announce forums and mailing list

Copyright © Eclipse Foundation, Inc. All Rights Reserved.