From b39ebbf0095e171bb4278767ddc29ddd0af5bdaa Mon Sep 17 00:00:00 2001 From: Christian Schlotter Date: Thu, 11 Apr 2024 19:21:58 +0200 Subject: [PATCH] test: fix kubetest to allow parallel execution on different clusters --- test/e2e/cluster_upgrade.go | 1 + test/e2e/k8s_conformance.go | 1 + test/e2e/quick_start_test.go | 2 ++ test/framework/kubetest/run.go | 13 +++++++++++-- 4 files changed, 15 insertions(+), 2 deletions(-) diff --git a/test/e2e/cluster_upgrade.go b/test/e2e/cluster_upgrade.go index f5d67e62637f..0e649381de5b 100644 --- a/test/e2e/cluster_upgrade.go +++ b/test/e2e/cluster_upgrade.go @@ -256,6 +256,7 @@ func ClusterUpgradeConformanceSpec(ctx context.Context, inputGetter func() Clust ArtifactsDirectory: input.ArtifactFolder, ConfigFilePath: kubetestConfigFilePath, GinkgoNodes: int(clusterResources.ExpectedWorkerNodes()), + ClusterName: clusterResources.Cluster.GetName(), }, ) Expect(err).ToNot(HaveOccurred(), "Failed to run Kubernetes conformance") diff --git a/test/e2e/k8s_conformance.go b/test/e2e/k8s_conformance.go index 86c2422cce07..5b768ca6a57e 100644 --- a/test/e2e/k8s_conformance.go +++ b/test/e2e/k8s_conformance.go @@ -148,6 +148,7 @@ func K8SConformanceSpec(ctx context.Context, inputGetter func() K8SConformanceSp ArtifactsDirectory: input.ArtifactFolder, ConfigFilePath: kubetestConfigFilePath, GinkgoNodes: ginkgoNodes, + ClusterName: clusterResources.Cluster.GetName(), }, ) Expect(err).ToNot(HaveOccurred(), "Failed to run Kubernetes conformance") diff --git a/test/e2e/quick_start_test.go b/test/e2e/quick_start_test.go index 077f737c6594..606e27942434 100644 --- a/test/e2e/quick_start_test.go +++ b/test/e2e/quick_start_test.go @@ -157,6 +157,7 @@ var _ = Describe("When following the Cluster API quick-start with dualstack and ClusterProxy: proxy.GetWorkloadCluster(ctx, namespace, clusterName), ArtifactsDirectory: artifactFolder, ConfigFilePath: "./data/kubetest/dualstack.yaml", + ClusterName: clusterName, }, )).To(Succeed()) }, @@ -183,6 +184,7 @@ var _ = Describe("When following the Cluster API quick-start with dualstack and ClusterProxy: proxy.GetWorkloadCluster(ctx, namespace, clusterName), ArtifactsDirectory: artifactFolder, ConfigFilePath: "./data/kubetest/dualstack.yaml", + ClusterName: clusterName, }, )).To(Succeed()) }, diff --git a/test/framework/kubetest/run.go b/test/framework/kubetest/run.go index 9c7b77fdc41d..59fa0d7ef8ba 100644 --- a/test/framework/kubetest/run.go +++ b/test/framework/kubetest/run.go @@ -31,6 +31,7 @@ import ( "github.com/onsi/ginkgo/v2" "github.com/pkg/errors" metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + "k8s.io/apimachinery/pkg/util/rand" "k8s.io/client-go/discovery" "k8s.io/client-go/tools/clientcmd" "sigs.k8s.io/yaml" @@ -73,6 +74,8 @@ type RunInput struct { // KubeTestRepoListPath is optional file for specifying custom image repositories // https://github.com/kubernetes/kubernetes/blob/master/test/images/README.md#testing-the-new-image KubeTestRepoListPath string + // ClusterName is the name of the cluster to run the test at + ClusterName string } // Run executes kube-test given an artifact directory, and sets settings @@ -82,6 +85,12 @@ func Run(ctx context.Context, input RunInput) error { if input.ClusterProxy == nil { return errors.New("ClusterProxy must be provided") } + // If input.ClusterName is not set use a random string to allow parallel execution + // of kubetest on different clusters. + if input.ClusterName == "" { + input.ClusterName = rand.String(10) + } + if input.GinkgoNodes == 0 { input.GinkgoNodes = DefaultGinkgoNodes } @@ -103,7 +112,7 @@ func Run(ctx context.Context, input RunInput) error { input.KubernetesVersion = discoveredVersion } input.ArtifactsDirectory = framework.ResolveArtifactsDirectory(input.ArtifactsDirectory) - reportDir := path.Join(input.ArtifactsDirectory, "kubetest") + reportDir := path.Join(input.ArtifactsDirectory, "kubetest", input.ClusterName) outputDir := path.Join(reportDir, "e2e-output") kubetestConfigDir := path.Join(reportDir, "config") if err := os.MkdirAll(outputDir, 0o750); err != nil { @@ -133,7 +142,7 @@ func Run(ctx context.Context, input RunInput) error { "report-dir": "/output", "e2e-output-dir": "/output/e2e-output", "dump-logs-on-failure": "false", - "report-prefix": "kubetest.", + "report-prefix": fmt.Sprintf("kubetest.%s.", input.ClusterName), "num-nodes": strconv.FormatInt(int64(input.NumberOfNodes), 10), } ginkgoArgs := buildArgs(ginkgoVars, "-")