grpc-js: Preserve order of metadata, messages, and call end with async interceptors #1986
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
The code already existed to ensure that the status/halfClose comes after the last message when interceptors do async processing. This change extends that to ensure that metadata is processed before both of those.
I also added handling for a call trying to output a status before the
start
method is called. Now the status waits for that, instead of getting sent into the void.This fixes #1984 and #1985.