- Announce Release
- Pre-Publishing Steps
- Login to NPM Registry
- Publish Packages
- Commit Updated Versions
- Create Release
- Update Eclipse Release Page
- Post-Release
It's good to give a heads-up to the Theia developers some hours before a release. One can use whatever forum is appropriate. At the time of writing this is Discourse
.
Here is an example.
Before publishing it's important to make sure that a functional Theia application can be made from the latest next
version of the platform. Else we will have problems with "latest" after publishing.
One easy way is to use the theia-apps repo CI:
-
Make sure that there is no pending build on Theia master, otherwise a new "next" version might be published while we validate the current "next".
-
Go in the theia-apps repo here and identify the latest commit. There should be an icon next to it; either a red X or a green checkmark. Click on it to go the Travis page. There re-trigger the build. We need to make sure that at least the various "next" builds pass CI.If it doesn't, it needs to be fixed before continuing.
-
In case the theia-app images fail CI for reasons not related to the
next
Theia platform extensions (e.g. none of the images currently pass CI includinglatest
), a fallback alternative is to build and briefly test one Theia app locally using thenext
version of a good subset of the platform extensions. -
Update the forum release post to ask committers to hold-off merging any PR while the release is ongoing.
Follow this instruction to login to the npm registry with a user account.
If you don't have an account contact Theia organization to request one.
yarn run publish
This command will rebuild all packages, test them, publish to npm and bump versions.
If publishing of an individual package failed then publish it with npm publish
from its root after resolving outstanding issues.
git add * git commit -m "publish v${published.version}" -s git push ${remote for main Theia repo} master:${branch}
The version picked during package publishing should be used as ${published.version}
.
For example, if you picked 0.1.0
as a version and your git remote for the main Theia repo is named origin
, then you should run:
git add *
git commit -m "publish v0.1.0" -s
git push origin master:release_0_1_0
Then from the project's main page, create a pull request from the branch just pushed. Have another committer on standby to quickly review and approve the PR, then merge it.
The next step is to create a new Release.
This will create a new tag
, release
with the appropriate assets (.zip
, tar.gz
) and notify subscribers.
In order to create a new release, one must:
-
navigate to the releases page.
-
select the "Draft a new release" button.
-
input the appropriate release
tag
version (ex:v1.2.0
). -
input the appropriate release
name
(ex:Eclipse Theia v1.2.0
). -
include a release
description
to include a reference to thechangelog
at the respectivesha
and release version:[Release Changelog](https://github.com/eclipse-theia/theia/blob/${sha}/CHANGELOG.md#${changelog-version-header})
For example (version
v1.2.0
):[Release Changelog](https://github.com/eclipse-theia/theia/blob/2aa2fa1ab091ec36ef851c4e364b322301cddb40/CHANGELOG.md#v120)
-
select "Publish Release" bottom at the bottom of the page.
For additional information, please consult the official GitHub documentation regarding creating releases.
Login to Eclipse Foundation Theia project page
-
On the right side panel, select Release / Create a new release
Create a new version
- Name: enter the new version for this release. (ex: 1.2.0).
- Date: enter the date for this release.
Select the edit tab
- In "The Basic" section
- Select the "Type A" in the IP Due Diligence type.
- In the "Project Plan"
- Deliverables section
- Paste the content of the changelog.md.
- Compatibility section
- Paste the content of the "Breaking changes"
- Deliverables section
-
When completing the edition, select "Save" at the bottom of the page.
-
To confirm the release is successful,
- Open the page https://projects.eclipse.org/projects/ecd.theia
- Select the version you just created.
- Open the Review plan section, you should see the data provided before.
- Open the page https://projects.eclipse.org/projects/ecd.theia
Update the forum release post to announce that the release has completed.
After a release, it is a good time to perform a yarn upgrade
on the repository to update the yarn.lock
.
Updating the yarn.lock
helps identify potential problems with our dependency version ranges, and is more representative of what downstream adopters may pull when building their own applications.
To successfully complete a yarn upgrade
, one must:
- perform
yarn upgrade
at the root of the repository. - fix any compilation errors, typing issues, and failing tests that may be introduced.