Skip to content
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

Backport handling improvements #7078

Open
bkchr opened this issue Jan 7, 2025 · 7 comments
Open

Backport handling improvements #7078

bkchr opened this issue Jan 7, 2025 · 7 comments

Comments

@bkchr
Copy link
Member

bkchr commented Jan 7, 2025

Backporting also already partly automated via the bot and that works okayish. However, prs are staying in the queue for some time and can only be merged by the release team or something like this. I don't see any reason why these prs can only be approved by the release team. These prs should be actually merged almost automatically if all tests are green. I think we should also push to crates.io more often and not wait for random dates. Having fixed dates for binaries is reasonable, but for libraries that get consumed it isn't that useful IMO. Once per day we could release the changes to crates.io to not do too many pushes or once peer week, but clearly more than once every x weeks. As the backports are also only patches/fixes that shouldn't be causing any problems downstream.

To make this happen, we need the following:

  • Ensure that CI is working in the stable branches. Right now it is most often failing and that should be prevented.
  • Change the flow to merge automatically if the backport is basically a verbatim copy of the original reviewed code or require one review if there is more than one commit in the backport pr.
  • Release the changed crates every X days from the stable branches.
@acatangiu
Copy link
Contributor

I fully support this! 👍

Ensure that CI is working in the stable branches. Right now it is most often failing and that should be prevented.

This is the most important piece, up until recently it was not working at all, but from what I've seen recently it's now (mostly) working. Just need to get it to the finish line.

@ggwpez
Copy link
Member

ggwpez commented Jan 7, 2025

CI should 100% be green. And all changed be pushed back to the release branches. Currently we dont even have the exact files that were published.

The daily releasing to crates-io could be done, but is currently bottelencked on the automation thereof (and people to automate that) - hence the monthly patches.

@EgorPopelyaev
Copy link
Contributor

I agree, the backports to release branches should have less strict review rules then the normal prs, as they were already reviewed. Probably one should be enough in case there are some conflicts or bigger changes.
I have another question here, what should we do then with the github releases for the previous stables in case of the more often crates releases (as we also discussed before in the coordination chat, that the binaries publications should be dropped for old stables and kept only for the actual stable and it's patches)? Should we drop then the github releases for the old stables completely, or accumulate these releases and publish the summary once a month for each release as we did before?

@ggwpez
Copy link
Member

ggwpez commented Jan 8, 2025

as we also discussed before in the coordination chat, that the binaries publications should be dropped for old stables and kept only for the actual stable and it's patches

I am not convinced of this. Pierre mentioned rollouts a few times and to me this means to have old binaries running as well. So that instead of all validators updating to a new binary, only a fraction does, and we roll out versions gradually.

I will try to get some clarity on this.

@bkchr
Copy link
Member Author

bkchr commented Jan 8, 2025

I am not convinced of this. Pierre mentioned rollouts a few times and to me this means to have old binaries running as well. So that instead of all validators updating to a new binary, only a fraction does, and we roll out versions gradually.

They can just revert to an old binary if there is an issue. "Staged rollouts" also doesn't make any sense in a decentralized network. We are not controlling when someone is updating its node and we will clearly not build in anything that would try to control this.
Also it is not about the binaries of an old release, just that we don't need any binary attached to patch releases of older stable branches.

@ggwpez
Copy link
Member

ggwpez commented Jan 14, 2025

"Staged rollouts" also doesn't make any sense in a decentralized network. We are not controlling when someone is updating its node and we will clearly not build in anything that would try to control this

Yes we cannot control this. But we can publish metrics and educate node operators about it. Ethereum has this page to track client diversity: https://clientdiversity.org/

Also it is not about the binaries of an old release, just that we don't need any binary attached to patch releases of older stable branches.

Sorry I dont get what you mean by "older stable". There are maintained stables and unmaintained ones.
I wrote it in here, hopefully more clearly: https://forum.parity.io/t/polkadot-binary-releases/2429

as we also discussed before in the coordination chat, that the binaries publications should be dropped for old stables and kept only for the actual stable and it's patches

I also dont get the notation of "old stable" here. Do you mean a stable release that is still in our maintenance promise or not anymore?

@bkchr
Copy link
Member Author

bkchr commented Jan 14, 2025

By old stable I mean everything that is still maintained.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants