2017-07-06 14:28:13 +00:00
|
|
|
package integration
|
2015-09-27 13:59:51 +00:00
|
|
|
|
|
|
|
import (
|
2015-11-05 14:14:25 +00:00
|
|
|
"encoding/json"
|
|
|
|
"fmt"
|
2021-03-04 19:08:03 +00:00
|
|
|
"io"
|
2015-09-27 13:59:51 +00:00
|
|
|
"net/http"
|
2015-09-28 20:37:19 +00:00
|
|
|
"os"
|
2015-09-27 13:59:51 +00:00
|
|
|
"time"
|
|
|
|
|
2016-04-02 10:40:21 +00:00
|
|
|
"github.com/go-check/check"
|
2023-02-03 14:24:05 +00:00
|
|
|
"github.com/traefik/traefik/v3/integration/try"
|
2015-09-27 13:59:51 +00:00
|
|
|
checker "github.com/vdemeester/shakers"
|
|
|
|
)
|
|
|
|
|
2020-05-11 10:06:07 +00:00
|
|
|
// Docker tests suite.
|
2015-11-05 14:14:25 +00:00
|
|
|
type DockerSuite struct {
|
|
|
|
BaseSuite
|
2017-11-28 12:58:04 +00:00
|
|
|
}
|
|
|
|
|
2021-11-25 10:10:06 +00:00
|
|
|
func (s *DockerSuite) SetUpTest(c *check.C) {
|
|
|
|
s.createComposeProject(c, "docker")
|
2015-11-05 14:14:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *DockerSuite) TearDownTest(c *check.C) {
|
2021-11-25 10:10:06 +00:00
|
|
|
s.composeDown(c)
|
2015-11-05 14:14:25 +00:00
|
|
|
}
|
|
|
|
|
2015-09-27 13:59:51 +00:00
|
|
|
func (s *DockerSuite) TestSimpleConfiguration(c *check.C) {
|
2019-01-21 18:06:02 +00:00
|
|
|
tempObjects := struct {
|
|
|
|
DockerHost string
|
|
|
|
DefaultRule string
|
|
|
|
}{
|
|
|
|
DockerHost: s.getDockerHost(),
|
2019-01-30 15:24:07 +00:00
|
|
|
DefaultRule: "Host(`{{ normalize .Name }}.docker.localhost`)",
|
2019-01-21 18:06:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
file := s.adaptFile(c, "fixtures/docker/simple.toml", tempObjects)
|
2015-09-28 20:37:19 +00:00
|
|
|
defer os.Remove(file)
|
|
|
|
|
2021-11-25 10:10:06 +00:00
|
|
|
s.composeUp(c)
|
|
|
|
|
2017-09-13 08:34:04 +00:00
|
|
|
cmd, display := s.traefikCmd(withConfigFile(file))
|
|
|
|
defer display(c)
|
2021-11-25 10:10:06 +00:00
|
|
|
|
2015-09-27 13:59:51 +00:00
|
|
|
err := cmd.Start()
|
|
|
|
c.Assert(err, checker.IsNil)
|
2020-10-09 07:32:03 +00:00
|
|
|
defer s.killCmd(cmd)
|
2015-09-27 13:59:51 +00:00
|
|
|
|
2018-04-16 16:14:04 +00:00
|
|
|
// Expected a 404 as we did not configure anything
|
2017-11-20 08:40:03 +00:00
|
|
|
err = try.GetRequest("http://127.0.0.1:8000/", 500*time.Millisecond, try.StatusCodeIs(http.StatusNotFound))
|
2017-05-17 13:22:44 +00:00
|
|
|
c.Assert(err, checker.IsNil)
|
2015-11-05 14:14:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (s *DockerSuite) TestDefaultDockerContainers(c *check.C) {
|
2019-01-21 18:06:02 +00:00
|
|
|
tempObjects := struct {
|
|
|
|
DockerHost string
|
|
|
|
DefaultRule string
|
|
|
|
}{
|
|
|
|
DockerHost: s.getDockerHost(),
|
2019-01-30 15:24:07 +00:00
|
|
|
DefaultRule: "Host(`{{ normalize .Name }}.docker.localhost`)",
|
2019-01-21 18:06:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
file := s.adaptFile(c, "fixtures/docker/simple.toml", tempObjects)
|
2015-11-05 14:14:25 +00:00
|
|
|
defer os.Remove(file)
|
2019-01-18 14:18:04 +00:00
|
|
|
|
2021-11-25 10:10:06 +00:00
|
|
|
s.composeUp(c, "simple")
|
2015-11-05 14:14:25 +00:00
|
|
|
|
|
|
|
// Start traefik
|
2017-09-13 08:34:04 +00:00
|
|
|
cmd, display := s.traefikCmd(withConfigFile(file))
|
|
|
|
defer display(c)
|
2021-11-25 10:10:06 +00:00
|
|
|
|
2015-11-05 14:14:25 +00:00
|
|
|
err := cmd.Start()
|
|
|
|
c.Assert(err, checker.IsNil)
|
2020-10-09 07:32:03 +00:00
|
|
|
defer s.killCmd(cmd)
|
2015-11-05 14:14:25 +00:00
|
|
|
|
2017-05-17 13:22:44 +00:00
|
|
|
req, err := http.NewRequest(http.MethodGet, "http://127.0.0.1:8000/version", nil)
|
2015-11-05 14:14:25 +00:00
|
|
|
c.Assert(err, checker.IsNil)
|
2021-11-25 10:10:06 +00:00
|
|
|
req.Host = fmt.Sprintf("simple-%s.docker.localhost", s.composeProject.Name)
|
2015-11-05 14:14:25 +00:00
|
|
|
|
2022-08-31 06:24:08 +00:00
|
|
|
// TODO Need to wait than 500 milliseconds more (for swarm or traefik to boot up ?)
|
2017-11-20 08:40:03 +00:00
|
|
|
resp, err := try.ResponseUntilStatusCode(req, 1500*time.Millisecond, http.StatusOK)
|
2015-11-05 14:14:25 +00:00
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
|
2021-03-04 19:08:03 +00:00
|
|
|
body, err := io.ReadAll(resp.Body)
|
2015-11-05 14:14:25 +00:00
|
|
|
c.Assert(err, checker.IsNil)
|
2015-09-27 13:59:51 +00:00
|
|
|
|
2015-11-05 14:14:25 +00:00
|
|
|
var version map[string]interface{}
|
|
|
|
|
|
|
|
c.Assert(json.Unmarshal(body, &version), checker.IsNil)
|
|
|
|
c.Assert(version["Version"], checker.Equals, "swarm/1.0.0")
|
|
|
|
}
|
|
|
|
|
2019-03-21 14:22:06 +00:00
|
|
|
func (s *DockerSuite) TestDockerContainersWithTCPLabels(c *check.C) {
|
|
|
|
tempObjects := struct {
|
|
|
|
DockerHost string
|
|
|
|
DefaultRule string
|
|
|
|
}{
|
|
|
|
DockerHost: s.getDockerHost(),
|
|
|
|
DefaultRule: "Host(`{{ normalize .Name }}.docker.localhost`)",
|
|
|
|
}
|
|
|
|
|
|
|
|
file := s.adaptFile(c, "fixtures/docker/simple.toml", tempObjects)
|
|
|
|
defer os.Remove(file)
|
|
|
|
|
2021-11-25 10:10:06 +00:00
|
|
|
s.composeUp(c, "withtcplabels")
|
2019-03-21 14:22:06 +00:00
|
|
|
|
|
|
|
// Start traefik
|
|
|
|
cmd, display := s.traefikCmd(withConfigFile(file))
|
|
|
|
defer display(c)
|
2021-11-25 10:10:06 +00:00
|
|
|
|
2019-03-21 14:22:06 +00:00
|
|
|
err := cmd.Start()
|
|
|
|
c.Assert(err, checker.IsNil)
|
2020-10-09 07:32:03 +00:00
|
|
|
defer s.killCmd(cmd)
|
2019-03-21 14:22:06 +00:00
|
|
|
|
|
|
|
err = try.GetRequest("http://127.0.0.1:8080/api/rawdata", 500*time.Millisecond, try.StatusCodeIs(http.StatusOK), try.BodyContains("HostSNI(`my.super.host`)"))
|
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
|
|
|
|
who, err := guessWho("127.0.0.1:8000", "my.super.host", true)
|
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
|
|
|
|
c.Assert(who, checker.Contains, "my.super.host")
|
|
|
|
}
|
|
|
|
|
2015-11-05 14:14:25 +00:00
|
|
|
func (s *DockerSuite) TestDockerContainersWithLabels(c *check.C) {
|
2019-01-21 18:06:02 +00:00
|
|
|
tempObjects := struct {
|
|
|
|
DockerHost string
|
|
|
|
DefaultRule string
|
|
|
|
}{
|
|
|
|
DockerHost: s.getDockerHost(),
|
2019-01-30 15:24:07 +00:00
|
|
|
DefaultRule: "Host(`{{ normalize .Name }}.docker.localhost`)",
|
2019-01-21 18:06:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
file := s.adaptFile(c, "fixtures/docker/simple.toml", tempObjects)
|
2015-11-05 14:14:25 +00:00
|
|
|
defer os.Remove(file)
|
2019-01-18 14:18:04 +00:00
|
|
|
|
2021-11-25 10:10:06 +00:00
|
|
|
s.composeUp(c, "withlabels1", "withlabels2")
|
2019-01-18 14:18:04 +00:00
|
|
|
|
2015-11-05 14:14:25 +00:00
|
|
|
// Start traefik
|
2017-09-13 08:34:04 +00:00
|
|
|
cmd, display := s.traefikCmd(withConfigFile(file))
|
|
|
|
defer display(c)
|
2015-11-05 14:14:25 +00:00
|
|
|
err := cmd.Start()
|
|
|
|
c.Assert(err, checker.IsNil)
|
2020-10-09 07:32:03 +00:00
|
|
|
defer s.killCmd(cmd)
|
2015-11-05 14:14:25 +00:00
|
|
|
|
2017-05-17 13:22:44 +00:00
|
|
|
req, err := http.NewRequest(http.MethodGet, "http://127.0.0.1:8000/version", nil)
|
2015-11-05 14:14:25 +00:00
|
|
|
c.Assert(err, checker.IsNil)
|
2017-10-30 11:06:03 +00:00
|
|
|
req.Host = "my-super.host"
|
2015-11-05 14:14:25 +00:00
|
|
|
|
2022-08-31 06:24:08 +00:00
|
|
|
// TODO Need to wait than 500 milliseconds more (for swarm or traefik to boot up ?)
|
2017-12-02 18:26:44 +00:00
|
|
|
_, err = try.ResponseUntilStatusCode(req, 1500*time.Millisecond, http.StatusOK)
|
2015-11-05 14:14:25 +00:00
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
|
2017-10-30 11:06:03 +00:00
|
|
|
req, err = http.NewRequest(http.MethodGet, "http://127.0.0.1:8000/version", nil)
|
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
req.Host = "my.super.host"
|
|
|
|
|
2022-08-31 06:24:08 +00:00
|
|
|
// TODO Need to wait than 500 milliseconds more (for swarm or traefik to boot up ?)
|
2017-12-02 18:26:44 +00:00
|
|
|
resp, err := try.ResponseUntilStatusCode(req, 1500*time.Millisecond, http.StatusOK)
|
2017-10-30 11:06:03 +00:00
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
|
2021-03-04 19:08:03 +00:00
|
|
|
body, err := io.ReadAll(resp.Body)
|
2015-11-05 14:14:25 +00:00
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
|
|
|
|
var version map[string]interface{}
|
|
|
|
|
|
|
|
c.Assert(json.Unmarshal(body, &version), checker.IsNil)
|
|
|
|
c.Assert(version["Version"], checker.Equals, "swarm/1.0.0")
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *DockerSuite) TestDockerContainersWithOneMissingLabels(c *check.C) {
|
2019-01-21 18:06:02 +00:00
|
|
|
tempObjects := struct {
|
|
|
|
DockerHost string
|
|
|
|
DefaultRule string
|
|
|
|
}{
|
|
|
|
DockerHost: s.getDockerHost(),
|
2019-01-30 15:24:07 +00:00
|
|
|
DefaultRule: "Host(`{{ normalize .Name }}.docker.localhost`)",
|
2019-01-21 18:06:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
file := s.adaptFile(c, "fixtures/docker/simple.toml", tempObjects)
|
2015-11-05 14:14:25 +00:00
|
|
|
defer os.Remove(file)
|
2019-01-18 14:18:04 +00:00
|
|
|
|
2021-11-25 10:10:06 +00:00
|
|
|
s.composeUp(c, "withonelabelmissing")
|
2015-11-05 14:14:25 +00:00
|
|
|
|
|
|
|
// Start traefik
|
2017-09-13 08:34:04 +00:00
|
|
|
cmd, display := s.traefikCmd(withConfigFile(file))
|
|
|
|
defer display(c)
|
2021-11-25 10:10:06 +00:00
|
|
|
|
2015-11-05 14:14:25 +00:00
|
|
|
err := cmd.Start()
|
|
|
|
c.Assert(err, checker.IsNil)
|
2020-10-09 07:32:03 +00:00
|
|
|
defer s.killCmd(cmd)
|
2015-11-05 14:14:25 +00:00
|
|
|
|
2017-05-17 13:22:44 +00:00
|
|
|
req, err := http.NewRequest(http.MethodGet, "http://127.0.0.1:8000/version", nil)
|
2015-11-05 14:14:25 +00:00
|
|
|
c.Assert(err, checker.IsNil)
|
2017-05-17 13:22:44 +00:00
|
|
|
req.Host = "my.super.host"
|
2015-11-05 14:14:25 +00:00
|
|
|
|
2022-08-31 06:24:08 +00:00
|
|
|
// TODO Need to wait than 500 milliseconds more (for swarm or traefik to boot up ?)
|
2017-05-17 13:22:44 +00:00
|
|
|
// TODO validate : run on 80
|
2019-01-21 18:06:02 +00:00
|
|
|
// Expected a 404 as we did not configure anything
|
2017-05-17 13:22:44 +00:00
|
|
|
err = try.Request(req, 1500*time.Millisecond, try.StatusCodeIs(http.StatusNotFound))
|
2015-11-05 14:14:25 +00:00
|
|
|
c.Assert(err, checker.IsNil)
|
2015-09-27 13:59:51 +00:00
|
|
|
}
|
2017-10-30 14:10:05 +00:00
|
|
|
|
2017-11-28 12:58:04 +00:00
|
|
|
func (s *DockerSuite) TestRestartDockerContainers(c *check.C) {
|
2019-01-21 18:06:02 +00:00
|
|
|
tempObjects := struct {
|
|
|
|
DockerHost string
|
|
|
|
DefaultRule string
|
|
|
|
}{
|
|
|
|
DockerHost: s.getDockerHost(),
|
2019-01-30 15:24:07 +00:00
|
|
|
DefaultRule: "Host(`{{ normalize .Name }}.docker.localhost`)",
|
2019-01-21 18:06:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
file := s.adaptFile(c, "fixtures/docker/simple.toml", tempObjects)
|
2017-11-28 12:58:04 +00:00
|
|
|
defer os.Remove(file)
|
2019-01-18 14:18:04 +00:00
|
|
|
|
2021-11-25 10:10:06 +00:00
|
|
|
s.composeUp(c, "powpow")
|
2017-11-28 12:58:04 +00:00
|
|
|
|
|
|
|
// Start traefik
|
|
|
|
cmd, display := s.traefikCmd(withConfigFile(file))
|
|
|
|
defer display(c)
|
2021-11-25 10:10:06 +00:00
|
|
|
|
2017-11-28 12:58:04 +00:00
|
|
|
err := cmd.Start()
|
|
|
|
c.Assert(err, checker.IsNil)
|
2020-10-09 07:32:03 +00:00
|
|
|
defer s.killCmd(cmd)
|
2017-11-28 12:58:04 +00:00
|
|
|
|
|
|
|
req, err := http.NewRequest(http.MethodGet, "http://127.0.0.1:8000/version", nil)
|
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
req.Host = "my.super.host"
|
|
|
|
|
2022-08-31 06:24:08 +00:00
|
|
|
// TODO Need to wait than 500 milliseconds more (for swarm or traefik to boot up ?)
|
2017-11-28 12:58:04 +00:00
|
|
|
resp, err := try.ResponseUntilStatusCode(req, 1500*time.Millisecond, http.StatusOK)
|
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
|
2021-03-04 19:08:03 +00:00
|
|
|
body, err := io.ReadAll(resp.Body)
|
2017-11-28 12:58:04 +00:00
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
|
|
|
|
var version map[string]interface{}
|
|
|
|
|
|
|
|
c.Assert(json.Unmarshal(body, &version), checker.IsNil)
|
|
|
|
c.Assert(version["Version"], checker.Equals, "swarm/1.0.0")
|
|
|
|
|
2019-05-16 08:58:06 +00:00
|
|
|
err = try.GetRequest("http://127.0.0.1:8080/api/rawdata", 60*time.Second, try.BodyContains("powpow"))
|
2017-11-28 12:58:04 +00:00
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
|
2021-11-25 10:10:06 +00:00
|
|
|
s.composeStop(c, "powpow")
|
2017-11-28 12:58:04 +00:00
|
|
|
|
|
|
|
time.Sleep(5 * time.Second)
|
|
|
|
|
2019-05-16 08:58:06 +00:00
|
|
|
err = try.GetRequest("http://127.0.0.1:8080/api/rawdata", 10*time.Second, try.BodyContains("powpow"))
|
2017-11-28 12:58:04 +00:00
|
|
|
c.Assert(err, checker.NotNil)
|
|
|
|
|
2021-11-25 10:10:06 +00:00
|
|
|
s.composeUp(c, "powpow")
|
2019-05-16 08:58:06 +00:00
|
|
|
err = try.GetRequest("http://127.0.0.1:8080/api/rawdata", 60*time.Second, try.BodyContains("powpow"))
|
2017-11-28 12:58:04 +00:00
|
|
|
c.Assert(err, checker.IsNil)
|
|
|
|
}
|