Skip to content

Commit

Permalink
Merge branch 'main' into fix-ec
Browse files Browse the repository at this point in the history
  • Loading branch information
mnecas authored Oct 17, 2024
2 parents 8925050 + d4f8f47 commit 662a447
Show file tree
Hide file tree
Showing 7 changed files with 266 additions and 9 deletions.
175 changes: 175 additions & 0 deletions docs/enhancements/template.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,175 @@
---
title: neat-enhancement-idea
authors:
- "@janedoe"
reviewers:
- TBD
- "@alicedoe"
approvers:
- TBD
- "@oscardoe"
creation-date: yyyy-mm-dd
last-updated: yyyy-mm-dd
status: provisional|implementable|implemented|deferred|rejected|withdrawn|replaced
see-also:
- "/enhancements/this-other-neat-thing.md"
replaces:
- "/enhancements/that-less-than-great-idea.md"
superseded-by:
- "/enhancements/our-past-effort.md"
---

# Neat Enhancement Idea

This is the title of the enhancement. Keep it simple and descriptive. A good
title can help communicate what the enhancement is and should be considered as
part of any review.

The YAML `title` should be lowercased and spaces/punctuation should be
replaced with `-`.

To get started with this template:
1. **Pick a domain.** Find the appropriate domain to discuss your enhancement.
1. **Make a copy of this template.** Copy this template into the directory for
the domain.
1. **Fill out the "overview" sections.** This includes the Summary and
Motivation sections. These should be easy and explain why the community
should desire this enhancement.
1. **Create a PR.** Assign it to folks with expertise in that domain to help
sponsor the process.
1. **Merge at each milestone.** Merge when the design is able to transition to a
new status (provisional, implementable, implemented, etc.). View anything
marked as `provisional` as an idea worth exploring in the future, but not
accepted as ready to execute. Anything marked as `implementable` should
clearly communicate how an enhancement is coded up and delivered. If an
enhancement describes a new deployment topology or platform, include a
logical description for the deployment, and how it handles the unique aspects
of the platform. Aim for single topic PRs to keep discussions focused. If you
disagree with what is already in a document, open a new PR with suggested
changes.

The `Metadata` section above is intended to support the creation of tooling
around the enhancement process.

## Release Signoff Checklist

- [ ] Enhancement is `implementable`
- [ ] Design details are appropriately documented from clear requirements
- [ ] Test plan is defined
- [ ] User-facing documentation is created

## Open Questions [optional]

This is where to call out areas of the design that require closure before deciding
to implement the design. For instance,
> 1. This requires exposing previously private resources which contain sensitive
information. Can we do this?

## Summary

The `Summary` section is incredibly important for producing high quality
user-focused documentation such as release notes or a development roadmap. It
should be possible to collect this information before implementation begins in
order to avoid requiring implementors to split their attention between writing
release notes and implementing the feature itself.

A good summary is probably at least a paragraph in length.

## Motivation

This section is for explicitly listing the motivation, goals and non-goals of
this proposal. Describe why the change is important and the benefits to users.

### Goals

List the specific goals of the proposal. How will we know that this has succeeded?

### Non-Goals

What is out of scope for this proposal? Listing non-goals helps to focus discussion
and make progress.

## Proposal

This is where we get down to the nitty gritty of what the proposal actually is.

### User Stories [optional]

Detail the things that people will be able to do if this is implemented.
Include as much detail as possible so that people can understand the "how" of
the system. The goal here is to make this feel real for users without getting
bogged down.

#### Story 1

#### Story 2

### Implementation Details/Notes/Constraints [optional]

What are the caveats to the implementation? What are some important details that
didn't come across above. Go in to as much detail as necessary here. This might
be a good place to talk about core concepts and how they relate.

### Security, Risks, and Mitigations

**Carefully think through the security implications for this change**

What are the risks of this proposal and how do we mitigate. Think broadly. How
will this impact the broader OKD ecosystem? Does this work in a managed services
environment that has many tenants?

How will security be reviewed and by whom? How will UX be reviewed and by whom?

Consider including folks that also work outside your immediate sub-project.

## Design Details

### Test Plan

**Note:** *Section not required until targeted at a release.*

Consider the following in developing a test plan for this enhancement:
- Will there be e2e and integration tests, in addition to unit tests?
- How will it be tested in isolation vs with other components?

No need to outline all of the test cases, just the general strategy. Anything
that would count as tricky in the implementation and anything particularly
challenging to test should be called out.

All code is expected to have adequate tests (eventually with coverage
expectations).

### Upgrade / Downgrade Strategy

If applicable, how will the component be upgraded and downgraded? Make sure this
is in the test plan.

Consider the following in developing an upgrade/downgrade strategy for this
enhancement:
- What changes (in invocations, configurations, API use, etc.) is an existing
cluster required to make on upgrade in order to...
- keep previous behavior?
- make use of the enhancement?

## Implementation History

Major milestones in the life cycle of a proposal should be tracked in `Implementation
History`.

## Drawbacks

The idea is to find the best form of an argument why this enhancement should _not_ be implemented.

## Alternatives

Similar to the `Drawbacks` section the `Alternatives` section is used to
highlight and record other possible approaches to delivering the value proposed
by an enhancement.

## Infrastructure Needed [optional]

Use this section if you need things from the project. Examples include a new
subproject, repos requested, github details, and/or testing infrastructure.

Listing these here allows the community to get the process for these resources
started right away.
16 changes: 11 additions & 5 deletions pkg/controller/plan/util/kubevirtvmparser.go
Original file line number Diff line number Diff line change
Expand Up @@ -66,11 +66,17 @@ func GetFirmwareFromYaml(yamlData []byte) (string, error) {
if err := yaml.Unmarshal(yamlData, &cnvVm); err != nil {
return "", err
}
if cnvVm.Spec.Template.Spec.Domain.Firmware.Bootloader.BIOS != nil {
return "bios", nil
}
if cnvVm.Spec.Template.Spec.Domain.Firmware.Bootloader.EFI != nil {
return "uefi", nil

if cnvVm.Spec.Template != nil &&
cnvVm.Spec.Template.Spec.Domain.Firmware != nil &&
cnvVm.Spec.Template.Spec.Domain.Firmware.Bootloader != nil {

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

log.Info("Firmware type was not detected")
Expand Down
2 changes: 2 additions & 0 deletions pkg/controller/plan/util/kubevirtvmparser_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,8 @@ func TestKubevirtVmParser(t *testing.T) {
testFile(t, "new_format_efi.yml", "uefi")
testFile(t, "old_format_bios.yml", "bios")
testFile(t, "old_format_efi.yml", "uefi")
testFile(t, "old_format_none.yml", "")
testFile(t, "new_format_none.yml", "")
}

func testFile(t *testing.T, filename, expectedFormat string) {
Expand Down
37 changes: 37 additions & 0 deletions pkg/controller/plan/util/testdata/new_format_none.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
---
# 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:
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

37 changes: 37 additions & 0 deletions pkg/controller/plan/util/testdata/old_format_none.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
---
# 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:
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
2 changes: 1 addition & 1 deletion virt-v2v/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -451,7 +451,7 @@ rpmtree(
"@util-linux-core-0__2.37.4-20.el9.x86_64//rpm",
"@vim-minimal-2__8.2.2637-21.el9.x86_64//rpm",
"@virt-v2v-1__2.5.6-4.el9.x86_64//rpm",
"@virtio-win-0__1.9.15-4.el9.x86_64//rpm",
"@virtio-win-1.9.40-1.el9.noarch//rpm",
"@which-0__2.21-29.el9.x86_64//rpm",
"@xfsprogs-0__6.4.0-4.el9.x86_64//rpm",
"@xz-0__5.2.5-8.el9.x86_64//rpm",
Expand Down
6 changes: 3 additions & 3 deletions virt-v2v/WORKSPACE
Original file line number Diff line number Diff line change
Expand Up @@ -2931,10 +2931,10 @@ rpm(
)

rpm(
name = "virtio-win-0__1.9.15-4.el9.x86_64",
sha256 = "6673ae4cb0f24fdc75b12b68aa37533c29eae2a98eaa60d1ee7c8390f7edd20b",
name = "virtio-win-1.9.40-1.el9.noarch",
sha256 = "7baa1bddc62a72798b00f1ccd7ba46e3a79d7cd8224d3aabae328719f4d604bc",
urls = [
"https://composes.stream.centos.org/development/latest-CentOS-Stream/compose/AppStream/x86_64/os/Packages/virtio-win-1.9.15-4.el9.noarch.rpm",
"https://kojihub.stream.rdu2.redhat.com/kojifiles/packages/virtio-win/1.9.40/1.el9/noarch/virtio-win-1.9.40-1.el9.noarch.rpm",
],
)

Expand Down

0 comments on commit 662a447

Please sign in to comment.