-
Notifications
You must be signed in to change notification settings - Fork 1.6k
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
Update to grpc-gateway v2 #6567
Update to grpc-gateway v2 #6567
Conversation
hack/generate-proto.sh
Outdated
@@ -16,16 +16,18 @@ | |||
|
|||
set -e | |||
|
|||
docker build -t gen-proto -f hack/proto/Dockerfile --target generate-files proto | |||
docker build --platform linux/amd64 -t gen-proto -f hack/proto/Dockerfile --target generate-files proto |
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.
Do we really need to mention the platform switch?
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.
Oops. I was trying to build from an M1 and it was failing. I'll back this out.
7d22452
to
c447965
Compare
Codecov Report
@@ Coverage Diff @@
## main #6567 +/- ##
==========================================
- Coverage 70.48% 70.38% -0.11%
==========================================
Files 515 517 +2
Lines 23150 23365 +215
==========================================
+ Hits 16317 16445 +128
- Misses 5776 5857 +81
- Partials 1057 1063 +6
Continue to review full report at Codecov.
|
CI/CD failing with lint error:
The kokoro failure is the known flake -
|
Thanks @aaron-prindle — I left that code in to see as the integration tests were failing when cloning the state using the JSON marshaller as |
Marking as blocked: hold off until next release. |
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.
Couple quick questions but everything looks good
var suggestions2 protoV2.Suggestion | ||
suggestions2.Action = suggestion.Action | ||
suggestions2.SuggestionCode = suggestion.SuggestionCode | ||
suggestions2.Action = suggestion.Action | ||
suggestionsV2[i] = &suggestions2 |
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.
feel free to add a todo here for me to put this into a function since we use it a couple times
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.
Are there other places?
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 think there are just 2, here and in func V2fromV1()
a bit further down in the same file
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. Thanks for the clarifications @briandealwis
Fixes #5986
Related: #6556
Description
This PR separates out an upgrade of
grpc-gateway
that @baleshk incorporated into his CloudEvents PR in #6556.Protobufs must be passed by-reference and not by-value
A side-effect is that I had to change our code pass protobuf objects by reference instead of by value (more below). The newer proto generation now marks protobuf objects with a
DoNotCopy
marker to generate warnings when they are copied. Protobuf objects are not meant to be copied by value: they include an internal field that is meant to be accessed atomic access, and this field has been there for a while.Swagger/OpenAPI output has changed
@baleshk noted that error handling is removed in the newer gateway. As a result the swagger output is changed.
The gRPC Gateway migration guide notes that they now use the RPC status return.
This change is for the better:
OLD:
data:image/s3,"s3://crabby-images/3597f/3597f746e16c1a32ec95151d21d4c967cd58e699" alt="swagger-old"
NEW:
data:image/s3,"s3://crabby-images/5aa4c/5aa4ce70cece5b83c5df293569f06455e3c40910" alt="skaffold-new"
User facing changes (remove if N/A)
Follow-up Work (remove if N/A)
Filed #6600 to track follow-on work: the Swagger editor complains about our Swagger output as we're missing a version field, and we have a lot of badly named types (
protoState
) that would be nice to clear up.