From 3e445855aaa006ee298222954964b45e8a3604fa Mon Sep 17 00:00:00 2001 From: apostasie Date: Fri, 5 Jul 2024 00:07:06 -0700 Subject: [PATCH] Fix/enhance IPFS tests Signed-off-by: apostasie --- cmd/nerdctl/container_create_linux_test.go | 4 +- cmd/nerdctl/ipfs_linux_test.go | 43 ++++++++++++++++++---- 2 files changed, 39 insertions(+), 8 deletions(-) diff --git a/cmd/nerdctl/container_create_linux_test.go b/cmd/nerdctl/container_create_linux_test.go index 871685e70a9..2a634299592 100644 --- a/cmd/nerdctl/container_create_linux_test.go +++ b/cmd/nerdctl/container_create_linux_test.go @@ -97,7 +97,9 @@ func TestCreateWithMACAddress(t *testing.T) { network := test.Network wantErr := test.WantErr t.Run(testName, func(tt *testing.T) { - tt.Parallel() + // FIXME IMPORTANT: it is painfully obvious that parallelization here is breaking this test very often + // Something seems to be racy wrt network creation, or container creation with custom network + // tt.Parallel() macAddress, err := nettestutil.GenerateMACAddress() if err != nil { diff --git a/cmd/nerdctl/ipfs_linux_test.go b/cmd/nerdctl/ipfs_linux_test.go index f86d7d92a97..9cf7ebe0579 100644 --- a/cmd/nerdctl/ipfs_linux_test.go +++ b/cmd/nerdctl/ipfs_linux_test.go @@ -20,10 +20,13 @@ import ( "fmt" "regexp" "testing" + "time" "github.com/containerd/nerdctl/v2/pkg/infoutil" "github.com/containerd/nerdctl/v2/pkg/rootlessutil" "github.com/containerd/nerdctl/v2/pkg/testutil" + "github.com/containerd/nerdctl/v2/pkg/testutil/nettestutil" + "github.com/containerd/nerdctl/v2/pkg/testutil/portlock" "gotest.tools/v3/assert" ) @@ -71,25 +74,51 @@ func TestIPFSAddress(t *testing.T) { } func runIPFSDaemonContainer(t *testing.T, base *testutil.Base) (ipfsAddress string, done func()) { - name := "test-ipfs-address" + port, err := portlock.Acquire(0) + assert.NilError(base.T, err, fmt.Errorf("failed acquiring port: %w", err)) + + name := "test-ipfs-address-" + testutil.Identifier(t) var ipfsaddr string + var addrTest string if detachedNetNS, _ := rootlessutil.DetachedNetNS(); detachedNetNS != "" { // detached-netns mode can't use .NetworkSettings.IPAddress, because the daemon and CNI has different network namespaces - base.Cmd("run", "-d", "-p", "127.0.0.1:5999:5999", "--name", name, "--entrypoint=/bin/sh", testutil.KuboImage, "-c", "ipfs init && ipfs config Addresses.API /ip4/0.0.0.0/tcp/5999 && ipfs daemon --offline").AssertOK() - ipfsaddr = "/ip4/127.0.0.1/tcp/5999" + base.Cmd("run", "-d", "-p", fmt.Sprintf("127.0.0.1:%d:%d", port, port), "--name", name, "--entrypoint=/bin/sh", testutil.KuboImage, "-c", fmt.Sprintf("ipfs init && ipfs config Addresses.API /ip4/0.0.0.0/tcp/%d && ipfs daemon --offline", port)).AssertOK() + ipfsaddr = fmt.Sprintf("/ip4/127.0.0.1/tcp/%d", port) + addrTest = fmt.Sprintf("127.0.0.1:%d", port) } else { - base.Cmd("run", "-d", "--name", name, "--entrypoint=/bin/sh", testutil.KuboImage, "-c", "ipfs init && ipfs config Addresses.API /ip4/0.0.0.0/tcp/5001 && ipfs daemon --offline").AssertOK() + base.Cmd("run", "-d", "--name", name, "--entrypoint=/bin/sh", testutil.KuboImage, "-c", fmt.Sprintf("ipfs init && ipfs config Addresses.API /ip4/0.0.0.0/tcp/%d && ipfs daemon --offline", port)).AssertOK() iplines := base.Cmd("inspect", name, "-f", "'{{json .NetworkSettings.IPAddress}}'").OutLines() t.Logf("IPAddress=%v", iplines) assert.Equal(t, len(iplines), 2) matches := iplineRegexp.FindStringSubmatch(iplines[0]) t.Logf("ip address matches=%v", matches) assert.Equal(t, len(matches), 2) - ipfsaddr = fmt.Sprintf("/ip4/%s/tcp/5001", matches[1]) + ipfsaddr = fmt.Sprintf("/ip4/%s/tcp/%d", matches[1], port) + addrTest = matches[1] + fmt.Sprintf(":%d", port) + } + + _, err = nettestutil.HTTPGet(fmt.Sprintf("http://%s/api/v0", addrTest), 30, true) + // Not there... give it more time... + if err != nil { + time.Sleep(1 * time.Second) + _, err = nettestutil.HTTPGet(fmt.Sprintf("http://%s/api/v0", addrTest), 30, true) } + if err != nil { + fmt.Println("Something is wrong with ipfs communication") + res := base.Cmd("inspect", name).Run() + fmt.Println(res) + res = base.Cmd("logs", name).Run() + fmt.Println(res) + } + assert.NilError(t, err) + return ipfsaddr, func() { - base.Cmd("kill", "test-ipfs-address").AssertOK() - base.Cmd("rm", "test-ipfs-address").AssertOK() + base.Cmd("kill", name).AssertOK() + base.Cmd("rm", name).AssertOK() + err = portlock.Release(port) + if err != nil { + t.Errorf("failed to release ipfs port %d: %v", port, err) + } } }