Skip to content

Commit

Permalink
Add backupPVC config e2e
Browse files Browse the repository at this point in the history
Signed-off-by: Shubham Pampattiwar <[email protected]>

fix framework errors

Signed-off-by: Shubham Pampattiwar <[email protected]>
  • Loading branch information
shubham-pampattiwar committed Sep 24, 2024
1 parent 3f9c2dc commit 272b9b4
Show file tree
Hide file tree
Showing 2 changed files with 117 additions and 0 deletions.
114 changes: 114 additions & 0 deletions test/e2e/basic/backup-pvc-config.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,114 @@
package basic

import (
"fmt"
. "github.com/onsi/ginkgo/v2"
. "github.com/onsi/gomega"
. "github.com/vmware-tanzu/velero/test"
. "github.com/vmware-tanzu/velero/test/e2e/test"
. "github.com/vmware-tanzu/velero/test/util/k8s"
. "github.com/vmware-tanzu/velero/test/util/velero"
)

type BackupPVCConfigChange struct {
TestCase
data map[string]string
configmapName string
namespace string
sourcePVCStorageClassName string
backupPVCStorageClassName string
pvcName string
volumeName string
podName string
deploymentName string
}

const BPCCBaseName string = "bpcc"

var BackupPVCConfigChangeTest = TestFunc(&BackupPVCConfigChange{})
var configData = map[string]string{
"backupPVC": `
{
"e2e-storage-class": {
"storageClass": "e2e-storage-class-2",
"readOnly": true
},
}`,
}

func (b *BackupPVCConfigChange) Init() error {
b.TestCase.Init()
b.configmapName = "node-agent-configmap"
b.VeleroCfg.Options.NodeAgentConfigMap = b.configmapName
b.CaseBaseName = BPCCBaseName + b.UUIDgen
b.namespace = b.CaseBaseName
b.BackupName = "backup-" + b.CaseBaseName
b.RestoreName = "restore-" + b.CaseBaseName
b.sourcePVCStorageClassName = StorageClassName
b.backupPVCStorageClassName = StorageClassName2
b.data = configData
b.volumeName = "volume-1"
b.pvcName = fmt.Sprintf("pvc-%s", b.volumeName)
b.podName = "pod-1"
b.BackupArgs = []string{
"create", "--namespace", b.VeleroCfg.VeleroNamespace, "backup", b.BackupName,
"--include-namespaces", b.namespace,
"--snapshot-move-data=true", "--wait",
}
b.TestMsg = &TestMSG{
Desc: "BackupPVC Config Change",
FailedMSG: "Failed to apply Backup PVC Config",
Text: "Change the configuration of backupPVC during DM backup operation",
}
return nil
}

func (s *BackupPVCConfigChange) CreateResources() error {
label := map[string]string{
"app": "test",
}

By(("Installing storage class..."), func() {
Expect(InstallTestStorageClasses(fmt.Sprintf("../testdata/storage-class/%s.yaml", s.VeleroCfg.CloudProvider))).To(Succeed(), "Failed to install storage class")
})

By(fmt.Sprintf("Create namespace %s", s.namespace), func() {
Expect(CreateNamespace(s.Ctx, s.Client, s.namespace)).To(Succeed(),
fmt.Sprintf("Failed to create namespace %s", s.namespace))
})

By(fmt.Sprintf("Create a deployment in namespace %s", s.VeleroCfg.VeleroNamespace), func() {
pvc, err := CreatePVC(s.Client, s.namespace, s.pvcName, s.sourcePVCStorageClassName, nil)
Expect(err).To(Succeed())
vols := CreateVolumes(pvc.Name, []string{s.volumeName})

deployment := NewDeployment(s.CaseBaseName, s.namespace, 1, label, nil).WithVolume(vols).Result()
deployment, err = CreateDeployment(s.Client.ClientGo, s.namespace, deployment)
Expect(err).To(Succeed())
s.deploymentName = deployment.Name
err = WaitForReadyDeployment(s.Client.ClientGo, s.namespace, s.deploymentName)
Expect(err).To(Succeed())
})

By(fmt.Sprintf("Create ConfigMap %s in namespace %s", s.configmapName, s.VeleroCfg.VeleroNamespace), func() {
_, err := CreateConfigMap(s.Client.ClientGo, s.VeleroCfg.VeleroNamespace, s.configmapName, label, s.data)
Expect(err).To(Succeed(), fmt.Sprintf("failed to create configmap in the namespace %q", s.VeleroCfg.VeleroNamespace))
})
return nil
}

func (b *BackupPVCConfigChange) Verify() error {
return nil
}

func (b *BackupPVCConfigChange) Cleanup() error {
return nil
}

func (b *BackupPVCConfigChange) Restore() error {
return nil
}

func (b *BackupPVCConfigChange) Destroy() error {
return nil
}
3 changes: 3 additions & 0 deletions test/e2e/e2e_suite_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -139,6 +139,9 @@ var _ = Describe("Service NodePort reservation during restore is configurable",
var _ = Describe("Storage class of persistent volumes and persistent volume claims can be changed during restores",
Label("Basic", "StorageClass"), StorageClasssChangingTest)

var _ = Describe("Changing BackupPVC Configuration for Data Movement Backup Operation",
Label("Basic", "backupPVCConfig"), BackupPVCConfigChangeTest)

var _ = Describe("Node selectors of persistent volume claims can be changed during restores",
Label("Basic", "SelectedNode", "SKIP_KIND"), PVCSelectedNodeChangingTest)

Expand Down

0 comments on commit 272b9b4

Please sign in to comment.