-
Notifications
You must be signed in to change notification settings - Fork 140
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
docs releases #766
docs releases #766
Conversation
Bencher
Bencher - Continuous Benchmarking View Public Perf Page Docs | Repo | Chat | Help |
Bencher
Bencher - Continuous Benchmarking View Public Perf Page Docs | Repo | Chat | Help |
Bencher
Bencher - Continuous Benchmarking View Public Perf Page Docs | Repo | Chat | Help |
Bencher
Bencher - Continuous Benchmarking View Public Perf Page Docs | Repo | Chat | Help |
we should also specify when to run the action. I would say every time that we do PR we need to bump the versions of the affected crates and then run the action in order to do a release. Keep in mine that at least for the lib crates if we try to do release without bumping the version the action will fail so is kinda safe. Of course if bump minor or major or patch is up to the dev but we have review for that. |
3182669
to
0427297
Compare
ack 0427297 |
Due to either github dependencies or a crate failing the build stage during publish not all crates are being published. | ||
Whenever a `PATCH` is introduced, it is applied to all the latest `MAJOR` releases. | ||
For example: imagine there's releases `v1.0.0`, `v1.1.0`, and `v2.0.0`. A bug is found, dating back all the way to `v1.0.0`. | ||
A patch is applied such that the following new tags are introduced: `v1.1.1` and `v2.0.1`. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
How do we do it? I guess that we should have a branch (or a tag?) for all the last x majior version of each libs.
This seems complicate. Another way could be to create the branch only when needed. We fix a bug for lib1-2.0.0
we find that also lib1-1.1.0
is affected and we want to backport the fix. We create a new branch from whatever was the state of the repo when lib1 have been go from v1 ti v2 and we apply the fix. If we do that only for last majior version, only when we have a bug that affect also the last majior version I do not think that we will end up with 'too many' branches, considering that most library in this repo will do not get a new majior version in many years. If this is a concern we can just say that we support the last majior version and that is not safe to use any version that is not the majior, or we can think about it when we will have more then one majior version (0 wont be maintained cause is unstable). Maybe we can just leave the various possibility here, for now we can say that we support only last majior so we do not make promise and when we will have more majior we will think about it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
On lines 10 and 12 of my proposal, there is a very important distinction we need to keep in mind:
SRI has a global version, which uses git tags and keeps track of how the codebase evolves across time as a whole.
Every internal SRI crate also follows SemVer 2.0.0, but each crate version is only set on the respective `Cargo.toml`,
(no git tags), and it evolves independently of the global release version.
Let's imagine this scenario, where both crate-A
and crate-B
are affected by a bug on the following versions:
Global Release Version | v2.0.0 | v1.1.0 |
---|---|---|
crate-A | v1.0.0 | v0.9.0 |
crate-B | v2.0.0 | v2.0.0 |
Here, Global Release Versions would be indicated as git tags.
Crate versions however, would only be indicated by Cargo.toml
and crates.io
. Otherwise, we would end up with too many tags.
After we patch the bug, we would have the following:
Global Release Version | v2.0.1 (new git tag) | v1.1.1 (new git tag) |
---|---|---|
crate-A | v1.0.1 (only bump Cargo.toml ) |
v0.9.1 (only bump Cargo.toml ) |
crate-B | v2.0.1 (only bump Cargo.toml ) |
v2.0.1 (only bump Cargo.toml ) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ok make sense. Only thing I wouldn't maintain version 0 and 1. I would just bump majior version of everyting to 2. And start from there 2 reasons here:
- We didn't followed semver so if you assume semver for what we have now you risk to end up with not compatible libraries.
- There several 0 library that now are 1 that at 0 were very very experimental and it do not make sense to to support them
An example of that is the noise crate.
Also is startum v2 so it can make sense to start from 2. Otherwise we should remove the old library from crates.io but I dont' know if is something possible or not.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree with what you're saying @Fi3, the only thing that bugs me is starting with 2.0.0, afaik we didn't really have an official release yet, and in public we always referred to things as MVP and later update. 1.0.0 is really a nice clean milestone, I am worried 2.0.0 may communicate certain level of maturity and stability which I am not sure we have yet.
Otherwise we should remove the old library from crates.io but I don't know if is something possible or not.
Doesn't sound like something impossible, I doubt there can be any consequences to this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
With regards to 2.0.0
, we should keep the SRI vs SV2 distinction in mind.
Sure, SV2 implies v2, but only for the Specifications.
That doesn't necessarily mean that as a Rust codebase, SRI should start at v2.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
With regards to crates.io removal, I found this:
rust-lang/crates.io#1506 (comment)
which is discouraging... it basically means we will not be able to remove the old libraries from crates.io, and we cannot "start from scratch".
I did understand your point on starting on 2.0.0
@Fi3 . It would be a way to put all SRI crates at the same starting point. But I still think starting on 2.0.0
would be bad, for the reasons I explained in my previous comment.
I wonder if we could do the same, but with all crates starting at 1.0.0
?
I did a quick search on all workspaces and I didn't see any crate that is above 1.0.0
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
from @Fi3 (over discord):
main issue is noise crate already 1.1.0 and is not semver 1.0.0 is not compatible with 1.1.0 but jakub told me in the call that you can mark a crate on crates.io as not usable so this could be a solution we could mark all crates like this one as not usable and in that case start from 1.1.0 and mark 1.0.0 as not usable
so assuming we will set all crates to v1.0.0
(except noise-sv2
), I crated this PR: #785
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sounds good. All the 0s will become 1.0.0. All the one already to 1 are yanked and we start from the very next minor. And we say that 0 is not supported anymore.
RELEASE.md
Outdated
|
||
## Versioning Notes | ||
Every PR needs to increase the version of whatever crate it is touching. Otherwise, we will mess up the dependency chain of whoever is fetching from crates.io |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would specify, every PR in main. PRs that add feature in dev are not going to increase the version number since they will be batched every [duration] into main. So lets say that when I do the release I add 5 feature to lib1 I will not increase the minor version of 5 but of 1.
So when we merge dev in main we increase the versions of the touched libs. When we merge a buge fix in main we increase the version of the touched libs. Whenever we merge something in main we run the releases actions
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ack bb039a4
We should decide the interval between release and stick with it, 2 weeks? That means that we do not wait for feature to be ready, every 2 weeks we ship what we have on dev. Also I would add something to automatically check the we do not mess with semver (it is very easy to think that something do not change the API but it change it). I found this linter https://crates.io/crates/cargo-semver-checks that we could add to our actions. That ofc do not remove the needs for human reviews is just an helper. |
ack 22e196e |
RELEASE.md
Outdated
|
||
# Versioning | ||
Every two weeks all the changes to `dev` are merged back into `main` and then tagged with a release number while bumping `MAJOR` and/or `MINOR`. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Every two weeks all the changes to `dev` are merged back into `main` and then tagged with a release number while bumping `MAJOR` and/or `MINOR`. | |
Every two weeks all the changes to `dev` are merged back into `main` and then tagged with a release number while bumping `MAJOR` and/or `MINOR`. |
After re-reading the PR the only thing I would be very careful is the pace of releases which we say is 2 weeks.
In startup/company structures this works, but my foss experience says we should probably be more conservative here no matter what type of release it is, I think even with 1-4 PR's it's obvious things can take quite a lot of time, especially if mainnet testing or any sort of testing is involved.
I would say we probablt shouldn't put a time-frame here, or we can put a 2-4weeks - until we do trial and error and see what kind of pace works for the structure/team we have here.
Trust me, 2-weeks is very tight in FOSS and can cause of lot of stress. As a reminder we're 8 months behind this release (ok it's major but just to give you a bit more realistic overview). What happens if we have PR's depending on each other and each of them requires testing (situation we had last 4-6 weeks).
FOSS structures are much loose and time-frames should adjust to that imo.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not opinionated on this, and I do see your point.
Over Discord I think you expressed a slightly different idea. There you're suggesting a 4 week release cycle.
Did you change your mind after writing this comment here (maybe during today's call)?
Either way is fine, just asking so I can change the wording on the PR. Also, feel free to suggest some direct changes to RELEASE.md
if you want.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would say 4 weeks was a consensus, but I still believe this is very optimistic. But for now we agreed we try with 4 weeks, and then see how it works for the team.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for pushing this one through end ensuring there's clarity. I left 2 comments that I believe we should discuss and one minor typo suggestion.
Due to either github dependencies or a crate failing the build stage during publish not all crates are being published. | ||
Whenever a `PATCH` is introduced, it is applied to all the latest `MAJOR` releases. | ||
For example: imagine there's releases `v1.0.0`, `v1.1.0`, and `v2.0.0`. A bug is found, dating back all the way to `v1.0.0`. | ||
A patch is applied such that the following new tags are introduced: `v1.1.1` and `v2.0.1`. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree with what you're saying @Fi3, the only thing that bugs me is starting with 2.0.0, afaik we didn't really have an official release yet, and in public we always referred to things as MVP and later update. 1.0.0 is really a nice clean milestone, I am worried 2.0.0 may communicate certain level of maturity and stability which I am not sure we have yet.
Otherwise we should remove the old library from crates.io but I don't know if is something possible or not.
Doesn't sound like something impossible, I doubt there can be any consequences to this?
Co-authored-by: Pavlenex <pavle@pavle.org>
Gave it another round of review, besides 4 week time-frame for a release, I don't see vulnerability/critical releases and how we handle those? Are those considered a patch, and if so does it mean a critical vulnerability will be patched within whatever time-frame we agreed on (2 or 4 weeks)on or is it instant? I don't mean define vulnerability response processes, but rather when a critical vulnerabilty is found how is it handled in a release cycle. Step by step on vulnerability response can be done in a separate security.md Generally with releases, it sounds odd, but it's storytelling. We want to tell a story, ,motivate the users and community why certain release brings good functionality, improvements or fixes is very important for users, helps build excitement and community around releases and encourage people to try them out and report back if they find issues. With short release cycle, this is really tricky. I've checked how other projects do it, and BDK does it every 4 weeks, and LDK does it every two months. I think for us it'll be trial and error and we may decide to change things as we learn more on what works for us. The biggest advantage of this PR is that it introduces some structure, and more importantly consensus on versioning. Time-frames and other things, can always changde depending on the structure of contributors and community. Just as an example, our first update was 6 months late, and the second one is probably few months behind (hard to say since we keep switching deadlines, but according to the latest deadline we're 20days behind). |
RELEASE.md
Outdated
|
||
# Versioning | ||
Every 4 weeks all the changes to `dev` are merged back into `main` and then tagged with a release number while bumping `MAJOR` and/or `MINOR`. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree with all @pavlenex's considerations about the 4 weeks period. I'm very skeptical about it and I don't see a need for it to be that strictly to be honest. Why not defining a time period at all? Or put it larger (2 months)?
Since with this release we finally implemented everything from the specs, I don't expect that many new features in a short-mid time frame. I'm sure we will need to make more patch releases than feature ones btw
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ok this point is generating a lot of confusion so I propose we leave the document like this for now:
- Every 4 weeks all the changes to `dev` are merged back into `main` and then tagged with a release number while bumping `MAJOR` and/or `MINOR`.
+ The SRI team will decide the appropriate time when the changes to `dev` are merged back into `main` and then tagged with a release number while bumping `MAJOR` and/or `MINOR`.
we can revisit this point in the future if necessary, but for now, we leave the date for v1.1.0
to be defined.
what do you think @Fi3 ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm sure we will need to make more patch releases than feature ones btw
I can understand this point, and I wonder if we can do something about it.
While we already have a strategy for dealing with bugs under SemVer 2.0.0
, IMO we should keep that for exceptional situations where finding a bug is actually a surprise.
With that in mind, I propose that we start our release cycle with v1.0.0-beta.0
instead of v1.0.0
.
As we fix bugs, we increase v1.0.0-beta.1
, v1.0.0-beta.2
, etc.
When we feel confident, we can finally move to v1.0.0
as a stable release.
(This suggestion is only related to global SRI releases. The internal crate versioning proposed on #785 can continue the same).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I understand your point about v1.0.0-beta.1, v1.0.0-beta.2
but I am slightly worried on what that communicates to the public, and something as simple as a tag could drive people away from implementing and just keep them in "I'll wait a bit more stage", and I am not sure about you guys, but I am tired of SV2 being in "pending" state. We need to push forward.
1.0.0 communicates that after 3+ years this is ready to be tested and adopted, sure there will be bugs, sure there's a LOT of work to be done to ensure stability, and probably a whole can of worms once different configurations and use-cases start being used, but... this is our opportunity to start fresh and clean, and I feel these tags would kill the momentum of excitement around something as significant as 1.0.0, so I'll really keep things as we already agreed, besides timeframe for releases seems we have a consensus. Timelines can easily be adjusted.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah now I would try to release it as 1.0.0
, without specifying a timeframe for merging dev
into main
and push a new release. After that, we will see how we can be more specific about timeframes, depending on external feedback and testing!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
ack 2c4cc3f
I think that falls under the definition of bugs and patches. Since we are leaving the timelines open for releases, I guess there's no point in specifying that for patches as well? Anyways, IMO these questions are already answered in these lines:
@pavlenex let me know if you feel we should elaborate more on this. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
Refactoring of docs about releases.