Run ipvlan tests even if 'modprobe ipvlan' fails
This reverts commit a77e147d32
.
The ipvlan integration tests have been skipped in CI because of a check
intended to ensure the kernel has ipvlan support - which failed, but
seems to be unnecessary (probably because kernels have moved on).
Signed-off-by: Rob Murray <rob.murray@docker.com>
This commit is contained in:
parent
cd7240f6d9
commit
9954d7c6bd
1 changed files with 2 additions and 26 deletions
|
@ -5,10 +5,7 @@ package ipvlan // import "github.com/docker/docker/integration/network/ipvlan"
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
|
||||||
"os/exec"
|
|
||||||
"strings"
|
"strings"
|
||||||
"sync"
|
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/docker/docker/api/types"
|
"github.com/docker/docker/api/types"
|
||||||
|
@ -27,7 +24,7 @@ import (
|
||||||
func TestDockerNetworkIpvlanPersistance(t *testing.T) {
|
func TestDockerNetworkIpvlanPersistance(t *testing.T) {
|
||||||
// verify the driver automatically provisions the 802.1q link (di-dummy0.70)
|
// verify the driver automatically provisions the 802.1q link (di-dummy0.70)
|
||||||
skip.If(t, testEnv.IsRemoteDaemon)
|
skip.If(t, testEnv.IsRemoteDaemon)
|
||||||
skip.If(t, !ipvlanKernelSupport(t), "Kernel doesn't support ipvlan")
|
skip.If(t, testEnv.IsRootless, "rootless mode has different view of network")
|
||||||
|
|
||||||
ctx := testutil.StartSpan(baseContext, t)
|
ctx := testutil.StartSpan(baseContext, t)
|
||||||
|
|
||||||
|
@ -56,7 +53,7 @@ func TestDockerNetworkIpvlanPersistance(t *testing.T) {
|
||||||
|
|
||||||
func TestDockerNetworkIpvlan(t *testing.T) {
|
func TestDockerNetworkIpvlan(t *testing.T) {
|
||||||
skip.If(t, testEnv.IsRemoteDaemon)
|
skip.If(t, testEnv.IsRemoteDaemon)
|
||||||
skip.If(t, !ipvlanKernelSupport(t), "Kernel doesn't support ipvlan")
|
skip.If(t, testEnv.IsRootless, "rootless mode has different view of network")
|
||||||
|
|
||||||
ctx := testutil.StartSpan(baseContext, t)
|
ctx := testutil.StartSpan(baseContext, t)
|
||||||
|
|
||||||
|
@ -444,27 +441,6 @@ func testIpvlanL3Addressing(t *testing.T, ctx context.Context, client dclient.AP
|
||||||
assert.Check(t, is.Contains(result.Combined(), "default dev eth0"))
|
assert.Check(t, is.Contains(result.Combined(), "default dev eth0"))
|
||||||
}
|
}
|
||||||
|
|
||||||
var (
|
|
||||||
once sync.Once
|
|
||||||
ipvlanSupported bool
|
|
||||||
)
|
|
||||||
|
|
||||||
// figure out if ipvlan is supported by the kernel
|
|
||||||
func ipvlanKernelSupport(t *testing.T) bool {
|
|
||||||
once.Do(func() {
|
|
||||||
// this may have the side effect of enabling the ipvlan module
|
|
||||||
exec.Command("modprobe", "ipvlan").Run()
|
|
||||||
_, err := os.Stat("/sys/module/ipvlan")
|
|
||||||
if err == nil {
|
|
||||||
ipvlanSupported = true
|
|
||||||
} else if !os.IsNotExist(err) {
|
|
||||||
t.Logf("WARNING: ipvlanKernelSupport: stat failed: %v\n", err)
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
return ipvlanSupported
|
|
||||||
}
|
|
||||||
|
|
||||||
// TestIPVlanDNS checks whether DNS is forwarded, for combinations of l2/l3 mode,
|
// TestIPVlanDNS checks whether DNS is forwarded, for combinations of l2/l3 mode,
|
||||||
// with/without a parent interface, and with '--internal'. Note that, there's no
|
// with/without a parent interface, and with '--internal'. Note that, there's no
|
||||||
// attempt here to give the ipvlan network external connectivity - when this test
|
// attempt here to give the ipvlan network external connectivity - when this test
|
||||||
|
|
Loading…
Reference in a new issue