From 2a038d0267fc65f61bfd8a095f02ed2f8097870c Mon Sep 17 00:00:00 2001 From: Benny Zlotnik Date: Thu, 10 Aug 2023 13:45:18 +0300 Subject: [PATCH 1/2] Check claimName on DV status It seems like dv.PVC is always nil because we don't create a DV from a PVC, this leads to failing to find the DV whenever the importer pod fails and it will restart forever instead of 3 times Signed-off-by: Benny Zlotnik --- pkg/controller/plan/migration.go | 39 ++++++++++++++------------------ 1 file changed, 17 insertions(+), 22 deletions(-) diff --git a/pkg/controller/plan/migration.go b/pkg/controller/plan/migration.go index 963a113d8..f3f060b1e 100644 --- a/pkg/controller/plan/migration.go +++ b/pkg/controller/plan/migration.go @@ -1389,32 +1389,27 @@ func (r *Migration) updateCopyProgress(vm *plan.VMStatus, step *plan.Step) (err var importer *core.Pod var found bool var kErr error - if dv.PVC == nil && !r.Plan.IsSourceProviderOCP() { + + if dv.Status.ClaimName == "" { found = false } else { - var importerPVC core.PersistentVolumeClaim - if r.Plan.IsSourceProviderOCP() { - pvc := &core.PersistentVolumeClaim{} - err = r.Destination.Client.Get(context.TODO(), types.NamespacedName{ - Namespace: r.Plan.Spec.TargetNamespace, - Name: dv.Status.ClaimName, - }, pvc) - if err != nil { - log.Error( - err, - "Could not get PVC for DataVolume.", - "vm", - vm.String(), - "dv", - path.Join(dv.Namespace, dv.Name)) - continue - } - importerPVC = *pvc - } else { - importerPVC = *dv.PVC + pvc := &core.PersistentVolumeClaim{} + err = r.Destination.Client.Get(context.TODO(), types.NamespacedName{ + Namespace: r.Plan.Spec.TargetNamespace, + Name: dv.Status.ClaimName, + }, pvc) + if err != nil { + log.Error( + err, + "Could not get PVC for DataVolume.", + "vm", + vm.String(), + "dv", + path.Join(dv.Namespace, dv.Name)) + continue } - importer, found, kErr = r.kubevirt.GetImporterPod(importerPVC) + importer, found, kErr = r.kubevirt.GetImporterPod(*pvc) } if kErr != nil { From 7ea8beba18eb2a487a5317384a7f6bc9c6249712 Mon Sep 17 00:00:00 2001 From: Benny Zlotnik Date: Sun, 13 Aug 2023 13:47:38 +0300 Subject: [PATCH 2/2] rename DataVolume to DataVolumeWrapper Make it slightly less confusing Signed-off-by: Benny Zlotnik --- pkg/controller/plan/kubevirt.go | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/pkg/controller/plan/kubevirt.go b/pkg/controller/plan/kubevirt.go index d3668418b..4b2506ce1 100644 --- a/pkg/controller/plan/kubevirt.go +++ b/pkg/controller/plan/kubevirt.go @@ -159,7 +159,7 @@ func (r *KubeVirt) ListVMs() ([]VirtualMachine, error) { } vm.DataVolumes = append( vm.DataVolumes, - DataVolume{ + ExtendedDataVolume{ DataVolume: dv, PVC: pvc, }) @@ -537,7 +537,7 @@ func (r *KubeVirt) isDataVolumeExistsInList(dv *cdi.DataVolume, dataVolumeList * } // Return DataVolumes associated with a VM. -func (r *KubeVirt) getDVs(vm *plan.VMStatus) (dvs []DataVolume, err error) { +func (r *KubeVirt) getDVs(vm *plan.VMStatus) (edvs []ExtendedDataVolume, err error) { dvsList := &cdi.DataVolumeList{} err = r.Destination.Client.List( context.TODO(), @@ -552,10 +552,10 @@ func (r *KubeVirt) getDVs(vm *plan.VMStatus) (dvs []DataVolume, err error) { return } - dvs = []DataVolume{} + edvs = []ExtendedDataVolume{} for i := range dvsList.Items { dv := &dvsList.Items[i] - dvs = append(dvs, DataVolume{ + edvs = append(edvs, ExtendedDataVolume{ DataVolume: dv, }) } @@ -1686,14 +1686,14 @@ func (r *KubeVirt) vmAllButMigrationLabels(vmRef ref.Ref) (labels map[string]str return } -// Represents a CDI DataVolume and add behavior. -type DataVolume struct { +// Represents a CDI DataVolume, its associated PVC, and added behavior. +type ExtendedDataVolume struct { *cdi.DataVolume PVC *core.PersistentVolumeClaim } // Get conditions. -func (r *DataVolume) Conditions() (cnd *libcnd.Conditions) { +func (r *ExtendedDataVolume) Conditions() (cnd *libcnd.Conditions) { cnd = &libcnd.Conditions{} for _, c := range r.Status.Conditions { cnd.SetCondition(libcnd.Condition{ @@ -1710,7 +1710,7 @@ func (r *DataVolume) Conditions() (cnd *libcnd.Conditions) { // Convert the Status.Progress into a // percentage (float). -func (r *DataVolume) PercentComplete() (pct float64) { +func (r *ExtendedDataVolume) PercentComplete() (pct float64) { s := string(r.Status.Progress) if strings.HasSuffix(s, "%") { s = s[:len(s)-1] @@ -1726,7 +1726,7 @@ func (r *DataVolume) PercentComplete() (pct float64) { // Represents Kubevirt VirtualMachine with associated DataVolumes. type VirtualMachine struct { *cnv.VirtualMachine - DataVolumes []DataVolume + DataVolumes []ExtendedDataVolume } // Determine if `this` VirtualMachine is the