fix missing trailers with retry
This commit is contained in:
parent
06905cb14a
commit
db13dbdf46
4 changed files with 86 additions and 0 deletions
34
integration/fixtures/grpc/config_retry.toml
Normal file
34
integration/fixtures/grpc/config_retry.toml
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
[serversTransport]
|
||||||
|
rootCAs = [ """{{ .CertContent }}""" ]
|
||||||
|
|
||||||
|
[entryPoints]
|
||||||
|
[entryPoints.https]
|
||||||
|
address = ":4443"
|
||||||
|
[entryPoints.https.tls]
|
||||||
|
[entryPoints.https.tls.DefaultCertificate]
|
||||||
|
certFile = """{{ .CertContent }}"""
|
||||||
|
keyFile = """{{ .KeyContent }}"""
|
||||||
|
|
||||||
|
|
||||||
|
[api]
|
||||||
|
|
||||||
|
[providers]
|
||||||
|
[providers.file]
|
||||||
|
|
||||||
|
[routers]
|
||||||
|
[routers.router1]
|
||||||
|
rule = "Host(`127.0.0.1`)"
|
||||||
|
service = "service1"
|
||||||
|
middlewares = ["retryer"]
|
||||||
|
|
||||||
|
[middlewares]
|
||||||
|
[middlewares.retryer.retry]
|
||||||
|
Attempts = 2
|
||||||
|
|
||||||
|
[services]
|
||||||
|
[services.service1.loadbalancer]
|
||||||
|
[services.service1.loadbalancer.responseForwarding]
|
||||||
|
flushInterval="1ms"
|
||||||
|
[[services.service1.loadbalancer.servers]]
|
||||||
|
url = "https://127.0.0.1:{{ .GRPCServerPort }}"
|
||||||
|
weight = 1
|
|
@ -423,3 +423,45 @@ func (s *GRPCSuite) TestGRPCBufferWithFlushInterval(c *check.C) {
|
||||||
})
|
})
|
||||||
c.Assert(err, check.IsNil)
|
c.Assert(err, check.IsNil)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s *GRPCSuite) TestGRPCWithRetry(c *check.C) {
|
||||||
|
lis, err := net.Listen("tcp", ":0")
|
||||||
|
_, port, err := net.SplitHostPort(lis.Addr().String())
|
||||||
|
c.Assert(err, check.IsNil)
|
||||||
|
|
||||||
|
go func() {
|
||||||
|
err := startGRPCServer(lis, &myserver{})
|
||||||
|
c.Log(err)
|
||||||
|
c.Assert(err, check.IsNil)
|
||||||
|
}()
|
||||||
|
|
||||||
|
file := s.adaptFile(c, "fixtures/grpc/config_retry.toml", struct {
|
||||||
|
CertContent string
|
||||||
|
KeyContent string
|
||||||
|
GRPCServerPort string
|
||||||
|
}{
|
||||||
|
CertContent: string(LocalhostCert),
|
||||||
|
KeyContent: string(LocalhostKey),
|
||||||
|
GRPCServerPort: port,
|
||||||
|
})
|
||||||
|
|
||||||
|
defer os.Remove(file)
|
||||||
|
cmd, display := s.traefikCmd(withConfigFile(file))
|
||||||
|
defer display(c)
|
||||||
|
|
||||||
|
err = cmd.Start()
|
||||||
|
c.Assert(err, check.IsNil)
|
||||||
|
defer cmd.Process.Kill()
|
||||||
|
|
||||||
|
// wait for Traefik
|
||||||
|
err = try.GetRequest("http://127.0.0.1:8080/api/providers/file/routers", 1*time.Second, try.BodyContains("Host(`127.0.0.1`)"))
|
||||||
|
c.Assert(err, check.IsNil)
|
||||||
|
|
||||||
|
var response string
|
||||||
|
err = try.Do(1*time.Second, func() error {
|
||||||
|
response, err = callHelloClientGRPC("World", true)
|
||||||
|
return err
|
||||||
|
})
|
||||||
|
c.Assert(err, check.IsNil)
|
||||||
|
c.Assert(response, check.Equals, "Hello World")
|
||||||
|
}
|
||||||
|
|
|
@ -132,6 +132,7 @@ type responseWriterWithoutCloseNotify struct {
|
||||||
responseWriter http.ResponseWriter
|
responseWriter http.ResponseWriter
|
||||||
headers http.Header
|
headers http.Header
|
||||||
shouldRetry bool
|
shouldRetry bool
|
||||||
|
written bool
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *responseWriterWithoutCloseNotify) ShouldRetry() bool {
|
func (r *responseWriterWithoutCloseNotify) ShouldRetry() bool {
|
||||||
|
@ -143,6 +144,9 @@ func (r *responseWriterWithoutCloseNotify) DisableRetries() {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *responseWriterWithoutCloseNotify) Header() http.Header {
|
func (r *responseWriterWithoutCloseNotify) Header() http.Header {
|
||||||
|
if r.written {
|
||||||
|
return r.responseWriter.Header()
|
||||||
|
}
|
||||||
return r.headers
|
return r.headers
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -177,6 +181,7 @@ func (r *responseWriterWithoutCloseNotify) WriteHeader(code int) {
|
||||||
}
|
}
|
||||||
|
|
||||||
r.responseWriter.WriteHeader(code)
|
r.responseWriter.WriteHeader(code)
|
||||||
|
r.written = true
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *responseWriterWithoutCloseNotify) Hijack() (net.Conn, *bufio.ReadWriter, error) {
|
func (r *responseWriterWithoutCloseNotify) Hijack() (net.Conn, *bufio.ReadWriter, error) {
|
||||||
|
|
|
@ -110,6 +110,7 @@ type retryResponseWriterWithoutCloseNotify struct {
|
||||||
responseWriter http.ResponseWriter
|
responseWriter http.ResponseWriter
|
||||||
headers http.Header
|
headers http.Header
|
||||||
shouldRetry bool
|
shouldRetry bool
|
||||||
|
written bool
|
||||||
}
|
}
|
||||||
|
|
||||||
func (rr *retryResponseWriterWithoutCloseNotify) ShouldRetry() bool {
|
func (rr *retryResponseWriterWithoutCloseNotify) ShouldRetry() bool {
|
||||||
|
@ -121,6 +122,9 @@ func (rr *retryResponseWriterWithoutCloseNotify) DisableRetries() {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (rr *retryResponseWriterWithoutCloseNotify) Header() http.Header {
|
func (rr *retryResponseWriterWithoutCloseNotify) Header() http.Header {
|
||||||
|
if rr.written {
|
||||||
|
return rr.responseWriter.Header()
|
||||||
|
}
|
||||||
return rr.headers
|
return rr.headers
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -155,6 +159,7 @@ func (rr *retryResponseWriterWithoutCloseNotify) WriteHeader(code int) {
|
||||||
}
|
}
|
||||||
|
|
||||||
rr.responseWriter.WriteHeader(code)
|
rr.responseWriter.WriteHeader(code)
|
||||||
|
rr.written = true
|
||||||
}
|
}
|
||||||
|
|
||||||
func (rr *retryResponseWriterWithoutCloseNotify) Hijack() (net.Conn, *bufio.ReadWriter, error) {
|
func (rr *retryResponseWriterWithoutCloseNotify) Hijack() (net.Conn, *bufio.ReadWriter, error) {
|
||||||
|
|
Loading…
Reference in a new issue