diff --git a/pkg/controller/plan/kubevirt.go b/pkg/controller/plan/kubevirt.go index 205b6cbde..13301facb 100644 --- a/pkg/controller/plan/kubevirt.go +++ b/pkg/controller/plan/kubevirt.go @@ -12,7 +12,6 @@ import ( "sort" "strconv" "strings" - "syscall" "time" api "github.com/konveyor/forklift-controller/pkg/apis/forklift/v1beta1" @@ -910,7 +909,7 @@ func (r *KubeVirt) UpdateVmByConvertedConfig(vm *plan.VMStatus, pod *core.Pod, s */ resp, err := http.Get(url) if err != nil { - if err == syscall.ECONNREFUSED { + if strings.Contains(err.Error(), "connection refused") { err = nil } return @@ -941,6 +940,8 @@ func (r *KubeVirt) UpdateVmByConvertedConfig(vm *plan.VMStatus, pod *core.Pod, s err = nil } } + step.MarkCompleted() + step.Progress.Completed = step.Progress.Total return } diff --git a/pkg/controller/plan/migration.go b/pkg/controller/plan/migration.go index 714b9770d..eab03ea05 100644 --- a/pkg/controller/plan/migration.go +++ b/pkg/controller/plan/migration.go @@ -1118,6 +1118,12 @@ func (r *Migration) execute(vm *plan.VMStatus) (err error) { } step.MarkStarted() step.Phase = Running + + err = r.updateConversionProgress(vm, step) + if err != nil { + return + } + // only for OVA, fetch config from the conversion pod if r.Source.Provider.Type() == v1beta1.Ova { pod, err := r.kubevirt.GetGuestConversionPod(vm) @@ -1133,11 +1139,6 @@ func (r *Migration) execute(vm *plan.VMStatus) (err error) { } } - err = r.updateConversionProgress(vm, step) - if err != nil { - return - } - if step.MarkedCompleted() && !step.HasError() { step.Phase = Completed vm.Phase = r.next(vm.Phase) @@ -1695,7 +1696,7 @@ func (r *Migration) updateConversionProgressEl9(pod *core.Pod, step *plan.Step) } } step.ReflectTasks() - if step.Name == ImageConversion && someProgress { + if step.Name == ImageConversion && someProgress && r.Source.Provider.Type() != v1beta1.Ova { // Disk copying has already started. Transition from // ConvertGuest to CopyDisksVirtV2V . step.MarkCompleted()