-
Notifications
You must be signed in to change notification settings - Fork 1.5k
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 gateway to avoid an extra gRPC call #1174
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -224,24 +224,16 @@ func (r *Receiver) startServer(host component.Host) error { | |
err := componenterror.ErrAlreadyStarted | ||
r.startServerOnce.Do(func() { | ||
err = nil | ||
// Register the grpc-gateway on the HTTP server mux | ||
c := context.Background() | ||
opts := []grpc.DialOption{grpc.WithInsecure()} | ||
endpoint := r.ln.Addr().String() | ||
|
||
_, ok := r.ln.(*net.UnixListener) | ||
if ok { | ||
endpoint = "unix:" + endpoint | ||
} | ||
|
||
err = collectortrace.RegisterTraceServiceHandlerFromEndpoint(c, r.gatewayMux, endpoint, opts) | ||
if err != nil { | ||
return | ||
// Register the grpc-gateway on the HTTP server mux | ||
if r.traceReceiver != nil { | ||
// Cannot return error, impossible to test | ||
_ = collectortrace.RegisterTraceServiceHandlerServer(context.Background(), r.gatewayMux, r.traceReceiver) | ||
} | ||
|
||
err = collectormetrics.RegisterMetricsServiceHandlerFromEndpoint(c, r.gatewayMux, endpoint, opts) | ||
if err != nil { | ||
return | ||
if r.metricsReceiver != nil { | ||
// Cannot return error, impossible to test | ||
_ = collectormetrics.RegisterMetricsServiceHandlerServer(context.Background(), r.gatewayMux, r.metricsReceiver) | ||
} | ||
|
||
// Start the gRPC and HTTP/JSON (grpc-gateway) servers on the same port. | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The comment about JSON is probably misleading now, given the recent change #1021 introducing support for It seems that grpc-gateway still supports JSON as a default serialization format, see https://github.com/grpc-ecosystem/grpc-gateway/blob/ee3ef70b7777cde4e61e4e224cb11e92beecee6a/runtime/marshaler_registry.go#L78 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This is the There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
In your comment I linked above, you say that we don't want to support JSON yet, but we already do, and there is a known issue with encoding of trace and span IDs. So to prevent people from using the JSON format until we decide to officially support it, we need to override the default marshaller in gRPC Gateway. You're right that this is out of scope of this PR, I just made a comment to clarify the desired behaviour since you've touched the gRPC Gateway. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Please file an issue to not forget about this. As you said is not in the scope so don't want to focus on other things. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. |
||
|
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.
If it cannot return error then it's safer to panic in case the impossible does happen than ignoring the error
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.
See the comment, I did this because of test coverage :(. And panic will not help. If you have any idea (I would avoid adding a func pointer just to test an impossible to fail function)
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.
Well, this really seems like a code smell just to make the code coverage happy :(
Go linters normally complain about the incorrect error handling like this.
Looks like the only way to exclude this block from code coverage is to extract it to a separate file and exclude from the file list for
go tool cover
. I agree that's not worth 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.
I know also that API smells a bit because returns an error that never happens. :(
Will give a shot tomorrow to have something more reasonable