From 3be5fe15d9dace2cb93f08420758598e1070b081 Mon Sep 17 00:00:00 2001 From: Sakuralbj Date: Fri, 18 Sep 2020 18:52:29 +0800 Subject: [PATCH] test: add unit-test for TranslateCSIPVToInTree. --- .../plugins/azure_file_test.go | 114 ++++++++++++++++++ 1 file changed, 114 insertions(+) diff --git a/staging/src/k8s.io/csi-translation-lib/plugins/azure_file_test.go b/staging/src/k8s.io/csi-translation-lib/plugins/azure_file_test.go index ffc4be5d29e..66c4dc14453 100644 --- a/staging/src/k8s.io/csi-translation-lib/plugins/azure_file_test.go +++ b/staging/src/k8s.io/csi-translation-lib/plugins/azure_file_test.go @@ -282,6 +282,120 @@ func TestTranslateAzureFileInTreePVToCSI(t *testing.T) { } } +func TestTranslateCSIPVToInTree(t *testing.T) { + translator := NewAzureFileCSITranslator() + + secretNamespace := "secretnamespace" + mp := make(map[string]string) + mp["shareName"] = "unit-test" + cases := []struct { + name string + volume *corev1.PersistentVolume + expVol *corev1.PersistentVolume + expErr bool + }{ + { + name: "empty volume", + expErr: true, + }, + { + name: "resource group empty", + volume: &corev1.PersistentVolume{ + Spec: corev1.PersistentVolumeSpec{ + PersistentVolumeSource: corev1.PersistentVolumeSource{ + CSI: &corev1.CSIPersistentVolumeSource{ + NodeStageSecretRef: &corev1.SecretReference{ + Name: "ut", + Namespace: secretNamespace, + }, + ReadOnly: true, + VolumeAttributes: mp, + }, + }, + }, + }, + expVol: &corev1.PersistentVolume{ + Spec: corev1.PersistentVolumeSpec{ + PersistentVolumeSource: corev1.PersistentVolumeSource{ + AzureFile: &corev1.AzureFilePersistentVolumeSource{ + SecretName: "ut", + SecretNamespace: &secretNamespace, + ReadOnly: true, + ShareName: "unit-test", + }, + }, + }, + }, + expErr: false, + }, + { + name: "translate from volume handle error", + volume: &corev1.PersistentVolume{ + Spec: corev1.PersistentVolumeSpec{ + PersistentVolumeSource: corev1.PersistentVolumeSource{ + CSI: &corev1.CSIPersistentVolumeSource{ + VolumeHandle: "unit-test", + ReadOnly: true, + VolumeAttributes: mp, + }, + }, + }, + }, + expErr: true, + }, + { + name: "translate from volume handle", + volume: &corev1.PersistentVolume{ + ObjectMeta: metav1.ObjectMeta{ + Name: "file.csi.azure.com-sharename", + }, + Spec: corev1.PersistentVolumeSpec{ + PersistentVolumeSource: corev1.PersistentVolumeSource{ + CSI: &corev1.CSIPersistentVolumeSource{ + VolumeHandle: "rg#st#pvc-file-dynamic#diskname.vhd", + ReadOnly: true, + VolumeAttributes: mp, + }, + }, + }, + }, + expVol: &corev1.PersistentVolume{ + ObjectMeta: metav1.ObjectMeta{ + Name: "file.csi.azure.com-sharename", + Annotations: map[string]string{resourceGroupAnnotation: "rg"}, + }, + Spec: corev1.PersistentVolumeSpec{ + PersistentVolumeSource: corev1.PersistentVolumeSource{ + AzureFile: &corev1.AzureFilePersistentVolumeSource{ + SecretName: "azure-storage-account-st-secret", + ShareName: "pvc-file-dynamic", + ReadOnly: true, + }, + }, + }, + }, + expErr: false, + }, + } + + for _, tc := range cases { + t.Logf("Testing %v", tc.name) + got, err := translator.TranslateCSIPVToInTree(tc.volume) + if err != nil && !tc.expErr { + t.Errorf("Did not expect error but got: %v", err) + } + + if err == nil && tc.expErr { + t.Errorf("Expected error, but did not get one.") + } + + if !reflect.DeepEqual(got, tc.expVol) { + t.Errorf("Got parameters: %v, expected :%v", got, tc.expVol) + } + } + +} + func TestGetStorageAccount(t *testing.T) { tests := []struct { secretName string