From 114193ae3b02bec67ec6b0a3e686565c20886c46 Mon Sep 17 00:00:00 2001 From: danfengliu Date: Fri, 9 Jun 2023 09:59:19 +0800 Subject: [PATCH] add ut for pkg client factory (#6371) Signed-off-by: danfengl --- hack/test.sh | 2 +- pkg/client/factory_test.go | 91 ++++++++++++++++++++++++++++++++++++-- 2 files changed, 89 insertions(+), 4 deletions(-) diff --git a/hack/test.sh b/hack/test.sh index 808197044..a79ddb9d6 100755 --- a/hack/test.sh +++ b/hack/test.sh @@ -42,5 +42,5 @@ fi # but the user and group don't exist inside the container, when the code(https://github.com/kubernetes-sigs/controller-runtime/blob/v0.10.2/pkg/internal/testing/addr/manager.go#L44) # tries to get the cache directory, it gets the directory "/" and then get the permission error when trying to create directory under "/". # Specifying the cache directory by environment variable "XDG_CACHE_HOME" to workaround it -XDG_CACHE_HOME=/tmp/ go test -installsuffix "static" -short -timeout 60s -coverprofile=coverage.out "${TARGETS[@]}" +XDG_CACHE_HOME=/tmp/ go test -installsuffix "static" -short -timeout 120s -coverprofile=coverage.out "${TARGETS[@]}" echo "Success!" diff --git a/pkg/client/factory_test.go b/pkg/client/factory_test.go index db5edb257..e96b2b044 100644 --- a/pkg/client/factory_test.go +++ b/pkg/client/factory_test.go @@ -16,11 +16,16 @@ limitations under the License. package client import ( + "context" + "fmt" "os" + "strings" "testing" - "github.com/spf13/pflag" + flag "github.com/spf13/pflag" "github.com/stretchr/testify/assert" + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" + "k8s.io/apimachinery/pkg/runtime/schema" ) // TestFactory tests the client.Factory interface. @@ -40,7 +45,7 @@ func TestFactory(t *testing.T) { // Argument should change the namespace f = NewFactory("velero", make(map[string]interface{})) s := "flag-velero" - flags := new(pflag.FlagSet) + flags := new(flag.FlagSet) f.BindFlags(flags) @@ -51,11 +56,91 @@ func TestFactory(t *testing.T) { // An argument overrides the env variable if both are set. os.Setenv("VELERO_NAMESPACE", "env-velero") f = NewFactory("velero", make(map[string]interface{})) - flags = new(pflag.FlagSet) + flags = new(flag.FlagSet) f.BindFlags(flags) flags.Parse([]string{"--namespace", s}) assert.Equal(t, s, f.Namespace()) os.Unsetenv("VELERO_NAMESPACE") + + tests := []struct { + name string + kubeconfig string + kubecontext string + QPS float32 + burst int + baseName string + expectedHost string + }{ + { + name: "Test flag setting in factory ClientConfig (test data #1)", + kubeconfig: "kubeconfig", + kubecontext: "federal-context", + QPS: 1.0, + burst: 1, + baseName: "bn-velero-1", + expectedHost: "https://horse.org:4443", + }, + { + name: "Test flag setting in factory ClientConfig (test data #2)", + kubeconfig: "kubeconfig", + kubecontext: "queen-anne-context", + QPS: 200.0, + burst: 20, + baseName: "bn-velero-2", + expectedHost: "https://pig.org:443", + }, + } + + baseName := "velero-bn" + config, err := LoadConfig() + assert.Equal(t, err, nil) + for _, test := range tests { + t.Run(test.name, func(t *testing.T) { + f = NewFactory(baseName, config) + f.SetClientBurst(test.burst) + f.SetClientQPS(test.QPS) + f.SetBasename(test.baseName) + + flags = new(flag.FlagSet) + f.BindFlags(flags) + flags.Parse([]string{"--kubeconfig", test.kubeconfig, "--kubecontext", test.kubecontext}) + clientConfig, _ := f.ClientConfig() + assert.Equal(t, test.expectedHost, clientConfig.Host) + assert.Equal(t, test.QPS, clientConfig.QPS) + assert.Equal(t, test.burst, clientConfig.Burst) + strings.Contains(clientConfig.UserAgent, test.baseName) + + client, _ := f.Client() + _, e := client.Discovery().ServerGroups() + assert.Contains(t, e.Error(), fmt.Sprintf("Get \"%s/api?timeout=", test.expectedHost)) + assert.NotNil(t, client) + + kubeClient, _ := f.KubeClient() + group := kubeClient.NodeV1().RESTClient().APIVersion().Group + assert.NotNil(t, kubeClient) + assert.Equal(t, "node.k8s.io", group) + + namespace := "ns1" + dynamicClient, _ := f.DynamicClient() + resource := &schema.GroupVersionResource{ + Group: "group_test", + Version: "verion_test", + } + list, e := dynamicClient.Resource(*resource).Namespace(namespace).List( + context.Background(), + metav1.ListOptions{ + LabelSelector: "none", + }, + ) + assert.Contains(t, e.Error(), fmt.Sprintf("Get \"%s/apis/%s/%s/namespaces/%s", test.expectedHost, resource.Group, resource.Version, namespace)) + assert.Nil(t, list) + assert.NotNil(t, dynamicClient) + + kubebuilderClient, e := f.KubebuilderClient() + assert.Contains(t, e.Error(), fmt.Sprintf("Get \"%s/api?timeout=", test.expectedHost)) + assert.Nil(t, kubebuilderClient) + }) + } }