From eb29e4d016f031d841da435e41bd6779e183eeef Mon Sep 17 00:00:00 2001 From: Ryotaro Banno Date: Wed, 25 Dec 2024 02:18:46 +0000 Subject: [PATCH] test/e2e: test correct incremental backup if previous backup is removed only in the primary cluster Signed-off-by: Ryotaro Banno --- test/e2e/multik8s/suite_test.go | 46 ++++++++++++++++++++++++++++++++- 1 file changed, 45 insertions(+), 1 deletion(-) diff --git a/test/e2e/multik8s/suite_test.go b/test/e2e/multik8s/suite_test.go index b78154bb..19cc9de5 100644 --- a/test/e2e/multik8s/suite_test.go +++ b/test/e2e/multik8s/suite_test.go @@ -388,7 +388,7 @@ func replicationTestSuite() { ensureCorrectRestoration(secondaryK8sCluster, ctx, namespace, backupName0, restoreName0, writtenDataHash0) }) - It("should back up correctly if previous inc. backup is removed only in the secondary cluster", func(ctx SpecContext) { + It("should back up correctly if previous inc. backup is removed in the secondary cluster", func(ctx SpecContext) { namespace := util.GetUniqueName("ns-") pvcName := util.GetUniqueName("pvc-") backupName0 := util.GetUniqueName("mb-") @@ -438,6 +438,50 @@ func replicationTestSuite() { return mb.GetName() == backupName1 })).To(BeFalse()) }) + + It("should back up correctly if previous inc. backup is removed only in the primary cluster", func(ctx SpecContext) { + namespace := util.GetUniqueName("ns-") + pvcName := util.GetUniqueName("pvc-") + backupName0 := util.GetUniqueName("mb-") + backupName1 := util.GetUniqueName("mb-") + backupName2 := util.GetUniqueName("mb-") + restoreName0 := util.GetUniqueName("mr-") + restoreName1 := util.GetUniqueName("mr-") + restoreName2 := util.GetUniqueName("mr-") + + setupEnvironment(namespace, pvcName) + + // create M0. + writtenDataHash0 := writeRandomDataToPV(ctx, namespace, pvcName) + createMantleBackup(namespace, pvcName, backupName0) + waitMantleBackupSynced(namespace, backupName0) + + // create M1. + writtenDataHash1 := writeRandomDataToPV(ctx, namespace, pvcName) + createMantleBackup(namespace, pvcName, backupName1) + waitMantleBackupSynced(namespace, backupName1) + + // remove M1. + _, _, err := kubectl(primaryK8sCluster, nil, "delete", "mb", "-n", namespace, backupName1) + Expect(err).NotTo(HaveOccurred()) + + // create M2. + writtenDataHash2 := writeRandomDataToPV(ctx, namespace, pvcName) + createMantleBackup(namespace, pvcName, backupName2) + waitMantleBackupSynced(namespace, backupName2) + ensureTemporaryResourcesRemoved(ctx) + + // Make sure M2 and M2' have the same contents. + ensureCorrectRestoration(primaryK8sCluster, ctx, namespace, backupName2, restoreName2, writtenDataHash2) + ensureCorrectRestoration(secondaryK8sCluster, ctx, namespace, backupName2, restoreName2, writtenDataHash2) + + // Make sure M1' has the same contents. + ensureCorrectRestoration(secondaryK8sCluster, ctx, namespace, backupName1, restoreName1, writtenDataHash1) + + // Make sure M0 and M0' have the same contents. + ensureCorrectRestoration(primaryK8sCluster, ctx, namespace, backupName0, restoreName0, writtenDataHash0) + ensureCorrectRestoration(secondaryK8sCluster, ctx, namespace, backupName0, restoreName0, writtenDataHash0) + }) }) }