mirror of
				https://github.com/traefik/traefik.git
				synced 2025-10-25 06:21:38 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			46 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package integration
 | |
| 
 | |
| import (
 | |
| 	"net/http"
 | |
| 	"os"
 | |
| 	"time"
 | |
| 
 | |
| 	"github.com/containous/traefik/integration/try"
 | |
| 	"github.com/go-check/check"
 | |
| 	checker "github.com/vdemeester/shakers"
 | |
| )
 | |
| 
 | |
| type TimeoutSuite struct{ BaseSuite }
 | |
| 
 | |
| func (s *TimeoutSuite) SetUpSuite(c *check.C) {
 | |
| 	s.createComposeProject(c, "timeout")
 | |
| 	s.composeProject.Start(c)
 | |
| }
 | |
| 
 | |
| func (s *TimeoutSuite) TestForwardingTimeouts(c *check.C) {
 | |
| 	httpTimeoutEndpoint := s.composeProject.Container(c, "timeoutEndpoint").NetworkSettings.IPAddress
 | |
| 	file := s.adaptFile(c, "fixtures/timeout/forwarding_timeouts.toml", struct {
 | |
| 		TimeoutEndpoint string
 | |
| 	}{httpTimeoutEndpoint})
 | |
| 	defer os.Remove(file)
 | |
| 
 | |
| 	cmd, display := s.traefikCmd(withConfigFile(file))
 | |
| 	defer display(c)
 | |
| 	err := cmd.Start()
 | |
| 	c.Assert(err, checker.IsNil)
 | |
| 	defer cmd.Process.Kill()
 | |
| 
 | |
| 	err = try.GetRequest("http://127.0.0.1:8080/api/providers", 60*time.Second, try.BodyContains("Path:/dialTimeout"))
 | |
| 	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)
 | |
| 
 | |
| 	// 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)
 | |
| }
 |