Skip to content

Commit

Permalink
tests: parametrize uvm_any fixture family with vcpus and memory
Browse files Browse the repository at this point in the history
Add a parameter so that we can control vcpu number and memory.

Right now it uses a hardcoded value, but it can be overridden per test.

Signed-off-by: Pablo Barbáchano <pablob@amazon.com>
  • Loading branch information
pb8o authored and tommady committed Dec 6, 2024
1 parent 2df0766 commit e39504c
Showing 1 changed file with 46 additions and 8 deletions.
54 changes: 46 additions & 8 deletions tests/conftest.py
Original file line number Diff line number Diff line change
Expand Up @@ -455,20 +455,34 @@ def uvm_with_initrd(
yield uvm


def uvm_booted(microvm_factory, guest_kernel, rootfs, cpu_template):
@pytest.fixture
def vcpu_count():
"""Return default vcpu_count. Use indirect parametrization to override."""
return 2


@pytest.fixture
def mem_size_mib():
"""Return memory size. Use indirect parametrization to override."""
return 256


def uvm_booted(
microvm_factory, guest_kernel, rootfs, cpu_template, vcpu_count=2, mem_size_mib=256
):
"""Return a booted uvm"""
uvm = microvm_factory.build(guest_kernel, rootfs)
uvm.spawn()
uvm.basic_config(vcpu_count=2, mem_size_mib=256)
uvm.basic_config(vcpu_count=vcpu_count, mem_size_mib=mem_size_mib)
uvm.set_cpu_template(cpu_template)
uvm.add_net_iface()
uvm.start()
return uvm


def uvm_restored(microvm_factory, guest_kernel, rootfs, cpu_template):
def uvm_restored(microvm_factory, guest_kernel, rootfs, cpu_template, **kwargs):
"""Return a restored uvm"""
uvm = uvm_booted(microvm_factory, guest_kernel, rootfs, cpu_template)
uvm = uvm_booted(microvm_factory, guest_kernel, rootfs, cpu_template, **kwargs)
snapshot = uvm.snapshot_full()
uvm.kill()
uvm2 = microvm_factory.build_from_snapshot(snapshot)
Expand All @@ -483,12 +497,36 @@ def uvm_ctor(request):


@pytest.fixture
def uvm_any(microvm_factory, uvm_ctor, guest_kernel, rootfs, cpu_template_any):
def uvm_any(
microvm_factory,
uvm_ctor,
guest_kernel,
rootfs,
cpu_template_any,
vcpu_count,
mem_size_mib,
):
"""Return booted and restored uvms"""
return uvm_ctor(microvm_factory, guest_kernel, rootfs, cpu_template_any)
return uvm_ctor(
microvm_factory,
guest_kernel,
rootfs,
cpu_template_any,
vcpu_count=vcpu_count,
mem_size_mib=mem_size_mib,
)


@pytest.fixture
def uvm_any_booted(microvm_factory, guest_kernel, rootfs, cpu_template_any):
def uvm_any_booted(
microvm_factory, guest_kernel, rootfs, cpu_template_any, vcpu_count, mem_size_mib
):
"""Return booted uvms"""
return uvm_booted(microvm_factory, guest_kernel, rootfs, cpu_template_any)
return uvm_booted(
microvm_factory,
guest_kernel,
rootfs,
cpu_template_any,
vcpu_count=vcpu_count,
mem_size_mib=mem_size_mib,
)

0 comments on commit e39504c

Please sign in to comment.