Browse Source

lib/api: Skip an IPv6 specific test inside Docker (fixes #5991) (#5992)

Isn't this just the most beautiful thing you've ever seen?
Jakob Borg 6 years ago
parent
commit
e945e65b13
1 changed files with 27 additions and 0 deletions
  1. 27 0
      lib/api/api_test.go

+ 27 - 0
lib/api/api_test.go

@@ -18,6 +18,7 @@ import (
 	"net/http/httptest"
 	"net/http/httptest"
 	"os"
 	"os"
 	"path/filepath"
 	"path/filepath"
+	"runtime"
 	"strconv"
 	"strconv"
 	"strings"
 	"strings"
 	"testing"
 	"testing"
@@ -826,6 +827,11 @@ func TestHostCheck(t *testing.T) {
 
 
 	// This should all work over IPv6 as well
 	// This should all work over IPv6 as well
 
 
+	if runningInContainer() {
+		// Working IPv6 in Docker can't be taken for granted.
+		return
+	}
+
 	cfg = new(mockedConfig)
 	cfg = new(mockedConfig)
 	cfg.gui.RawAddress = "[::1]:0"
 	cfg.gui.RawAddress = "[::1]:0"
 	baseURL, err = startHTTP(cfg)
 	baseURL, err = startHTTP(cfg)
@@ -1090,3 +1096,24 @@ func equalStrings(a, b []string) bool {
 	}
 	}
 	return true
 	return true
 }
 }
+
+// runningInContainer returns true if we are inside Docker or LXC. It might
+// be prone to false negatives if things change in the future, but likely
+// not false positives.
+func runningInContainer() bool {
+	if runtime.GOOS != "linux" {
+		return false
+	}
+
+	bs, err := ioutil.ReadFile("/proc/1/cgroup")
+	if err != nil {
+		return false
+	}
+	if bytes.Contains(bs, []byte("/docker/")) {
+		return true
+	}
+	if bytes.Contains(bs, []byte("/lxc/")) {
+		return true
+	}
+	return false
+}