-
Notifications
You must be signed in to change notification settings - Fork 834
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Improve release notes #1471
Comments
/priority p1 |
I've been checking out how does Kubernetes handle this. I've summarised the main points below. What are your thoughts on this process @gsunner? Adding release notes to PRsOn one hand, when a PR is created, a Prow automation checks if there is a populated block in the PR body such as:
If there isn't, a Prow automation will label the PR as Note that some PRs won't need public-facing release notes (e.g. fixes on the integration tests). To disable release notes for a PR, you can use the There are also a few other conventions to flag different types of release notes. This is documented in detail here: https://github.com/kubernetes/community/blob/62300e7e0b066131bfc45721f5042d9db9e14aea/contributors/guide/release-notes.md Extracting release notes from PRsOn the other hand, at release time they've got some tooling which crawls over all the PRs, extracting the |
I do like this that by deafult its "do-not-merge/release-note-label-needed" and then you have to "/release-note-none" to merge it. But does this mean you only add a body to the PR if its "Some public-facing release note."? |
Actually I see the release-note has a particular format, so you can mix normal PR descriptions and ones for the public note. |
@gsunner I had a go using the Prow plugin and the
By default, the The default template splits the changelog by kind (using the # Release notes for master
[Documentation](https://docs.k8s.io/docs/home)
# Changelog since v10.0.3
## Urgent Upgrade Notes
### (No, really, you MUST read this before you upgrade)
- You now need to add a `release-notes` block on every PR. ([#27](https://github.com/SeldonIO/jenkins-x-seldon-core-sandbox/pull/27), [@adriangonz](https://github.com/adriangonz))
## Changes by Kind
### Documentation
- Added `release-notes` plugin. ([#26](https://github.com/SeldonIO/jenkins-x-seldon-core-sandbox/pull/26), [@adriangonz](https://github.com/adriangonz)) [SIG Python] That was generated running: release-notes \
--github-org SeldonIO \
--github-repo jenkins-x-seldon-core-sandbox \
--required-author '' \
--start-rev v10.0.3 \
--end-rev master \
--output release-notes.md \
--release-version v10.1.0 |
This is really cool. As part of this I would be keen to explore potentially moving to squashed commits, which require having a required structure on the content of the PR which could go into the automated release, not sure if this would still be part of the context of this issue tho? |
It also may be worth creating a new pipeline that is focused on releases, such as |
Right now we generate the release notes automatically from Git's history (using PR titles). However, this information alone may not be enough on some cases. One common example would be breaking changes introduced by the PR (e.g. dependency updates, changes on functionality, naming, etc.).
It would be good to define a process to document these kind of upgrade notes (including breaking changes) so that they also get incorporated on the release notes.
Before deciding on a process, we should research what other open source projects do to compile these notes and to generate the changelogs automatically. Prow may already have an opinion on how to compile and publish breaking changes?
The text was updated successfully, but these errors were encountered: