Skip to main content

Notice: this Wiki will be going read only early in 2024 and edits will no longer be possible. Please see: https://gitlab.eclipse.org/eclipsefdn/helpdesk/-/wikis/Wiki-shutdown-plan for the plan.

Jump to: navigation, search

Difference between revisions of "How to create a release of EMFStore"

(How to create a milestone release of EMFStore and ECP)
Line 14: Line 14:
 
* Update marketplace entrys: http://marketplace.eclipse.org/content/emfstore-0
 
* Update marketplace entrys: http://marketplace.eclipse.org/content/emfstore-0
 
* Tweet about the new release, use the hashtag #emfstore :)
 
* Tweet about the new release, use the hashtag #emfstore :)
 
== How to release locally ==
 
''org.eclipse.emf.emfstore.releng/build.properties'' defines the paths for the cloned git-repositories, for Hudson as well as for local builds. The properties ''local.git.checkout.base'' is the common base to which six different suffixes are appended. One for each repository. If you want to build locally, you will need to adjust these properties to your directory structure.
 
<source lang="python">
 
# repositories on local disk
 
local.git.checkout.base=${user.home}/git/ssh_emf
 
 
local.git.checkout.emfstore.core.extension=store.core
 
local.git.checkout.emfstore.releng.extension=store.releng
 
local.git.checkout.emfstore.other.extension=store.other
 
 
local.git.checkout.ecp.core.extension=cp.core
 
local.git.checkout.ecp.releng.extension=cp.releng
 
local.git.checkout.ecp.other.extension=cp.other
 
</source>
 
 
To start the Buckminster import from within the Eclipse IDE, right-click ''org.eclipse.emf.emfstore.releng/buckminster.mspec'' and select ''Buckminster''->''Import...''. Wait until all dependencies are resolved, then click ''Finish'' to materialize them.
 
In order to build EMFStore and ECP, right-click the project ''org.eclipse.emf.emfstore.site'' and select ''Buckminster''->''Invoke Action...''. Select the target ''site.p2'', and the properties-file ''org.eclipse.emf.emfstore.site/buckminster.properties'' from your workspace, and start the build with ''Ok''.
 
The result of the build will be in the sub-directory ''buckminster.output'' in your workspace, inside the folder named after the site-project.
 
  
 
== For all releases ==
 
== For all releases ==

Revision as of 07:03, 21 March 2013

How to create a milestone release of EMFStore and ECP

  • Commit with a message such as "release 0.8.9.M945" and push your changes to the emfstore.core repository.
  • Wait for the hudson job to recognize these changes (currently <= 5 minutes) and build.
  • Download the artifact site.p2 as a zip-file from the build that was triggered by your commit (look for your commit message).
  • Using scp (or WinScp) login with your Eclipse committer account at dev.eclipse.org, and move the content of /home/data/httpd/download.eclipse.org/emf-store/milestones/latest to /home/data/httpd/download.eclipse.org/emf-store/milestones/archive into a new subfolder named after the version, e.g. 0.8.9.M944, if it does not yet exist. You might have to download and re-upload, if the server does now allow you to move files.
  • Upload the unpacked zip-file and the zip-file itself to /home/data/httpd/download.eclipse.org/emf-store/milestones/latest

How to create a final release of EMFStore and ECP

To release a final version, you need to replace the version numbers manually and drop the qualifier:

  • Increase the version milestone number globally for all MANIFEST.MF and features.xml files in all repositories, e.g. if you currently have version 0.8.9.qualifier in, your workspace you would end up with 0.9.0.
  • Proceed with hudson and the upload of the build as with the milestone release, but use the directory releases instead of milestones
  • Switch back the relase to the continuous integration versioning scheme by adding the qualifier to the release version. For example, if you currently have version 0.9.0 in your workspace, you would end up with 0.9.0.qualifier.
  • Update project metadata on the release in portal: Mark as completed, add download and News and Noteworthy url, add planned next release
  • Update marketplace entrys: http://marketplace.eclipse.org/content/emfstore-0
  • Tweet about the new release, use the hashtag #emfstore :)

For all releases

  • Commit and push.
  • Create tags:
git tag -a x.x.x -m 'Release x.x.x'
git push --tags

Unresolved issues

  • Currently, there is still a known bug that prevents hudson from building the repository if there are no new changes since the last build. In this case the build will fail with the message "Nothing to do". Therefore, try not to build manually but commit a dummy-change to trigger the build.
  • "ERROR No reader type with id git has been registered with extension-point org.eclipse.buckminster.core.readerTypes". This means that the Git-reader is unknown to the Buckminster installation on the selected Hudson node. Resolution: Select a different set of nodes in the job-configuration.
  • "Wiping out workspace first. java.io.IOException: Unable to delete /opt/users/hudsonbuild/.hudson/jobs/emf-emfstore-integration/workspace [...]". This means that a file in the workspace is currently locked by a process on the server. Resolution: Try again later (you can trigger the deletion of the workspace manually from within Hudson).
  • "ERROR: Failed to join the process Looks like the node went offline during the build. Check the slave log for the details." Resolution: Try again later

See also

  • How to clone a git repository [2]
  • EMFStore changelog [3]
  • ECP changelog [4]

Links

Back to the top