2017-08-18 13:34:04 +00:00
|
|
|
package integration
|
|
|
|
|
|
|
|
import (
|
2019-01-16 14:00:09 +00:00
|
|
|
"fmt"
|
2022-05-17 13:48:08 +00:00
|
|
|
"net"
|
2017-08-18 13:34:04 +00:00
|
|
|
"net/http"
|
|
|
|
"os"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/go-check/check"
|
2023-02-03 14:24:05 +00:00
|
|
|
"github.com/traefik/traefik/v3/integration/try"
|
2017-08-18 13:34:04 +00:00
|
|
|
checker "github.com/vdemeester/shakers"
|
|
|
|
)
|
|
|
|
|
|
|
|
type TimeoutSuite struct{ BaseSuite }
|
|
|
|
|
|
|
|
func (s *TimeoutSuite) SetUpSuite(c *check.C) {
|
|
|
|
s.createComposeProject(c, "timeout")
|
2021-11-25 10:10:06 +00:00
|
|
|
s.composeUp(c)
|
2017-08-18 13:34:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *TimeoutSuite) TestForwardingTimeouts(c *check.C) {
|
2021-11-25 10:10:06 +00:00
|
|
|
timeoutEndpointIP := s.getComposeServiceIP(c, "timeoutEndpoint")
|
|
|
|
file := s.adaptFile(c, "fixtures/timeout/forwarding_timeouts.toml", struct{ TimeoutEndpoint string }{timeoutEndpointIP})
|
2017-08-18 13:34:04 +00:00
|
|
|
defer os.Remove(file)
|
|
|
|
|
2017-09-13 08:34:04 +00:00
|
|
|
cmd, display := s.traefikCmd(withConfigFile(file))
|
|
|
|
defer display(c)
|
2017-08-18 13:34:04 +00:00
|
|
|
err := cmd.Start()
|
|
|
|
c.Assert(err, checker.IsNil)
|
2020-10-09 07:32:03 +00:00
|
|
|
defer s.killCmd(cmd)
|
2017-08-18 13:34:04 +00:00
|
|
|
|
2019-05-16 08:58:06 +00:00
|
|
|
err = try.GetRequest("http://127.0.0.1:8080/api/rawdata", 60*time.Second, try.BodyContains("Path(`/dialTimeout`)"))
|
2017-08-18 13:34:04 +00:00
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
|
|
|
|
// This simulates a DialTimeout when connecting to the backend server.
|
|
|
|
response, err := http.Get("http://127.0.0.1:8000/dialTimeout")
|
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
c.Assert(response.StatusCode, checker.Equals, http.StatusGatewayTimeout)
|
|
|
|
|
2019-01-16 14:00:09 +00:00
|
|
|
// Check that timeout service is available
|
2022-05-17 13:48:08 +00:00
|
|
|
statusURL := fmt.Sprintf("http://%s/statusTest?status=200",
|
|
|
|
net.JoinHostPort(timeoutEndpointIP, "9000"))
|
2019-01-16 14:00:09 +00:00
|
|
|
c.Assert(try.GetRequest(statusURL, 60*time.Second, try.StatusCodeIs(http.StatusOK)), checker.IsNil)
|
|
|
|
|
2017-08-18 13:34:04 +00:00
|
|
|
// This simulates a ResponseHeaderTimeout.
|
|
|
|
response, err = http.Get("http://127.0.0.1:8000/responseHeaderTimeout?sleep=1000")
|
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
c.Assert(response.StatusCode, checker.Equals, http.StatusGatewayTimeout)
|
|
|
|
}
|