Skip to content

Commit

Permalink
Update documentation about how to create a release (opencast#6320)
Browse files Browse the repository at this point in the history
This patch updates the documentation about how to create a release.

While the process is mostly the same, it is slightly different by now.
This patch reflects the changes by updating our release manager guide.


### Your pull request should…

* [x] have a concise title
* [x] [close an accompanying
issue](https://docs.opencast.org/develop/developer/#participate/development-process/#automatically-closing-issues-when-a-pr-is-merged)
if one exists
* [x] [be against the correct
branch](https://docs.opencast.org/develop/developer/development-process#acceptance-criteria-for-patches-in-different-versions)
* [x] include migration scripts and documentation, if appropriate
* [x] pass automated tests
* [x] have a clean commit history
* [x] [have proper commit messages (title and body) for all
commits](https://medium.com/@steveamaza/e028865e5791)
* [x] explain why it needs to be merged into the legacy branch, if it is
targeting the legacy branch
  • Loading branch information
lkiesow authored Nov 20, 2024
2 parents 29de317 + 9cdd4e6 commit fab8535
Showing 1 changed file with 22 additions and 47 deletions.
69 changes: 22 additions & 47 deletions docs/guides/developer/docs/participate/release-manager.md
Original file line number Diff line number Diff line change
Expand Up @@ -307,26 +307,26 @@ needs to be done manually.

The following steps outline the necessary steps for cutting the final release:

1. Switch to and update your release branch and ensure the latest state of the previous release branch is merged:
0. Switch to and update your local release branch.

git checkout r/6.x
git fetch <remote>
git merge <remote>/r/6.x
git merge <remote>/r/5.x

2. Add the release notes, and update the changelog. The `create-changelog` [helper script
1. Add the release notes, and update the changelog. The `create-changelog` [helper script
](https://github.com/opencast/helper-scripts/tree/master/release-management/create-changelog) is a convenient tool
for this.
for this. You need to update:

- `docs/guides/admin/docs/releasenotes.md`
- `docs/guides/admin/docs/changelog.md`

Create a pull request for the updated documentation and merge it.

cd docs/guides/admin/docs/
vim releasenotes.md
vim changelog.md
git commit -S releasenotes.md changelog.md -m 'Updated Release Notes'
git push <remote> r/6.x
2. Update your local release branch yet again, so that it contains the documentation:

git checkout r/16.x
git fetch <remote>
git merge <remote>/r/16.x

3. Switch to a new branch to create the release (name does not really matter):

git checkout -b tmp-6.0
git checkout -b tmp-16.0

4. Make the version changes for the release:

Expand All @@ -335,17 +335,18 @@ The following steps outline the necessary steps for cutting the final release:
5. Have a look at the changes. Make sure that nothing else was modified:

git diff
git status | grep modified: | grep -v pom.xml # this should yield no output
# The following command should yield no output:
git status | grep modified: | grep -v pom.xml

6. Commit the changes and create a release tag:

git add $(git status | grep 'modified:.*pom.xml' | awk '{print $2;}')
git commit -S -m 'Opencast 6.0'
git tag -s 6.0
git commit -S -m 'Opencast 16.0'
git tag -s 16.0 -m 'Opencast 16.0'

7. Push the tag to the community repository (you can remove the branch afterwards):

git push <remote> 6.0:6.0
git push <remote> 16.0

8. Check the “Create new release” GitHub Actions workflow.
It will automatically build and upload the release tarballs and create a new release draft.
Expand All @@ -354,38 +355,12 @@ The following steps outline the necessary steps for cutting the final release:
If the workflow fails, investigate what was going wrong and either restart the workflow or create the release
manually in the GitHub user interface.

9. Check that the release is published on [Maven Central](https://repo1.maven.org/maven2/org/opencastproject/opencast-common/).
9. Post a release notification on [opencast.org](https://opencast.org).

10. Check that the release is published on [Maven Central](https://repo1.maven.org/maven2/org/opencastproject/opencast-common/).
This can take some time, and is done via [Buildbot](http://ci.opencast.org). If in doubt, ask the QA Coordinator to
check. If you need to do this yourself please read the [infra documentation](infrastructure/maven-repository.md#pushing-to-maven-central).

Finally, send a release notice to Opencast's announcement list. Note that posting to this list is restricted to those
who need access to avoid general discussions on that list. In case you do not already have permissions to post on this
list, please ask to be given permission. For the message, you may use the following template:

```no-highlight
To: [email protected]
Subject: Opencast <VERSION> Released
Hi everyone,
it is my pleasure to announce that Opencast <VERSION> has
been released:
https://github.com/opencast/opencast/releases
The documentation for this release can be found at:
https://docs.opencast.org/r/<VERSION>/admin/
RPM and Debian packages as well as Docker images will be
available soon. Watch for announcements on the users list.
To all committers and involved contributors, thank you for
all your work. This could not have happened without you and
I am glad we were able to work together and get this release
out.
```


### Appointment of Next Release Manager

After the release branch is cut, all work on `develop` is effectively the preparation for the next release. At this
Expand Down

0 comments on commit fab8535

Please sign in to comment.