Skip to content

Commit

Permalink
Add GetVmFromConfigYaml
Browse files Browse the repository at this point in the history
Signed-off-by: Martin Necas <mnecas@redhat.com>
  • Loading branch information
mnecas committed Sep 18, 2024
1 parent 5962784 commit 6faea4f
Show file tree
Hide file tree
Showing 14 changed files with 278 additions and 168 deletions.
1 change: 0 additions & 1 deletion pkg/controller/plan/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,6 @@ go_library(
"//pkg/controller/base",
"//pkg/controller/plan/adapter",
"//pkg/controller/plan/adapter/base",
"//pkg/controller/plan/adapter/ova",
"//pkg/controller/plan/adapter/vsphere",
"//pkg/controller/plan/context",
"//pkg/controller/plan/handler",
Expand Down
2 changes: 2 additions & 0 deletions pkg/controller/plan/adapter/ova/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ go_library(
"builder.go",
"client.go",
"destinationclient.go",
"ovfparser.go",
"validator.go",
],
importpath = "github.com/konveyor/forklift-controller/pkg/controller/plan/adapter/ova",
Expand All @@ -26,6 +27,7 @@ go_library(
"//pkg/lib/error",
"//pkg/lib/inventory/web",
"//pkg/lib/itinerary",
"//pkg/lib/logging",
"//vendor/github.com/go-logr/logr",
"//vendor/k8s.io/api/core/v1:core",
"//vendor/k8s.io/apimachinery/pkg/api/resource",
Expand Down
5 changes: 4 additions & 1 deletion pkg/controller/plan/util/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -16,18 +16,21 @@ go_library(
"//pkg/controller/provider/web/ovirt",
"//pkg/lib/logging",
"//pkg/settings",
"//vendor/gopkg.in/yaml.v2:yaml_v2",
"//vendor/k8s.io/api/core/v1:core",
"//vendor/k8s.io/apimachinery/pkg/apis/meta/v1:meta",
"//vendor/kubevirt.io/api/core/v1:core",
"//vendor/sigs.k8s.io/yaml",
],
)

go_test(
name = "util_test",
srcs = [
"kubevirtvmparser_test.go",
"util_suite_test.go",
"utils_test.go",
],
data = glob(["testdata/**"]),
embed = [":util"],
deps = [
"//vendor/github.com/onsi/ginkgo/v2:ginkgo",
Expand Down
91 changes: 17 additions & 74 deletions pkg/controller/plan/util/kubevirtvmparser.go
Original file line number Diff line number Diff line change
@@ -1,11 +1,10 @@
package util

import (
"fmt"
"strings"
cnv "kubevirt.io/api/core/v1"
"sigs.k8s.io/yaml"

"github.com/konveyor/forklift-controller/pkg/lib/logging"
"gopkg.in/yaml.v2"
)

const (
Expand All @@ -16,42 +15,6 @@ const (
// Package logger.
var log = logging.WithName(Name)

// Map of osinfo ids to vmware guest ids.
var osV2VMap = map[string]string{
"centos6": "centos6_64Guest",
"centos7": "centos7_64Guest",
"centos8": "centos8_64Guest",
"centos9": "centos9_64Guest",
"rhel7": "rhel7_64Guest",
"rhel8": "rhel8_64Guest",
"rhel9": "rhel9_64Guest",
"rocky": "rockylinux_64Guest",
"sles10": "sles10_64Guest",
"sles11": "sles11_64Guest",
"sles12": "sles12_64Guest",
"sles15": "sles15_64Guest",
"sles16": "sles16_64Guest",
"opensuse": "opensuse64Guest",
"debian4": "debian4_64Guest",
"debian5": "debian5_64Guest",
"debian6": "debian6_64Guest",
"debian7": "debian7_64Guest",
"debian8": "debian8_64Guest",
"debian9": "debian9_64Guest",
"debian10": "debian10_64Guest",
"debian11": "debian11_64Guest",
"debian12": "debian12_64Guest",
"ubuntu": "ubuntu64Guest",
"fedora": "fedora64Guest",
"win7": "windows7Server64Guest",
"win8": "windows8Server64Guest",
"win10": "windows9Server64Guest",
"win11": "windows11_64Guest",
"win12": "windows12_64Guest",
"win2k19": "windows2019srv_64Guest",
"win2k22": "windows2022srvNext_64Guest",
}

type OS struct {
Firmware string `yaml:"firmware"`
}
Expand Down Expand Up @@ -91,45 +54,25 @@ func GetFirmwareFromYaml(yamlData []byte) (string, error) {
}

firmware := vm.Spec.Template.Spec.Domain.OS.Firmware
if firmware == "" {
log.Info("Firmware type was not detected")
if firmware != "" {
return firmware, nil
}

return firmware, nil
}

func GetOperationSystemFromYaml(yamlData []byte) (os string, err error) {
var vm VirtualMachine
if err = yaml.Unmarshal(yamlData, &vm); err != nil {
return
// FIXME: In newer version of virt-v2v the output will change to support CNV VM format.
// With this we will support both so the migrations should not fail during the update to newer virt-v2v.
// But we still need to remove the custom templating.
// https://issues.redhat.com/browse/RHEL-58065
var cnvVm *cnv.VirtualMachine
if err := yaml.Unmarshal(yamlData, &cnvVm); err != nil {
return "", err
}

labels := vm.Metadata.Labels
if osinfo, ok := labels["libguestfs.org/osinfo"]; ok {
return mapOs(osinfo), nil

if cnvVm.Spec.Template.Spec.Domain.Firmware.Bootloader.BIOS != nil {
return "bios", nil
}
return
}

func mapOs(labelOS string) (os string) {
distro := strings.SplitN(labelOS, ".", 2)[0]

switch {
case strings.HasPrefix(distro, "rocky"):
distro = "rocky"
case strings.HasPrefix(distro, "opensuse"):
distro = "opensuse"
case strings.HasPrefix(distro, "ubuntu"):
distro = "ubuntu"
case strings.HasPrefix(distro, "fedora"):
distro = "fedora"
if cnvVm.Spec.Template.Spec.Domain.Firmware.Bootloader.EFI != nil {
return "uefi", nil
}

os, ok := osV2VMap[distro]
if !ok {
log.Info(fmt.Sprintf("Received %s, mapped to: %s", labelOS, os))
os = "otherGuest64"
}
return
log.Info("Firmware type was not detected")
return "", nil
}
31 changes: 31 additions & 0 deletions pkg/controller/plan/util/kubevirtvmparser_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
package util

import (
"fmt"
"os"
"path/filepath"
"testing"
)

func TestKubevirtVmParser(t *testing.T) {
fmt.Println("test")
testFile(t, "new_format_bios.yml", "bios")
testFile(t, "new_format_efi.yml", "uefi")
testFile(t, "old_format_bios.yml", "bios")
testFile(t, "old_format_efi.yml", "uefi")
}

func testFile(t *testing.T, filename, expectedFormat string) {
data, err := os.ReadFile(filepath.Join("testdata", filename))
if err != nil {
fmt.Println(err)
}
firmware, err := GetFirmwareFromYaml(data)
if err != nil {
fmt.Println(err)
}
fmt.Println(firmware)
if firmware != expectedFormat {
t.Fatalf("Failed to parse '%s' from file '%s'", expectedFormat, filename)
}
}
38 changes: 38 additions & 0 deletions pkg/controller/plan/util/testdata/new_format_bios.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
---
# generated by virt-v2v 2.5.8fedora=40,release=1.fc40
apiVersion: kubevirt.io/v1
kind: VirtualMachine
metadata:
name: mnecas-win-2022
labels:
libguestfs.org/virt-v2v-version: "2.5.8"
libguestfs.org/genid: f2fc75e8-4961-1425-4740-fcf2bc09685a
libguestfs.org/osinfo: win2k22
libguestfs.org/source: vmware
spec:
template:
spec:
domain:
firmware:
bootloader:
bios: {}
resources:
clock:
timer:
hpet:
present: false
hyperv: {}
pit:
tickPolicy: delay
rtc:
tickPolicy: catchup
utc: {}
requests:
memory: 8192Mi
features:
cpu:
sockets: 2
cores: 2
thread: 1
terminationGracePeriodSeconds: 0

39 changes: 39 additions & 0 deletions pkg/controller/plan/util/testdata/new_format_efi.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
---
# generated by virt-v2v 2.5.8fedora=40,release=1.fc40
apiVersion: kubevirt.io/v1
kind: VirtualMachine
metadata:
name: mnecas-win-2022
labels:
libguestfs.org/virt-v2v-version: "2.5.8"
libguestfs.org/genid: f2fc75e8-4961-1425-4740-fcf2bc09685a
libguestfs.org/osinfo: win2k22
libguestfs.org/source: vmware
spec:
template:
spec:
domain:
firmware:
bootloader:
efi:
persistent: true
resources:
clock:
timer:
hpet:
present: false
hyperv: {}
pit:
tickPolicy: delay
rtc:
tickPolicy: catchup
utc: {}
requests:
memory: 8192Mi
features:
cpu:
sockets: 2
cores: 2
thread: 1
terminationGracePeriodSeconds: 0

38 changes: 38 additions & 0 deletions pkg/controller/plan/util/testdata/old_format_bios.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
---
# generated by virt-v2v 2.5.8fedora=40,release=1.fc40
apiVersion: kubevirt.io/v1
kind: VirtualMachine
metadata:
name: mnecas-win-2022
labels:
libguestfs.org/virt-v2v-version: "2.5.8"
libguestfs.org/genid: 4f3c8a7c-3464-c9b0-cf79-08325a6bf1e8
libguestfs.org/osinfo: win2k22
libguestfs.org/source: kvm
spec:
template:
spec:
domain:
os:
firmware: bios
resources:
clock:
timer:
hpet:
present: false
hyperv: {}
pit:
tickPolicy: delay
rtc:
tickPolicy: catchup
utc: {}
requests:
memory: 8192Mi
features:
acpi: {}
apic: {}
cpu:
sockets: 2
cores: 2
thread: 1
terminationGracePeriodSeconds: 0
38 changes: 38 additions & 0 deletions pkg/controller/plan/util/testdata/old_format_efi.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
---
# generated by virt-v2v 2.5.8fedora=40,release=1.fc40
apiVersion: kubevirt.io/v1
kind: VirtualMachine
metadata:
name: mnecas-win-2022
labels:
libguestfs.org/virt-v2v-version: "2.5.8"
libguestfs.org/genid: 4f3c8a7c-3464-c9b0-cf79-08325a6bf1e8
libguestfs.org/osinfo: win2k22
libguestfs.org/source: kvm
spec:
template:
spec:
domain:
os:
firmware: uefi
resources:
clock:
timer:
hpet:
present: false
hyperv: {}
pit:
tickPolicy: delay
rtc:
tickPolicy: catchup
utc: {}
requests:
memory: 8192Mi
features:
acpi: {}
apic: {}
cpu:
sockets: 2
cores: 2
thread: 1
terminationGracePeriodSeconds: 0
8 changes: 7 additions & 1 deletion virt-v2v/cmd/entrypoint.go
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,7 @@ func virtV2vBuildCommand() (args []string, err error) {
}
return nil, fmt.Errorf("virt-v2v supports the following providers: {%v}. Provided: %s\n", strings.Join(providers, ", "), source)
}
args = append(args, "-o", "local", "-os", global.DIR)
args = append(args, "-o", "kubevirt", "-os", global.DIR)

switch source {
case global.VSPHERE:
Expand All @@ -121,6 +121,12 @@ func virtV2vBuildCommand() (args []string, err error) {
args = append(args, "-i", "ova", os.Getenv("V2V_diskPath"))
}

// When converting VM with name that do not meet DNS1123 RFC requirements,
// it should be changed to supported one to ensure the conversion does not fail.
if utils.CheckEnvVariablesSet("V2V_NewName") {
args = append(args, "-on", os.Getenv("V2V_NewName"))
}

return args, nil
}

Expand Down
Loading

0 comments on commit 6faea4f

Please sign in to comment.