You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I am using hoverfly-java (0.14.0) with my Spring project in integration testing.
My actual service (under test/spy) calls are routed through envoy which relies on the Host: X header - where X specifies the service name.
For example, this is the original request:
I went through some debugging and couldn't see anywhere in goproxy or hoverfly that would remove the Host header, and then I found this in the golang HTTP doc:
// For incoming requests, the Host header is promoted to the
// Request.Host field and removed from the Header map.
It's surprising to see that's how the go HTTP package behaves. As hoverfly doesn't see the original Host header, it cannot reconstruct the original request with the Host header value you supply.
You can read more about the original Go issue on Github: golang/go#7682
A workaround is probably to use a custom host header for routing, however I'm not sure if your envoy proxy supports it.
Description of the bug
I am using hoverfly-java (0.14.0) with my Spring project in integration testing.
My actual service (under test/spy) calls are routed through envoy which relies on the
Host: X
header - whereX
specifies the service name.For example, this is the original request:
While using Hoverfly in SPY mode, it is proxying requests but replacing the
Host
header to finally have this request:This makes the underlying service unable to route requests.
Is it possible to specify custom header for Hoverfly to use internally for forwarding requests? Or can I explicitly re-set the header using a hack?
Steps to reproduce the issue
I can upload a sample project in the discussion below - however, the issue is easy to reproduce with SPY mode.
Observed result
404 Not Found due to wrong Host header
Expected result
200 OK
The text was updated successfully, but these errors were encountered: