forked from kubevirt/kubevirt
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
hostdev: usb: Add functional testing
The test takes inspiration on PCI's tests/vmi_hostdev_test.go Since the introduction of emulated USB devices [0], this can be tested locally with: > export KUBEVIRT_PROVIDER=k8s-1.26-centos9 > export KUBEVIRTCI_TAG=latest > export KUBEVIRT_PROVIDER_EXTRA_ARGS="--usb 20M --usb 40M" > make cluster-up [0] kubevirt/kubevirtci#996 Signed-off-by: Luboslav Pivarc <[email protected]> Signed-off-by: Victor Toso <[email protected]>
- Loading branch information
1 parent
d3854e1
commit a5af396
Showing
3 changed files
with
107 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,105 @@ | ||
package usb | ||
|
||
import ( | ||
"context" | ||
"fmt" | ||
|
||
. "github.com/onsi/ginkgo/v2" | ||
. "github.com/onsi/gomega" | ||
|
||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||
|
||
v1 "kubevirt.io/api/core/v1" | ||
"kubevirt.io/client-go/kubecli" | ||
|
||
virtconfig "kubevirt.io/kubevirt/pkg/virt-config" | ||
"kubevirt.io/kubevirt/tests" | ||
"kubevirt.io/kubevirt/tests/console" | ||
"kubevirt.io/kubevirt/tests/decorators" | ||
"kubevirt.io/kubevirt/tests/framework/kubevirt" | ||
"kubevirt.io/kubevirt/tests/libwait" | ||
"kubevirt.io/kubevirt/tests/util" | ||
) | ||
|
||
const ( | ||
failedDeleteVMI = "Failed to delete VMI" | ||
) | ||
|
||
var _ = Describe("[Serial][sig-compute][USB] host USB Passthrough", Serial, decorators.SigCompute, decorators.USB, func() { | ||
var ( | ||
virtClient kubecli.KubevirtClient | ||
config v1.KubeVirtConfiguration | ||
) | ||
|
||
BeforeEach(func() { | ||
virtClient = kubevirt.Client() | ||
kv := util.GetCurrentKv(virtClient) | ||
config = kv.Spec.Configuration | ||
}) | ||
|
||
AfterEach(func() { | ||
kv := util.GetCurrentKv(virtClient) | ||
// Reinitialized the DeveloperConfiguration to avoid to influence the next test | ||
config = kv.Spec.Configuration | ||
config.DeveloperConfiguration = &v1.DeveloperConfiguration{} | ||
config.PermittedHostDevices = &v1.PermittedHostDevices{} | ||
tests.UpdateKubeVirtConfigValueAndWait(config) | ||
}) | ||
|
||
Context("with usb storage", func() { | ||
DescribeTable("with emulated USB devices", func(deviceNames []string) { | ||
resourceName := "kubevirt.io/usb-storage" | ||
|
||
By("Adding the emulated USB device to the permitted host devices") | ||
config.DeveloperConfiguration = &v1.DeveloperConfiguration{ | ||
FeatureGates: []string{virtconfig.HostDevicesGate}, | ||
} | ||
config.PermittedHostDevices = &v1.PermittedHostDevices{ | ||
USB: []v1.USBHostDevice{ | ||
{ | ||
ResourceName: resourceName, | ||
Selectors: []v1.USBSelector{ | ||
{ | ||
Vendor: "46f4", | ||
Product: "0001", | ||
}}, | ||
}}, | ||
} | ||
tests.UpdateKubeVirtConfigValueAndWait(config) | ||
|
||
By("Creating a Fedora VMI with the usb host device") | ||
hostDevs := []v1.HostDevice{} | ||
for i, name := range deviceNames { | ||
hostDevs = append(hostDevs, v1.HostDevice{ | ||
Name: fmt.Sprintf("usb-%d-%s", i, name), | ||
DeviceName: resourceName, | ||
}) | ||
} | ||
|
||
randomVMI := tests.NewRandomFedoraVMIWithGuestAgent() | ||
randomVMI.Spec.Domain.Devices.HostDevices = hostDevs | ||
vmi, err := virtClient.VirtualMachineInstance(util.NamespaceTestDefault).Create(context.Background(), randomVMI) | ||
Expect(err).ToNot(HaveOccurred()) | ||
libwait.WaitForSuccessfulVMIStart(vmi) | ||
Expect(console.LoginToFedora(vmi)).To(Succeed()) | ||
|
||
By("Making sure the usb is present inside the VMI") | ||
/* | ||
for _, id := range deviceIDs { | ||
Expect(console.SafeExpectBatch(vmi, []expect.Batcher{ | ||
&expect.BSnd{S: "grep -c " + strings.Replace(id, ":", "", 1) + " /proc/bus/pci/devices\n"}, | ||
&expect.BExp{R: console.RetValue("1")}, | ||
}, 15)).To(Succeed(), "Device not found") | ||
} | ||
*/ | ||
|
||
// Make sure to delete the VMI before ending the test otherwise a device could still be taken | ||
err = virtClient.VirtualMachineInstance(util.NamespaceTestDefault).Delete(context.Background(), vmi.ObjectMeta.Name, &metav1.DeleteOptions{}) | ||
Expect(err).ToNot(HaveOccurred(), failedDeleteVMI) | ||
libwait.WaitForVirtualMachineToDisappearWithTimeout(vmi, 180) | ||
}, | ||
Entry("Should successfully passthrough 1 emulated USB device", []string{"slow-storage"}), | ||
Entry("Should successfully passthrough 2 emulated USB devices", []string{"fast-storage", "low-storage"}), | ||
) | ||
}) | ||
}) |