-
Notifications
You must be signed in to change notification settings - Fork 437
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
Check flusher interface before calling Flush #479
Conversation
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.
Small suggestion. I'm in two minds about this, because on the one hand this risks us silently supporting ResponseWriters that won't work. I think we need to have a discussion around this before agreeing to merge it. Why do you need this?
I think the question here should be "why are we casting |
The default implementation (the |
https://golang.org/pkg/net/http/#ResponseWriter It's not on the default interface |
No, it's not on the default interface, because they couldn't change the interface for backwards-compatibility reasons, but as you can see on https://golang.org/pkg/net/http/#Flusher:
|
"The Flusher interface is implemented by ResponseWriters that allow an HTTP handler to flush buffered data to the client. " The ones that allow, not necessarily all of them |
from that quote as well:
This is exactly what I'm proposing, checking for the ability before calling it |
I'm not sure what your point is, my point is that this library might not be able to support |
If we merge this, it might produce incorrect output, because the current implementation relies on being able to call Flush explicitly. I think failing silently, like this change would do, is really dangerous, because a user might get some weird behaviour unexpectedly, whereas currently it will be very obvious that your ResponseWriter doesn't support Flusher, because your application crashed. Before we merge this I would ask that you test this in your environments and confirm that it still works as expected. |
For me it solves the problem, but then again we were not expecting |
I would encourage you to try to get a |
|
Sounds like you could just contribute a |
Wait, are you talking about https://github.com/opentracing-contrib/go-stdlib/blob/master/nethttp/status-code-tracker.go? It supports flusher as far as I can tell. |
It only returns the types the original writer supports. I'm still a bit confused, the official docs suggest that this behaviour should be checked for. Would adding some logging help in this case? Or if the Flusher is required then that should be the enforced type to make it absolutely obvious that it is a requirement, although that doesn't seem to be the case either. |
No I agree, maybe the best thing would be for us to change the dependency to one that includes the Flusher. What do you think about that? |
That would definitely make the API more clear and prevent these runtime errors by providing some type safety. |
It would technically be a backwards compatibility breaking change but as you noticed, any existing users of the narrower interface will have had a bad time 😁. Would you be interested in contributing this fix? |
I'm actually still wondering if some kind of logging wouldn't solve the problem since Flush is not really needed for all scenarios. I could come around to do it but at the moment I kinda need to fix the issue of it not working for me so if someone wants to pick it up it's up for grabs :) |
Do we have a logger already, or do we use the grpclog library? I can't remember. I think if we really need this we can probably just log a warning when flush is called, as you say. |
@johanbrandhorst, @mangas what's the next step for this PR? |
I think @mangas has abandoned this effort, but given the real problem, I recommend we merge this anyway. We can make the suggested changes if any consumers are complaining about the changes. We should make a new "major" release though (0.x+1.0). |
Hey @johanbrandhorst, at the time I ended up sorting this by upgrading another library that took care of exposing the Flusher interfaces. Ended up forgetting to write an update. |
Unfortunately this caused #526, so I will have to back this out again. @jonnyreeves we probably have to prepare v0.10.1 with the revert in place. |
This reverts commit cf7d15a. This introduced a recursive call to `Flush` in the proxy, which will crash the application.
Hi @mangas, would you be interested in re-submitting this fix? Unfortunately the first one had a critical bug that wasn't discovered until a user ran into it 😱. It's our fault as much as yours so this is not an attempt to appoint blame. We'd still like to see this functionality as it was causing a problem for you originally. |
Hey |
The project is not abandoned, but I don't know if this has been fixed yet. Would you be willing to contribute a fix? |
https://github.com/improbable-eng/grpc-web/pull/817/files |
FIxes #480
Changes
Ensure the cast succeeds before calling method.
Verification
Behaviour is unchanged for the standard case