-
Notifications
You must be signed in to change notification settings - Fork 372
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
1.10 generated files breaking changes #570
Comments
I think generated mock defaults to The protobuf messages embedding |
I created #572 to regenerate the structures in the old way. A proof of concept that it works is at kubernetes-csi/external-provisioner#1266. |
Thanks a lot @jsafrane for catching this and for helping put together a rollback PR. We discussed this with at the k8s Storage SIG meeting and the CSI Community Meeting and got input from a CSI driver author (AWS EBS team) who went through a 1.10 version bump. Based on those discussions, and given that:
We have decided that we will keep the changes as is, and document them as breaking changes in release notes (and send out an email to notify folks). |
Good call, Saad
…On Thu, Sep 12, 2024, 2:42 AM Saad Ali ***@***.***> wrote:
We discussed this with at the k8s Storage SIG meeting and the CSI
Community Meeting and got input from a CSI driver author (AWS EBS team) who
went through a 1.10 version bump.
Based on those discussions, and given that:
1. It is important to keep to an "up to date" version of our
dependencies.
2. The "on the wire" CSI RPC is backwards compatible and has not had
breaking changes.
3. These breaking changes are in code generation and are immediately
obvious to SPs when they bump the API (build fails, there is no silent
failure).
We have decided that we will keep the changes as is, and document them as
breaking changes in release notes (and send out an email to notify folks).
—
Reply to this email directly, view it on GitHub
<#570 (comment)>,
or unsubscribe
</~https://github.com/notifications/unsubscribe-auth/AAR5KLFJOC2ANZB7XTVWW3DZWEZV5AVCNFSM6AAAAABM4BQXR2VHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDGNBVGM4TOMRXGQ>
.
You are receiving this because you are subscribed to this thread.Message
ID: ***@***.***>
|
Release notes for 1.10.0 have been updated to indicate breaking change: /~https://github.com/container-storage-interface/spec/releases/tag/v1.10.0 I will send a follow up email to broadcast the breaking change more broadly. |
Update to #552 has broken quite some Kubernetes CSI sidecars.
So far I identified two issues:
gomock cannot easily compare two messages now. Protobuf now stores some private stuff in
state
field, e.g.NodeGetInfoResponse
:spec/lib/go/csi/csi.pb.go
Lines 4827 to 4830 in 2f34062
It is possible to implement a custom gomock matcher that compares just the public fields, or use
proto.Equal
, as suggested in https://protobuf.dev/reference/go/faq/#deepequal.It's not possible to copy message content. For example, this code copies value of NodeGetInfoResponse:
Such a copy will copy also the private fields and one of the fields is sync.Mutex, which should not be copied (
govet
complains hard about it).In this particular case, the Kubernetes external-provisioner can use a pointer, it does not need to copy the struct content.
Both issues are solvable using proper protobuf functions (WIP PR here), but they were quite surprising for a minor go package bump.
I am not asking for a revert, just for a better communication of the breaking changes and semantic versioning of go packages. This should not be a minor package bump. There should be probably a separate repo with the generated go code, so we can bump the versions independently on CSI spec. Kubernetes solved this by calling all its go packages 0.x, so no go API stability should be expected, and they break their API from time to time.
The text was updated successfully, but these errors were encountered: