Comments (2)
Hey Azuka, thanks for raising the issue.
When you call done
with a Readable
, I expect fastify to set this value as the body
property on the fastify request object. If I follow correctly, the Readable
is passed as a parsedJsonBody: JsonValue
to universalRequestFromNodeRequest()
here.
I think to properly support this, we have to update the signature of universalRequestFromNodeRequest
to explicitly handle this input, so that tests can be added.
I am not sure that we can modify the noop-parser without breaking other use cases. Adding good test coverage is not trivial, unfortunately. Maybe the best solution would be to allow you to bring your own content-type parser for firebase (in combination with updating the function signature).
We are currently switching our tests to https://github.com/connectrpc/conformance. This will possibly give us better options to add test coverage. For now, vendoring the plugin in your project seems like a good workaround.
from connect-es.
Thanks @timostamm.
I hadn't used fastify outside of firebase, but I agree about not breaking it for others without thorough tests.
I did go looking in the conformance repo before opening an issue (because I didn't see tests here), but glad to hear that there are plans to cover more use cases there.
from connect-es.
Related Issues (20)
- Content-Type and other HTTP headers missing with gRPC requests when launching in Cypress E2E Test HOT 1
- Remove "node" export condition
- Requests appear aborted before handler over HTTP/1.1 HOT 1
- Support alternate protobuf "runtimes"
- Support override of SSL target name HOT 2
- js_import_style=commonjs still generates 'export const MyService' instead of `exports.MyService` HOT 1
- Grpc-web lose connection after 60s for server-streaming calls HOT 1
- Generated service not showing up as type `ServiceType` HOT 3
- [Angular] Example using multiple endpoints HOT 1
- Incorrect typing of Struct.toJson() HOT 1
- Connect serialization should gracefully handle null values HOT 2
- Adding response headers to error responses in interceptor
- Allow keeping original method names HOT 2
- Root interceptors are overwritten when service interceptors are also defined HOT 1
- Conformance cleanup backlog
- use ConnectRPC Protobuf with React server actions HOT 9
- Client middleware that adds automatic retries to unary calls with timeouts between retry attempts. HOT 3
- Otel support just like otelconnect-go does HOT 10
- Request-scoped logging HOT 3
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from connect-es.