Skip to content

Commit

Permalink
Added on-demand backup check
Browse files Browse the repository at this point in the history
  • Loading branch information
abhishekdwivedi3060 committed Jul 31, 2024
1 parent 96fb195 commit 2169d11
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 0 deletions.
5 changes: 5 additions & 0 deletions api/v1beta1/aerospikebackup_webhook.go
Original file line number Diff line number Diff line change
Expand Up @@ -249,6 +249,11 @@ func (r *AerospikeBackup) validateAerospikeCluster(backupSvcConfig *model.Config
}

func (r *AerospikeBackup) validateOnDemandBackupsUpdate(oldObj *AerospikeBackup) error {
if !reflect.DeepEqual(r.Spec.OnDemandBackups, r.Status.OnDemandBackups) &&
!reflect.DeepEqual(r.Spec.Config.Raw, r.Status.Config.Raw) {
return fmt.Errorf("can not add/update onDemand backup along with backup config change")
}

if len(r.Spec.OnDemandBackups) > 0 && len(oldObj.Spec.OnDemandBackups) > 0 {
// Check if onDemand backup spec is updated
if r.Spec.OnDemandBackups[0].ID == oldObj.Spec.OnDemandBackups[0].ID &&
Expand Down
38 changes: 38 additions & 0 deletions test/backup/backup_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -292,6 +292,44 @@ var _ = Describe(
Expect(err.Error()).To(ContainSubstring("aerospike-cluster name update is not allowed"))
})

It("Should fail when on-demand backup is added along with backup-config update", func() {
backup, err = NewBackup(backupNsNm)
Expect(err).ToNot(HaveOccurred())

err = CreateBackup(k8sClient, backup)
Expect(err).ToNot(HaveOccurred())

err = validateTriggeredBackup(k8sClient, backup)
Expect(err).ToNot(HaveOccurred())

backup, err = getBackupObj(k8sClient, backup.Name, backup.Namespace)
Expect(err).ToNot(HaveOccurred())

backup.Spec.OnDemandBackups = []asdbv1beta1.OnDemandBackupSpec{
{
ID: "on-demand",
RoutineName: namePrefix(backupNsNm) + "-" + "test-routine",
},
}

// change storage to change overall backup config
config := getBackupConfigInMap(namePrefix(backupNsNm))
backupRoutines := config[common.BackupRoutinesKey].(map[string]interface{})
backupRoutines[namePrefix(backupNsNm)+"-"+"test-routine"].(map[string]interface{})[common.StorageKey] =
"s3Storage"

config[common.BackupRoutinesKey] = backupRoutines

configBytes, mErr := json.Marshal(config)
Expect(mErr).ToNot(HaveOccurred())

backup.Spec.Config.Raw = configBytes

err = updateBackup(k8sClient, backup)
Expect(err).To(HaveOccurred())
Expect(err.Error()).To(ContainSubstring(
"can not add/update onDemand backup along with backup config change"))
})
},
)

Expand Down

0 comments on commit 2169d11

Please sign in to comment.