Skip to content

Commit

Permalink
test/e2e: test correct incremental backup if previous backup is remov…
Browse files Browse the repository at this point in the history
…ed only in the primary cluster

Signed-off-by: Ryotaro Banno <[email protected]>
  • Loading branch information
ushitora-anqou committed Dec 25, 2024
1 parent c6766f9 commit eb29e4d
Showing 1 changed file with 45 additions and 1 deletion.
46 changes: 45 additions & 1 deletion test/e2e/multik8s/suite_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -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-")
Expand Down Expand Up @@ -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)
})
})
}

Expand Down

0 comments on commit eb29e4d

Please sign in to comment.