From 55cfb0a8d2a2ce0985728216e94bbc2527bb669c Mon Sep 17 00:00:00 2001 From: Neil Jerram Date: Mon, 14 Oct 2019 14:08:59 +0100 Subject: [PATCH] Fix loopback IP to work when there's only one plane --- pkg/internal/cluster/providers/docker/node.go | 28 ++++++++++++------- 1 file changed, 18 insertions(+), 10 deletions(-) diff --git a/pkg/internal/cluster/providers/docker/node.go b/pkg/internal/cluster/providers/docker/node.go index f12ff01230..ae3b234102 100644 --- a/pkg/internal/cluster/providers/docker/node.go +++ b/pkg/internal/cluster/providers/docker/node.go @@ -93,19 +93,27 @@ func (n *node) IP() (ipv4 string, ipv6 string, err error) { if len(lines) != 1 { return "", "", errors.Errorf("file should only be one line, got %d lines", len(lines)) } + // If the node has a loopback address, that provides the IPv4. + loopAddr, err := n.Loopback() + if err == nil && loopAddr != "" { + fmt.Printf("%v: use IPv4 loopback address %v\n", n.name, loopAddr) + ipv4 = loopAddr + } ips := strings.Split(lines[0], ",") - if len(ips) != 2 { - //return "", "", errors.Errorf("container addresses should have 2 values, got %d values", len(ips)) - fmt.Printf("%v: %#v\n", n.name, ips) - // If the node has a loopback address, that overrides the IPv4 one. - loopAddr, err := n.Loopback() - if err == nil && loopAddr != "" { - fmt.Printf("%v: use IPv4 loopback address %v\n", n.name, loopAddr) - return loopAddr, ips[1], nil + for _, ip := range ips { + if strings.Contains(ip, ":") { + // IPv6. + if ipv6 == "" { + ipv6 = ip + } + } else { + // IPv4 + if ipv4 == "" { + ipv4 = ip + } } - return ips[0], "", nil } - return ips[0], ips[1], nil + return } func (n *node) Command(command string, args ...string) exec.Cmd {