Skip to content

Commit

Permalink
reduce complexity in progress gathering from virt-v2v
Browse files Browse the repository at this point in the history
Signed-off-by: Arik Hadas <[email protected]>
  • Loading branch information
ahadas committed Dec 24, 2023
1 parent b1bc590 commit bce6075
Showing 1 changed file with 38 additions and 38 deletions.
76 changes: 38 additions & 38 deletions pkg/controller/plan/migration.go
Original file line number Diff line number Diff line change
Expand Up @@ -1475,58 +1475,58 @@ func (r *Migration) updateCopyProgress(vm *plan.VMStatus, step *plan.Step) (err
}

// Wait for guest conversion to complete, and update the ImageConversion pipeline step.
func (r *Migration) updateConversionProgress(vm *plan.VMStatus, step *plan.Step) (err error) {
func (r *Migration) updateConversionProgress(vm *plan.VMStatus, step *plan.Step) error {
pod, err := r.kubevirt.GetGuestConversionPod(vm)
if err != nil {
return
switch {
case err != nil:
return liberr.Wrap(err)
case pod == nil:
step.MarkCompleted()
step.AddError("Guest conversion pod not found")
return nil
}

if pod != nil {
switch pod.Status.Phase {
case core.PodSucceeded:
step.MarkCompleted()
step.Progress.Completed = step.Progress.Total
case core.PodFailed:
step.MarkCompleted()
step.AddError("Guest conversion failed. See pod logs for details.")
default:
el9, el9Err := r.Context.Plan.VSphereUsesEl9VirtV2v()
if el9Err != nil {
err = el9Err
return
}
if el9 {
err = r.updateConversionProgressEl9(pod, step)
if err != nil {
// Just log it. Missing progress is not fatal.
log.Error(err, "Failed to update conversion progress")
err = nil
return
}
switch pod.Status.Phase {
case core.PodSucceeded:
step.MarkCompleted()
step.Progress.Completed = step.Progress.Total
case core.PodFailed:
step.MarkCompleted()
step.AddError("Guest conversion failed. See pod logs for details.")
default:
if pod.Status.PodIP == "" {
// we get the progress from the pod and we cannot connect to the pod without PodIP
break
}

el9, err := r.Context.Plan.VSphereUsesEl9VirtV2v()
switch {
case err != nil:
return liberr.Wrap(err)
case el9:
if err := r.updateConversionProgressEl9(pod, step); err != nil {
// Just log it. Missing progress is not fatal.
log.Error(err, "Failed to update conversion progress")
}
}
} else {
step.MarkCompleted()
step.AddError("Guest conversion pod not found")
}
return

return nil
}

func (r *Migration) updateConversionProgressEl9(pod *core.Pod, step *plan.Step) (err error) {
if pod.Status.PodIP == "" {
return
}

var diskRegex = regexp.MustCompile(`v2v_disk_transfers\{disk_id="(\d+)"\} (\d{1,3}\.?\d*)`)
url := fmt.Sprintf("http://%s:2112/metrics", pod.Status.PodIP)
resp, err := http.Get(url)
if err != nil {
if strings.Contains(err.Error(), "connection refused") {
return nil
}
switch {
case err == nil:
defer resp.Body.Close()
case strings.Contains(err.Error(), "connection refused"):
return nil
default:
return
}
defer resp.Body.Close()

body, err := io.ReadAll(resp.Body)
if err != nil {
return
Expand Down

0 comments on commit bce6075

Please sign in to comment.