Merge "Use test_base symbols directly"
This commit is contained in:
commit
bd0ff54b4a
@ -21,11 +21,6 @@ from nova.tests.functional.api.openstack.placement.db import test_base as tb
|
|||||||
from nova.tests import uuidsentinel as uuids
|
from nova.tests import uuidsentinel as uuids
|
||||||
|
|
||||||
|
|
||||||
_add_inventory = tb._add_inventory
|
|
||||||
_allocate_from_provider = tb._allocate_from_provider
|
|
||||||
_set_traits = tb._set_traits
|
|
||||||
|
|
||||||
|
|
||||||
class ProviderDBHelperTestCase(tb.PlacementDbBaseTestCase):
|
class ProviderDBHelperTestCase(tb.PlacementDbBaseTestCase):
|
||||||
|
|
||||||
def test_get_provider_ids_matching(self):
|
def test_get_provider_ids_matching(self):
|
||||||
@ -37,119 +32,126 @@ class ProviderDBHelperTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
|
|
||||||
# Inventory of adequate CPU and memory, no allocations against it.
|
# Inventory of adequate CPU and memory, no allocations against it.
|
||||||
excl_big_cm_noalloc = self._create_provider('big_cm_noalloc')
|
excl_big_cm_noalloc = self._create_provider('big_cm_noalloc')
|
||||||
_add_inventory(excl_big_cm_noalloc, fields.ResourceClass.VCPU, 15)
|
tb.add_inventory(excl_big_cm_noalloc, fields.ResourceClass.VCPU, 15)
|
||||||
_add_inventory(excl_big_cm_noalloc, fields.ResourceClass.MEMORY_MB,
|
tb.add_inventory(excl_big_cm_noalloc, fields.ResourceClass.MEMORY_MB,
|
||||||
4096, max_unit=2048)
|
4096, max_unit=2048)
|
||||||
|
|
||||||
# Adequate inventory, no allocations against it.
|
# Adequate inventory, no allocations against it.
|
||||||
incl_biginv_noalloc = self._create_provider('biginv_noalloc')
|
incl_biginv_noalloc = self._create_provider('biginv_noalloc')
|
||||||
_add_inventory(incl_biginv_noalloc, fields.ResourceClass.VCPU, 15)
|
tb.add_inventory(incl_biginv_noalloc, fields.ResourceClass.VCPU, 15)
|
||||||
_add_inventory(incl_biginv_noalloc, fields.ResourceClass.MEMORY_MB,
|
tb.add_inventory(incl_biginv_noalloc, fields.ResourceClass.MEMORY_MB,
|
||||||
4096, max_unit=2048)
|
4096, max_unit=2048)
|
||||||
_add_inventory(incl_biginv_noalloc, fields.ResourceClass.DISK_GB, 2000)
|
tb.add_inventory(incl_biginv_noalloc, fields.ResourceClass.DISK_GB,
|
||||||
|
2000)
|
||||||
|
|
||||||
# No allocations, but inventory unusable. Try to hit all the possible
|
# No allocations, but inventory unusable. Try to hit all the possible
|
||||||
# reasons for exclusion.
|
# reasons for exclusion.
|
||||||
# VCPU min_unit too high
|
# VCPU min_unit too high
|
||||||
excl_badinv_min_unit = self._create_provider('badinv_min_unit')
|
excl_badinv_min_unit = self._create_provider('badinv_min_unit')
|
||||||
_add_inventory(excl_badinv_min_unit, fields.ResourceClass.VCPU, 12,
|
tb.add_inventory(excl_badinv_min_unit, fields.ResourceClass.VCPU, 12,
|
||||||
min_unit=6)
|
min_unit=6)
|
||||||
_add_inventory(excl_badinv_min_unit, fields.ResourceClass.MEMORY_MB,
|
tb.add_inventory(excl_badinv_min_unit, fields.ResourceClass.MEMORY_MB,
|
||||||
4096, max_unit=2048)
|
4096, max_unit=2048)
|
||||||
_add_inventory(excl_badinv_min_unit, fields.ResourceClass.DISK_GB,
|
tb.add_inventory(excl_badinv_min_unit, fields.ResourceClass.DISK_GB,
|
||||||
2000)
|
2000)
|
||||||
# MEMORY_MB max_unit too low
|
# MEMORY_MB max_unit too low
|
||||||
excl_badinv_max_unit = self._create_provider('badinv_max_unit')
|
excl_badinv_max_unit = self._create_provider('badinv_max_unit')
|
||||||
_add_inventory(excl_badinv_max_unit, fields.ResourceClass.VCPU, 15)
|
tb.add_inventory(excl_badinv_max_unit, fields.ResourceClass.VCPU, 15)
|
||||||
_add_inventory(excl_badinv_max_unit, fields.ResourceClass.MEMORY_MB,
|
tb.add_inventory(excl_badinv_max_unit, fields.ResourceClass.MEMORY_MB,
|
||||||
4096, max_unit=512)
|
4096, max_unit=512)
|
||||||
_add_inventory(excl_badinv_max_unit, fields.ResourceClass.DISK_GB,
|
tb.add_inventory(excl_badinv_max_unit, fields.ResourceClass.DISK_GB,
|
||||||
2000)
|
2000)
|
||||||
# DISK_GB unsuitable step_size
|
# DISK_GB unsuitable step_size
|
||||||
excl_badinv_step_size = self._create_provider('badinv_step_size')
|
excl_badinv_step_size = self._create_provider('badinv_step_size')
|
||||||
_add_inventory(excl_badinv_step_size, fields.ResourceClass.VCPU, 15)
|
tb.add_inventory(excl_badinv_step_size, fields.ResourceClass.VCPU, 15)
|
||||||
_add_inventory(excl_badinv_step_size, fields.ResourceClass.MEMORY_MB,
|
tb.add_inventory(excl_badinv_step_size, fields.ResourceClass.MEMORY_MB,
|
||||||
4096, max_unit=2048)
|
4096, max_unit=2048)
|
||||||
_add_inventory(excl_badinv_step_size, fields.ResourceClass.DISK_GB,
|
tb.add_inventory(excl_badinv_step_size, fields.ResourceClass.DISK_GB,
|
||||||
2000, step_size=7)
|
2000, step_size=7)
|
||||||
# Not enough total VCPU
|
# Not enough total VCPU
|
||||||
excl_badinv_total = self._create_provider('badinv_total')
|
excl_badinv_total = self._create_provider('badinv_total')
|
||||||
_add_inventory(excl_badinv_total, fields.ResourceClass.VCPU, 4)
|
tb.add_inventory(excl_badinv_total, fields.ResourceClass.VCPU, 4)
|
||||||
_add_inventory(excl_badinv_total, fields.ResourceClass.MEMORY_MB,
|
tb.add_inventory(excl_badinv_total, fields.ResourceClass.MEMORY_MB,
|
||||||
4096, max_unit=2048)
|
4096, max_unit=2048)
|
||||||
_add_inventory(excl_badinv_total, fields.ResourceClass.DISK_GB, 2000)
|
tb.add_inventory(excl_badinv_total, fields.ResourceClass.DISK_GB, 2000)
|
||||||
# Too much reserved MEMORY_MB
|
# Too much reserved MEMORY_MB
|
||||||
excl_badinv_reserved = self._create_provider('badinv_reserved')
|
excl_badinv_reserved = self._create_provider('badinv_reserved')
|
||||||
_add_inventory(excl_badinv_reserved, fields.ResourceClass.VCPU, 15)
|
tb.add_inventory(excl_badinv_reserved, fields.ResourceClass.VCPU, 15)
|
||||||
_add_inventory(excl_badinv_reserved, fields.ResourceClass.MEMORY_MB,
|
tb.add_inventory(excl_badinv_reserved, fields.ResourceClass.MEMORY_MB,
|
||||||
4096, max_unit=2048, reserved=3500)
|
4096, max_unit=2048, reserved=3500)
|
||||||
_add_inventory(excl_badinv_reserved, fields.ResourceClass.DISK_GB,
|
tb.add_inventory(excl_badinv_reserved, fields.ResourceClass.DISK_GB,
|
||||||
2000)
|
2000)
|
||||||
# DISK_GB allocation ratio blows it up
|
# DISK_GB allocation ratio blows it up
|
||||||
excl_badinv_alloc_ratio = self._create_provider('badinv_alloc_ratio')
|
excl_badinv_alloc_ratio = self._create_provider('badinv_alloc_ratio')
|
||||||
_add_inventory(excl_badinv_alloc_ratio, fields.ResourceClass.VCPU, 15)
|
tb.add_inventory(excl_badinv_alloc_ratio, fields.ResourceClass.VCPU,
|
||||||
_add_inventory(excl_badinv_alloc_ratio, fields.ResourceClass.MEMORY_MB,
|
15)
|
||||||
4096, max_unit=2048)
|
tb.add_inventory(excl_badinv_alloc_ratio,
|
||||||
_add_inventory(excl_badinv_alloc_ratio, fields.ResourceClass.DISK_GB,
|
fields.ResourceClass.MEMORY_MB, 4096, max_unit=2048)
|
||||||
|
tb.add_inventory(excl_badinv_alloc_ratio, fields.ResourceClass.DISK_GB,
|
||||||
2000, allocation_ratio=0.5)
|
2000, allocation_ratio=0.5)
|
||||||
|
|
||||||
# Inventory consumed in one RC, but available in the others
|
# Inventory consumed in one RC, but available in the others
|
||||||
excl_1invunavail = self._create_provider('1invunavail')
|
excl_1invunavail = self._create_provider('1invunavail')
|
||||||
_add_inventory(excl_1invunavail, fields.ResourceClass.VCPU, 10)
|
tb.add_inventory(excl_1invunavail, fields.ResourceClass.VCPU, 10)
|
||||||
_allocate_from_provider(excl_1invunavail, fields.ResourceClass.VCPU, 7)
|
tb.allocate_from_provider(excl_1invunavail, fields.ResourceClass.VCPU,
|
||||||
_add_inventory(excl_1invunavail, fields.ResourceClass.MEMORY_MB, 4096)
|
7)
|
||||||
_allocate_from_provider(excl_1invunavail,
|
tb.add_inventory(excl_1invunavail, fields.ResourceClass.MEMORY_MB,
|
||||||
|
4096)
|
||||||
|
tb.allocate_from_provider(excl_1invunavail,
|
||||||
fields.ResourceClass.MEMORY_MB, 1024)
|
fields.ResourceClass.MEMORY_MB, 1024)
|
||||||
_add_inventory(excl_1invunavail, fields.ResourceClass.DISK_GB, 2000)
|
tb.add_inventory(excl_1invunavail, fields.ResourceClass.DISK_GB, 2000)
|
||||||
_allocate_from_provider(excl_1invunavail,
|
tb.allocate_from_provider(excl_1invunavail,
|
||||||
fields.ResourceClass.DISK_GB, 400)
|
fields.ResourceClass.DISK_GB, 400)
|
||||||
|
|
||||||
# Inventory all consumed
|
# Inventory all consumed
|
||||||
excl_allused = self._create_provider('allused')
|
excl_allused = self._create_provider('allused')
|
||||||
_add_inventory(excl_allused, fields.ResourceClass.VCPU, 10)
|
tb.add_inventory(excl_allused, fields.ResourceClass.VCPU, 10)
|
||||||
_allocate_from_provider(excl_allused, fields.ResourceClass.VCPU, 7)
|
tb.allocate_from_provider(excl_allused, fields.ResourceClass.VCPU, 7)
|
||||||
_add_inventory(excl_allused, fields.ResourceClass.MEMORY_MB, 4000)
|
tb.add_inventory(excl_allused, fields.ResourceClass.MEMORY_MB, 4000)
|
||||||
_allocate_from_provider(excl_allused,
|
tb.allocate_from_provider(excl_allused,
|
||||||
fields.ResourceClass.MEMORY_MB, 1500)
|
fields.ResourceClass.MEMORY_MB, 1500)
|
||||||
_allocate_from_provider(excl_allused,
|
tb.allocate_from_provider(excl_allused,
|
||||||
fields.ResourceClass.MEMORY_MB, 2000)
|
fields.ResourceClass.MEMORY_MB, 2000)
|
||||||
_add_inventory(excl_allused, fields.ResourceClass.DISK_GB, 1500)
|
tb.add_inventory(excl_allused, fields.ResourceClass.DISK_GB, 1500)
|
||||||
_allocate_from_provider(excl_allused, fields.ResourceClass.DISK_GB, 1)
|
tb.allocate_from_provider(excl_allused, fields.ResourceClass.DISK_GB,
|
||||||
|
1)
|
||||||
|
|
||||||
# Inventory available in requested classes, but unavailable in others
|
# Inventory available in requested classes, but unavailable in others
|
||||||
incl_extra_full = self._create_provider('extra_full')
|
incl_extra_full = self._create_provider('extra_full')
|
||||||
_add_inventory(incl_extra_full, fields.ResourceClass.VCPU, 20)
|
tb.add_inventory(incl_extra_full, fields.ResourceClass.VCPU, 20)
|
||||||
_allocate_from_provider(incl_extra_full, fields.ResourceClass.VCPU, 15)
|
tb.allocate_from_provider(incl_extra_full, fields.ResourceClass.VCPU,
|
||||||
_add_inventory(incl_extra_full, fields.ResourceClass.MEMORY_MB, 4096)
|
15)
|
||||||
_allocate_from_provider(incl_extra_full,
|
tb.add_inventory(incl_extra_full, fields.ResourceClass.MEMORY_MB, 4096)
|
||||||
|
tb.allocate_from_provider(incl_extra_full,
|
||||||
fields.ResourceClass.MEMORY_MB, 1024)
|
fields.ResourceClass.MEMORY_MB, 1024)
|
||||||
_add_inventory(incl_extra_full, fields.ResourceClass.DISK_GB, 2000)
|
tb.add_inventory(incl_extra_full, fields.ResourceClass.DISK_GB, 2000)
|
||||||
_allocate_from_provider(incl_extra_full, fields.ResourceClass.DISK_GB,
|
tb.allocate_from_provider(incl_extra_full,
|
||||||
400)
|
fields.ResourceClass.DISK_GB, 400)
|
||||||
_add_inventory(incl_extra_full, fields.ResourceClass.PCI_DEVICE, 4)
|
tb.add_inventory(incl_extra_full, fields.ResourceClass.PCI_DEVICE, 4)
|
||||||
_allocate_from_provider(incl_extra_full,
|
tb.allocate_from_provider(incl_extra_full,
|
||||||
fields.ResourceClass.PCI_DEVICE, 1)
|
fields.ResourceClass.PCI_DEVICE, 1)
|
||||||
_allocate_from_provider(incl_extra_full,
|
tb.allocate_from_provider(incl_extra_full,
|
||||||
fields.ResourceClass.PCI_DEVICE, 3)
|
fields.ResourceClass.PCI_DEVICE, 3)
|
||||||
|
|
||||||
# Inventory available in a unrequested classes, not in requested ones
|
# Inventory available in a unrequested classes, not in requested ones
|
||||||
excl_extra_avail = self._create_provider('extra_avail')
|
excl_extra_avail = self._create_provider('extra_avail')
|
||||||
# Incompatible step size
|
# Incompatible step size
|
||||||
_add_inventory(excl_extra_avail, fields.ResourceClass.VCPU, 10,
|
tb.add_inventory(excl_extra_avail, fields.ResourceClass.VCPU, 10,
|
||||||
step_size=3)
|
step_size=3)
|
||||||
# Not enough left after reserved + used
|
# Not enough left after reserved + used
|
||||||
_add_inventory(excl_extra_avail, fields.ResourceClass.MEMORY_MB, 4096,
|
tb.add_inventory(excl_extra_avail, fields.ResourceClass.MEMORY_MB,
|
||||||
max_unit=2048, reserved=2048)
|
4096, max_unit=2048, reserved=2048)
|
||||||
_allocate_from_provider(excl_extra_avail,
|
tb.allocate_from_provider(excl_extra_avail,
|
||||||
fields.ResourceClass.MEMORY_MB, 1040)
|
fields.ResourceClass.MEMORY_MB, 1040)
|
||||||
# Allocation ratio math
|
# Allocation ratio math
|
||||||
_add_inventory(excl_extra_avail, fields.ResourceClass.DISK_GB, 2000,
|
tb.add_inventory(excl_extra_avail, fields.ResourceClass.DISK_GB, 2000,
|
||||||
allocation_ratio=0.5)
|
allocation_ratio=0.5)
|
||||||
_add_inventory(excl_extra_avail, fields.ResourceClass.IPV4_ADDRESS, 48)
|
tb.add_inventory(excl_extra_avail, fields.ResourceClass.IPV4_ADDRESS,
|
||||||
|
48)
|
||||||
custom_special = rp_obj.ResourceClass(self.ctx, name='CUSTOM_SPECIAL')
|
custom_special = rp_obj.ResourceClass(self.ctx, name='CUSTOM_SPECIAL')
|
||||||
custom_special.create()
|
custom_special.create()
|
||||||
_add_inventory(excl_extra_avail, 'CUSTOM_SPECIAL', 100)
|
tb.add_inventory(excl_extra_avail, 'CUSTOM_SPECIAL', 100)
|
||||||
_allocate_from_provider(excl_extra_avail, 'CUSTOM_SPECIAL', 99)
|
tb.allocate_from_provider(excl_extra_avail, 'CUSTOM_SPECIAL', 99)
|
||||||
|
|
||||||
resources = {
|
resources = {
|
||||||
fields.ResourceClass.STANDARD.index(fields.ResourceClass.VCPU): 5,
|
fields.ResourceClass.STANDARD.index(fields.ResourceClass.VCPU): 5,
|
||||||
@ -202,15 +204,16 @@ class ProviderDBHelperTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
|
|
||||||
# One trait
|
# One trait
|
||||||
cn2 = self._create_provider('cn2')
|
cn2 = self._create_provider('cn2')
|
||||||
_set_traits(cn2, 'HW_CPU_X86_TBM')
|
tb.set_traits(cn2, 'HW_CPU_X86_TBM')
|
||||||
|
|
||||||
# One the same as cn2
|
# One the same as cn2
|
||||||
cn3 = self._create_provider('cn3')
|
cn3 = self._create_provider('cn3')
|
||||||
_set_traits(cn3, 'HW_CPU_X86_TBM', 'HW_CPU_X86_TSX', 'HW_CPU_X86_SGX')
|
tb.set_traits(cn3, 'HW_CPU_X86_TBM', 'HW_CPU_X86_TSX',
|
||||||
|
'HW_CPU_X86_SGX')
|
||||||
|
|
||||||
# Disjoint
|
# Disjoint
|
||||||
cn4 = self._create_provider('cn4')
|
cn4 = self._create_provider('cn4')
|
||||||
_set_traits(cn4, 'HW_CPU_X86_SSE2', 'HW_CPU_X86_SSE3', 'CUSTOM_FOO')
|
tb.set_traits(cn4, 'HW_CPU_X86_SSE2', 'HW_CPU_X86_SSE3', 'CUSTOM_FOO')
|
||||||
|
|
||||||
# Request with no traits not allowed
|
# Request with no traits not allowed
|
||||||
self.assertRaises(
|
self.assertRaises(
|
||||||
@ -382,9 +385,9 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
allocation_requests and provider_summaries.
|
allocation_requests and provider_summaries.
|
||||||
"""
|
"""
|
||||||
cn1 = self._create_provider('cn1')
|
cn1 = self._create_provider('cn1')
|
||||||
_add_inventory(cn1, fields.ResourceClass.VCPU, 8)
|
tb.add_inventory(cn1, fields.ResourceClass.VCPU, 8)
|
||||||
_add_inventory(cn1, fields.ResourceClass.MEMORY_MB, 2048)
|
tb.add_inventory(cn1, fields.ResourceClass.MEMORY_MB, 2048)
|
||||||
_add_inventory(cn1, fields.ResourceClass.DISK_GB, 2000)
|
tb.add_inventory(cn1, fields.ResourceClass.DISK_GB, 2000)
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates([
|
alloc_cands = self._get_allocation_candidates([
|
||||||
placement_lib.RequestGroup(
|
placement_lib.RequestGroup(
|
||||||
@ -423,12 +426,12 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
cn1, cn2, cn3 = (self._create_provider(name)
|
cn1, cn2, cn3 = (self._create_provider(name)
|
||||||
for name in ('cn1', 'cn2', 'cn3'))
|
for name in ('cn1', 'cn2', 'cn3'))
|
||||||
for cn in (cn1, cn2, cn3):
|
for cn in (cn1, cn2, cn3):
|
||||||
_add_inventory(cn, fields.ResourceClass.VCPU, 24,
|
tb.add_inventory(cn, fields.ResourceClass.VCPU, 24,
|
||||||
allocation_ratio=16.0)
|
allocation_ratio=16.0)
|
||||||
_add_inventory(cn, fields.ResourceClass.MEMORY_MB, 32768,
|
tb.add_inventory(cn, fields.ResourceClass.MEMORY_MB, 32768,
|
||||||
min_unit=64, step_size=64, allocation_ratio=1.5)
|
min_unit=64, step_size=64, allocation_ratio=1.5)
|
||||||
total_gb = 1000 if cn.name == 'cn3' else 2000
|
total_gb = 1000 if cn.name == 'cn3' else 2000
|
||||||
_add_inventory(cn, fields.ResourceClass.DISK_GB, total_gb,
|
tb.add_inventory(cn, fields.ResourceClass.DISK_GB, total_gb,
|
||||||
reserved=100, min_unit=10, step_size=10,
|
reserved=100, min_unit=10, step_size=10,
|
||||||
allocation_ratio=1.0)
|
allocation_ratio=1.0)
|
||||||
|
|
||||||
@ -484,7 +487,7 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
|
|
||||||
# If we then associate the AVX2 trait to just compute node 2, we should
|
# If we then associate the AVX2 trait to just compute node 2, we should
|
||||||
# get back just that compute node in the provider summaries
|
# get back just that compute node in the provider summaries
|
||||||
_set_traits(cn2, 'HW_CPU_X86_AVX2')
|
tb.set_traits(cn2, 'HW_CPU_X86_AVX2')
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates([
|
alloc_cands = self._get_allocation_candidates([
|
||||||
placement_lib.RequestGroup(
|
placement_lib.RequestGroup(
|
||||||
@ -542,12 +545,12 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
# Create three compute node providers with VCPU, RAM and local disk
|
# Create three compute node providers with VCPU, RAM and local disk
|
||||||
for name in ('cn1', 'cn2', 'cn3'):
|
for name in ('cn1', 'cn2', 'cn3'):
|
||||||
cn = self._create_provider(name)
|
cn = self._create_provider(name)
|
||||||
_add_inventory(cn, fields.ResourceClass.VCPU, 24,
|
tb.add_inventory(cn, fields.ResourceClass.VCPU, 24,
|
||||||
allocation_ratio=16.0)
|
allocation_ratio=16.0)
|
||||||
_add_inventory(cn, fields.ResourceClass.MEMORY_MB, 32768,
|
tb.add_inventory(cn, fields.ResourceClass.MEMORY_MB, 32768,
|
||||||
min_unit=64, step_size=64, allocation_ratio=1.5)
|
min_unit=64, step_size=64, allocation_ratio=1.5)
|
||||||
total_gb = 1000 if name == 'cn3' else 2000
|
total_gb = 1000 if name == 'cn3' else 2000
|
||||||
_add_inventory(cn, fields.ResourceClass.DISK_GB, total_gb,
|
tb.add_inventory(cn, fields.ResourceClass.DISK_GB, total_gb,
|
||||||
reserved=100, min_unit=10, step_size=10,
|
reserved=100, min_unit=10, step_size=10,
|
||||||
allocation_ratio=1.0)
|
allocation_ratio=1.0)
|
||||||
|
|
||||||
@ -597,21 +600,21 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
cn1, cn2 = (self._create_provider(name, uuids.agg)
|
cn1, cn2 = (self._create_provider(name, uuids.agg)
|
||||||
for name in ('cn1', 'cn2'))
|
for name in ('cn1', 'cn2'))
|
||||||
for cn in (cn1, cn2):
|
for cn in (cn1, cn2):
|
||||||
_add_inventory(cn, fields.ResourceClass.VCPU, 24,
|
tb.add_inventory(cn, fields.ResourceClass.VCPU, 24,
|
||||||
allocation_ratio=16.0)
|
allocation_ratio=16.0)
|
||||||
_add_inventory(cn, fields.ResourceClass.MEMORY_MB, 1024,
|
tb.add_inventory(cn, fields.ResourceClass.MEMORY_MB, 1024,
|
||||||
min_unit=64, allocation_ratio=1.5)
|
min_unit=64, allocation_ratio=1.5)
|
||||||
|
|
||||||
# Create the shared storage pool, asociated with the same aggregate
|
# Create the shared storage pool, asociated with the same aggregate
|
||||||
ss = self._create_provider('shared storage', uuids.agg)
|
ss = self._create_provider('shared storage', uuids.agg)
|
||||||
|
|
||||||
# Give the shared storage pool some inventory of DISK_GB
|
# Give the shared storage pool some inventory of DISK_GB
|
||||||
_add_inventory(ss, fields.ResourceClass.DISK_GB, 2000, reserved=100,
|
tb.add_inventory(ss, fields.ResourceClass.DISK_GB, 2000, reserved=100,
|
||||||
min_unit=10)
|
min_unit=10)
|
||||||
|
|
||||||
# Mark the shared storage pool as having inventory shared among any
|
# Mark the shared storage pool as having inventory shared among any
|
||||||
# provider associated via aggregate
|
# provider associated via aggregate
|
||||||
_set_traits(ss, "MISC_SHARES_VIA_AGGREGATE")
|
tb.set_traits(ss, "MISC_SHARES_VIA_AGGREGATE")
|
||||||
|
|
||||||
# Ask for the alternative placement possibilities and verify each
|
# Ask for the alternative placement possibilities and verify each
|
||||||
# compute node provider is listed in the allocation requests as well as
|
# compute node provider is listed in the allocation requests as well as
|
||||||
@ -759,7 +762,7 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
|
|
||||||
# Require the AVX2 trait but forbid CUSTOM_EXTRA_FASTER, which is
|
# Require the AVX2 trait but forbid CUSTOM_EXTRA_FASTER, which is
|
||||||
# added to cn2
|
# added to cn2
|
||||||
_set_traits(cn2, 'CUSTOM_EXTRA_FASTER')
|
tb.set_traits(cn2, 'CUSTOM_EXTRA_FASTER')
|
||||||
alloc_cands = self._get_allocation_candidates([
|
alloc_cands = self._get_allocation_candidates([
|
||||||
placement_lib.RequestGroup(
|
placement_lib.RequestGroup(
|
||||||
use_same_provider=False,
|
use_same_provider=False,
|
||||||
@ -777,7 +780,7 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
|
|
||||||
# Add disk to cn1, forbid sharing, and require the AVX2 trait.
|
# Add disk to cn1, forbid sharing, and require the AVX2 trait.
|
||||||
# This should result in getting only cn1.
|
# This should result in getting only cn1.
|
||||||
_add_inventory(cn1, fields.ResourceClass.DISK_GB, 2048,
|
tb.add_inventory(cn1, fields.ResourceClass.DISK_GB, 2048,
|
||||||
allocation_ratio=1.5)
|
allocation_ratio=1.5)
|
||||||
alloc_cands = self._get_allocation_candidates([
|
alloc_cands = self._get_allocation_candidates([
|
||||||
placement_lib.RequestGroup(
|
placement_lib.RequestGroup(
|
||||||
@ -809,9 +812,9 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
# CUSTOM_MAGIC resources, associated with the aggregate.
|
# CUSTOM_MAGIC resources, associated with the aggregate.
|
||||||
for name in ('cn1', 'cn2'):
|
for name in ('cn1', 'cn2'):
|
||||||
cn = self._create_provider(name, agg_uuid)
|
cn = self._create_provider(name, agg_uuid)
|
||||||
_add_inventory(cn, fields.ResourceClass.VCPU, 24,
|
tb.add_inventory(cn, fields.ResourceClass.VCPU, 24,
|
||||||
allocation_ratio=16.0)
|
allocation_ratio=16.0)
|
||||||
_add_inventory(cn, fields.ResourceClass.MEMORY_MB, 1024,
|
tb.add_inventory(cn, fields.ResourceClass.MEMORY_MB, 1024,
|
||||||
min_unit=64, allocation_ratio=1.5)
|
min_unit=64, allocation_ratio=1.5)
|
||||||
|
|
||||||
# Create a custom resource called MAGIC
|
# Create a custom resource called MAGIC
|
||||||
@ -825,12 +828,12 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
# the same aggregate
|
# the same aggregate
|
||||||
magic_p = self._create_provider('shared custom resource provider',
|
magic_p = self._create_provider('shared custom resource provider',
|
||||||
agg_uuid)
|
agg_uuid)
|
||||||
_add_inventory(magic_p, magic_rc.name, 2048, reserved=1024,
|
tb.add_inventory(magic_p, magic_rc.name, 2048, reserved=1024,
|
||||||
min_unit=10)
|
min_unit=10)
|
||||||
|
|
||||||
# Mark the magic provider as having inventory shared among any provider
|
# Mark the magic provider as having inventory shared among any provider
|
||||||
# associated via aggregate
|
# associated via aggregate
|
||||||
_set_traits(magic_p, "MISC_SHARES_VIA_AGGREGATE")
|
tb.set_traits(magic_p, "MISC_SHARES_VIA_AGGREGATE")
|
||||||
|
|
||||||
# The resources we will request
|
# The resources we will request
|
||||||
requested_resources = {
|
requested_resources = {
|
||||||
@ -885,12 +888,12 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
# cn3 is not associated with the aggregate
|
# cn3 is not associated with the aggregate
|
||||||
cn3 = self._create_provider('cn3')
|
cn3 = self._create_provider('cn3')
|
||||||
for cn in (cn1, cn2, cn3):
|
for cn in (cn1, cn2, cn3):
|
||||||
_add_inventory(cn, fields.ResourceClass.VCPU, 24,
|
tb.add_inventory(cn, fields.ResourceClass.VCPU, 24,
|
||||||
allocation_ratio=16.0)
|
allocation_ratio=16.0)
|
||||||
_add_inventory(cn, fields.ResourceClass.MEMORY_MB, 1024,
|
tb.add_inventory(cn, fields.ResourceClass.MEMORY_MB, 1024,
|
||||||
min_unit=64, allocation_ratio=1.5)
|
min_unit=64, allocation_ratio=1.5)
|
||||||
# Only cn3 has disk
|
# Only cn3 has disk
|
||||||
_add_inventory(cn3, fields.ResourceClass.DISK_GB, 2000,
|
tb.add_inventory(cn3, fields.ResourceClass.DISK_GB, 2000,
|
||||||
reserved=100, min_unit=10)
|
reserved=100, min_unit=10)
|
||||||
|
|
||||||
# Create the shared storage pool in the same aggregate as the first two
|
# Create the shared storage pool in the same aggregate as the first two
|
||||||
@ -898,10 +901,10 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
ss = self._create_provider('shared storage', uuids.agg)
|
ss = self._create_provider('shared storage', uuids.agg)
|
||||||
|
|
||||||
# Give the shared storage pool some inventory of DISK_GB
|
# Give the shared storage pool some inventory of DISK_GB
|
||||||
_add_inventory(ss, fields.ResourceClass.DISK_GB, 2000, reserved=100,
|
tb.add_inventory(ss, fields.ResourceClass.DISK_GB, 2000, reserved=100,
|
||||||
min_unit=10)
|
min_unit=10)
|
||||||
|
|
||||||
_set_traits(ss, "MISC_SHARES_VIA_AGGREGATE")
|
tb.set_traits(ss, "MISC_SHARES_VIA_AGGREGATE")
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates()
|
alloc_cands = self._get_allocation_candidates()
|
||||||
|
|
||||||
@ -962,7 +965,7 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
# nodes, we should get back all compute nodes since they all now
|
# nodes, we should get back all compute nodes since they all now
|
||||||
# satisfy the required traits as well as the resource request
|
# satisfy the required traits as well as the resource request
|
||||||
for cn in (cn1, cn2, cn3):
|
for cn in (cn1, cn2, cn3):
|
||||||
_set_traits(cn, os_traits.HW_CPU_X86_AVX2)
|
tb.set_traits(cn, os_traits.HW_CPU_X86_AVX2)
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates(requests=[
|
alloc_cands = self._get_allocation_candidates(requests=[
|
||||||
placement_lib.RequestGroup(
|
placement_lib.RequestGroup(
|
||||||
@ -1009,7 +1012,8 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
# that will ONLY be satisfied by a compute node with local disk that
|
# that will ONLY be satisfied by a compute node with local disk that
|
||||||
# has SSD drives. Set this trait only on the compute node with local
|
# has SSD drives. Set this trait only on the compute node with local
|
||||||
# disk (cn3)
|
# disk (cn3)
|
||||||
_set_traits(cn3, os_traits.HW_CPU_X86_AVX2, os_traits.STORAGE_DISK_SSD)
|
tb.set_traits(cn3, os_traits.HW_CPU_X86_AVX2,
|
||||||
|
os_traits.STORAGE_DISK_SSD)
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates([
|
alloc_cands = self._get_allocation_candidates([
|
||||||
placement_lib.RequestGroup(
|
placement_lib.RequestGroup(
|
||||||
@ -1046,13 +1050,13 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
def test_common_rc(self):
|
def test_common_rc(self):
|
||||||
"""Candidates when cn and shared have inventory in the same class."""
|
"""Candidates when cn and shared have inventory in the same class."""
|
||||||
cn = self._create_provider('cn', uuids.agg1)
|
cn = self._create_provider('cn', uuids.agg1)
|
||||||
_add_inventory(cn, fields.ResourceClass.VCPU, 24)
|
tb.add_inventory(cn, fields.ResourceClass.VCPU, 24)
|
||||||
_add_inventory(cn, fields.ResourceClass.MEMORY_MB, 2048)
|
tb.add_inventory(cn, fields.ResourceClass.MEMORY_MB, 2048)
|
||||||
_add_inventory(cn, fields.ResourceClass.DISK_GB, 1600)
|
tb.add_inventory(cn, fields.ResourceClass.DISK_GB, 1600)
|
||||||
|
|
||||||
ss = self._create_provider('ss', uuids.agg1)
|
ss = self._create_provider('ss', uuids.agg1)
|
||||||
_set_traits(ss, "MISC_SHARES_VIA_AGGREGATE")
|
tb.set_traits(ss, "MISC_SHARES_VIA_AGGREGATE")
|
||||||
_add_inventory(ss, fields.ResourceClass.DISK_GB, 1600)
|
tb.add_inventory(ss, fields.ResourceClass.DISK_GB, 1600)
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates()
|
alloc_cands = self._get_allocation_candidates()
|
||||||
|
|
||||||
@ -1088,16 +1092,16 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
# use_same_provider=False
|
# use_same_provider=False
|
||||||
|
|
||||||
cn = self._create_provider('cn', uuids.agg1)
|
cn = self._create_provider('cn', uuids.agg1)
|
||||||
_add_inventory(cn, fields.ResourceClass.VCPU, 24)
|
tb.add_inventory(cn, fields.ResourceClass.VCPU, 24)
|
||||||
_add_inventory(cn, fields.ResourceClass.MEMORY_MB, 2048)
|
tb.add_inventory(cn, fields.ResourceClass.MEMORY_MB, 2048)
|
||||||
_add_inventory(cn, fields.ResourceClass.DISK_GB, 1600)
|
tb.add_inventory(cn, fields.ResourceClass.DISK_GB, 1600)
|
||||||
# The compute node's disk is SSD
|
# The compute node's disk is SSD
|
||||||
_set_traits(cn, 'HW_CPU_X86_SSE', 'STORAGE_DISK_SSD')
|
tb.set_traits(cn, 'HW_CPU_X86_SSE', 'STORAGE_DISK_SSD')
|
||||||
|
|
||||||
ss = self._create_provider('ss', uuids.agg1)
|
ss = self._create_provider('ss', uuids.agg1)
|
||||||
_add_inventory(ss, fields.ResourceClass.DISK_GB, 1600)
|
tb.add_inventory(ss, fields.ResourceClass.DISK_GB, 1600)
|
||||||
# The shared storage's disk is RAID
|
# The shared storage's disk is RAID
|
||||||
_set_traits(ss, 'MISC_SHARES_VIA_AGGREGATE', 'CUSTOM_RAID')
|
tb.set_traits(ss, 'MISC_SHARES_VIA_AGGREGATE', 'CUSTOM_RAID')
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates([
|
alloc_cands = self._get_allocation_candidates([
|
||||||
placement_lib.RequestGroup(
|
placement_lib.RequestGroup(
|
||||||
@ -1134,10 +1138,10 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
|
|
||||||
def test_only_one_sharing_provider(self):
|
def test_only_one_sharing_provider(self):
|
||||||
ss1 = self._create_provider('ss1', uuids.agg1)
|
ss1 = self._create_provider('ss1', uuids.agg1)
|
||||||
_set_traits(ss1, "MISC_SHARES_VIA_AGGREGATE")
|
tb.set_traits(ss1, "MISC_SHARES_VIA_AGGREGATE")
|
||||||
_add_inventory(ss1, fields.ResourceClass.IPV4_ADDRESS, 24)
|
tb.add_inventory(ss1, fields.ResourceClass.IPV4_ADDRESS, 24)
|
||||||
_add_inventory(ss1, fields.ResourceClass.SRIOV_NET_VF, 16)
|
tb.add_inventory(ss1, fields.ResourceClass.SRIOV_NET_VF, 16)
|
||||||
_add_inventory(ss1, fields.ResourceClass.DISK_GB, 1600)
|
tb.add_inventory(ss1, fields.ResourceClass.DISK_GB, 1600)
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates([
|
alloc_cands = self._get_allocation_candidates([
|
||||||
placement_lib.RequestGroup(
|
placement_lib.RequestGroup(
|
||||||
@ -1168,12 +1172,12 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
|
|
||||||
def test_all_sharing_providers_no_rc_overlap(self):
|
def test_all_sharing_providers_no_rc_overlap(self):
|
||||||
ss1 = self._create_provider('ss1', uuids.agg1)
|
ss1 = self._create_provider('ss1', uuids.agg1)
|
||||||
_set_traits(ss1, "MISC_SHARES_VIA_AGGREGATE")
|
tb.set_traits(ss1, "MISC_SHARES_VIA_AGGREGATE")
|
||||||
_add_inventory(ss1, fields.ResourceClass.IPV4_ADDRESS, 24)
|
tb.add_inventory(ss1, fields.ResourceClass.IPV4_ADDRESS, 24)
|
||||||
|
|
||||||
ss2 = self._create_provider('ss2', uuids.agg1)
|
ss2 = self._create_provider('ss2', uuids.agg1)
|
||||||
_set_traits(ss2, "MISC_SHARES_VIA_AGGREGATE")
|
tb.set_traits(ss2, "MISC_SHARES_VIA_AGGREGATE")
|
||||||
_add_inventory(ss2, fields.ResourceClass.DISK_GB, 1600)
|
tb.add_inventory(ss2, fields.ResourceClass.DISK_GB, 1600)
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates([
|
alloc_cands = self._get_allocation_candidates([
|
||||||
placement_lib.RequestGroup(
|
placement_lib.RequestGroup(
|
||||||
@ -1203,13 +1207,13 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
|
|
||||||
def test_all_sharing_providers_no_rc_overlap_more_classes(self):
|
def test_all_sharing_providers_no_rc_overlap_more_classes(self):
|
||||||
ss1 = self._create_provider('ss1', uuids.agg1)
|
ss1 = self._create_provider('ss1', uuids.agg1)
|
||||||
_set_traits(ss1, "MISC_SHARES_VIA_AGGREGATE")
|
tb.set_traits(ss1, "MISC_SHARES_VIA_AGGREGATE")
|
||||||
_add_inventory(ss1, fields.ResourceClass.IPV4_ADDRESS, 24)
|
tb.add_inventory(ss1, fields.ResourceClass.IPV4_ADDRESS, 24)
|
||||||
_add_inventory(ss1, fields.ResourceClass.SRIOV_NET_VF, 16)
|
tb.add_inventory(ss1, fields.ResourceClass.SRIOV_NET_VF, 16)
|
||||||
|
|
||||||
ss2 = self._create_provider('ss2', uuids.agg1)
|
ss2 = self._create_provider('ss2', uuids.agg1)
|
||||||
_set_traits(ss2, "MISC_SHARES_VIA_AGGREGATE")
|
tb.set_traits(ss2, "MISC_SHARES_VIA_AGGREGATE")
|
||||||
_add_inventory(ss2, fields.ResourceClass.DISK_GB, 1600)
|
tb.add_inventory(ss2, fields.ResourceClass.DISK_GB, 1600)
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates([
|
alloc_cands = self._get_allocation_candidates([
|
||||||
placement_lib.RequestGroup(
|
placement_lib.RequestGroup(
|
||||||
@ -1242,14 +1246,14 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
|
|
||||||
def test_all_sharing_providers(self):
|
def test_all_sharing_providers(self):
|
||||||
ss1 = self._create_provider('ss1', uuids.agg1)
|
ss1 = self._create_provider('ss1', uuids.agg1)
|
||||||
_set_traits(ss1, "MISC_SHARES_VIA_AGGREGATE")
|
tb.set_traits(ss1, "MISC_SHARES_VIA_AGGREGATE")
|
||||||
_add_inventory(ss1, fields.ResourceClass.IPV4_ADDRESS, 24)
|
tb.add_inventory(ss1, fields.ResourceClass.IPV4_ADDRESS, 24)
|
||||||
_add_inventory(ss1, fields.ResourceClass.SRIOV_NET_VF, 16)
|
tb.add_inventory(ss1, fields.ResourceClass.SRIOV_NET_VF, 16)
|
||||||
_add_inventory(ss1, fields.ResourceClass.DISK_GB, 1600)
|
tb.add_inventory(ss1, fields.ResourceClass.DISK_GB, 1600)
|
||||||
|
|
||||||
ss2 = self._create_provider('ss2', uuids.agg1)
|
ss2 = self._create_provider('ss2', uuids.agg1)
|
||||||
_set_traits(ss2, "MISC_SHARES_VIA_AGGREGATE")
|
tb.set_traits(ss2, "MISC_SHARES_VIA_AGGREGATE")
|
||||||
_add_inventory(ss2, fields.ResourceClass.DISK_GB, 1600)
|
tb.add_inventory(ss2, fields.ResourceClass.DISK_GB, 1600)
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates(requests=[
|
alloc_cands = self._get_allocation_candidates(requests=[
|
||||||
placement_lib.RequestGroup(
|
placement_lib.RequestGroup(
|
||||||
@ -1296,16 +1300,16 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
# It is different from test_mix_local_and_shared as it uses two
|
# It is different from test_mix_local_and_shared as it uses two
|
||||||
# different aggregates to connect the two CNs to the share RP
|
# different aggregates to connect the two CNs to the share RP
|
||||||
cn1 = self._create_provider('cn1', uuids.agg1)
|
cn1 = self._create_provider('cn1', uuids.agg1)
|
||||||
_add_inventory(cn1, fields.ResourceClass.VCPU, 24)
|
tb.add_inventory(cn1, fields.ResourceClass.VCPU, 24)
|
||||||
_add_inventory(cn1, fields.ResourceClass.MEMORY_MB, 2048)
|
tb.add_inventory(cn1, fields.ResourceClass.MEMORY_MB, 2048)
|
||||||
|
|
||||||
cn2 = self._create_provider('cn2', uuids.agg2)
|
cn2 = self._create_provider('cn2', uuids.agg2)
|
||||||
_add_inventory(cn2, fields.ResourceClass.VCPU, 24)
|
tb.add_inventory(cn2, fields.ResourceClass.VCPU, 24)
|
||||||
_add_inventory(cn2, fields.ResourceClass.MEMORY_MB, 2048)
|
tb.add_inventory(cn2, fields.ResourceClass.MEMORY_MB, 2048)
|
||||||
|
|
||||||
ss1 = self._create_provider('ss1', uuids.agg1, uuids.agg2)
|
ss1 = self._create_provider('ss1', uuids.agg1, uuids.agg2)
|
||||||
_set_traits(ss1, "MISC_SHARES_VIA_AGGREGATE")
|
tb.set_traits(ss1, "MISC_SHARES_VIA_AGGREGATE")
|
||||||
_add_inventory(ss1, fields.ResourceClass.DISK_GB, 1600)
|
tb.add_inventory(ss1, fields.ResourceClass.DISK_GB, 1600)
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates([
|
alloc_cands = self._get_allocation_candidates([
|
||||||
placement_lib.RequestGroup(
|
placement_lib.RequestGroup(
|
||||||
@ -1344,27 +1348,27 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
# / agg3 \ agg1 / agg1 \ agg2
|
# / agg3 \ agg1 / agg1 \ agg2
|
||||||
# SS3 (IPV4) SS1 (DISK_GB) SS2 (IPV4)
|
# SS3 (IPV4) SS1 (DISK_GB) SS2 (IPV4)
|
||||||
cn1 = self._create_provider('cn1', uuids.agg1, uuids.agg3)
|
cn1 = self._create_provider('cn1', uuids.agg1, uuids.agg3)
|
||||||
_add_inventory(cn1, fields.ResourceClass.VCPU, 24)
|
tb.add_inventory(cn1, fields.ResourceClass.VCPU, 24)
|
||||||
_add_inventory(cn1, fields.ResourceClass.MEMORY_MB, 2048)
|
tb.add_inventory(cn1, fields.ResourceClass.MEMORY_MB, 2048)
|
||||||
|
|
||||||
cn2 = self._create_provider('cn2', uuids.agg1, uuids.agg2)
|
cn2 = self._create_provider('cn2', uuids.agg1, uuids.agg2)
|
||||||
_add_inventory(cn2, fields.ResourceClass.VCPU, 24)
|
tb.add_inventory(cn2, fields.ResourceClass.VCPU, 24)
|
||||||
_add_inventory(cn2, fields.ResourceClass.MEMORY_MB, 2048)
|
tb.add_inventory(cn2, fields.ResourceClass.MEMORY_MB, 2048)
|
||||||
|
|
||||||
# ss1 is connected to both cn1 and cn2
|
# ss1 is connected to both cn1 and cn2
|
||||||
ss1 = self._create_provider('ss1', uuids.agg1)
|
ss1 = self._create_provider('ss1', uuids.agg1)
|
||||||
_set_traits(ss1, "MISC_SHARES_VIA_AGGREGATE")
|
tb.set_traits(ss1, "MISC_SHARES_VIA_AGGREGATE")
|
||||||
_add_inventory(ss1, fields.ResourceClass.DISK_GB, 1600)
|
tb.add_inventory(ss1, fields.ResourceClass.DISK_GB, 1600)
|
||||||
|
|
||||||
# ss2 only connected to cn2
|
# ss2 only connected to cn2
|
||||||
ss2 = self._create_provider('ss2', uuids.agg2)
|
ss2 = self._create_provider('ss2', uuids.agg2)
|
||||||
_set_traits(ss2, "MISC_SHARES_VIA_AGGREGATE")
|
tb.set_traits(ss2, "MISC_SHARES_VIA_AGGREGATE")
|
||||||
_add_inventory(ss2, fields.ResourceClass.IPV4_ADDRESS, 24)
|
tb.add_inventory(ss2, fields.ResourceClass.IPV4_ADDRESS, 24)
|
||||||
|
|
||||||
# ss3 only connected to cn1
|
# ss3 only connected to cn1
|
||||||
ss3 = self._create_provider('ss3', uuids.agg3)
|
ss3 = self._create_provider('ss3', uuids.agg3)
|
||||||
_set_traits(ss3, "MISC_SHARES_VIA_AGGREGATE")
|
tb.set_traits(ss3, "MISC_SHARES_VIA_AGGREGATE")
|
||||||
_add_inventory(ss3, fields.ResourceClass.IPV4_ADDRESS, 24)
|
tb.add_inventory(ss3, fields.ResourceClass.IPV4_ADDRESS, 24)
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates([
|
alloc_cands = self._get_allocation_candidates([
|
||||||
placement_lib.RequestGroup(
|
placement_lib.RequestGroup(
|
||||||
@ -1412,12 +1416,12 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
# ss1(DISK) a sharing RP that also has some of the resources
|
# ss1(DISK) a sharing RP that also has some of the resources
|
||||||
# (common-RC split case)
|
# (common-RC split case)
|
||||||
cn1 = self._create_provider('cn1', uuids.agg1)
|
cn1 = self._create_provider('cn1', uuids.agg1)
|
||||||
_add_inventory(cn1, fields.ResourceClass.VCPU, 24)
|
tb.add_inventory(cn1, fields.ResourceClass.VCPU, 24)
|
||||||
_add_inventory(cn1, fields.ResourceClass.MEMORY_MB, 2048)
|
tb.add_inventory(cn1, fields.ResourceClass.MEMORY_MB, 2048)
|
||||||
_add_inventory(cn1, fields.ResourceClass.DISK_GB, 2000)
|
tb.add_inventory(cn1, fields.ResourceClass.DISK_GB, 2000)
|
||||||
ss1 = self._create_provider('ss1', uuids.agg1)
|
ss1 = self._create_provider('ss1', uuids.agg1)
|
||||||
_add_inventory(ss1, fields.ResourceClass.DISK_GB, 2000)
|
tb.add_inventory(ss1, fields.ResourceClass.DISK_GB, 2000)
|
||||||
_set_traits(ss1, 'MISC_SHARES_VIA_AGGREGATE')
|
tb.set_traits(ss1, 'MISC_SHARES_VIA_AGGREGATE')
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates()
|
alloc_cands = self._get_allocation_candidates()
|
||||||
expected = [
|
expected = [
|
||||||
@ -1454,20 +1458,20 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
# ss2_1(MEM) ss2_2(DISK) with different resources.
|
# ss2_1(MEM) ss2_2(DISK) with different resources.
|
||||||
|
|
||||||
cn1 = self._create_provider('cn1', uuids.agg1)
|
cn1 = self._create_provider('cn1', uuids.agg1)
|
||||||
_add_inventory(cn1, fields.ResourceClass.VCPU, 24)
|
tb.add_inventory(cn1, fields.ResourceClass.VCPU, 24)
|
||||||
_add_inventory(cn1, fields.ResourceClass.MEMORY_MB, 2048)
|
tb.add_inventory(cn1, fields.ResourceClass.MEMORY_MB, 2048)
|
||||||
ss1 = self._create_provider('ss1', uuids.agg1)
|
ss1 = self._create_provider('ss1', uuids.agg1)
|
||||||
_add_inventory(ss1, fields.ResourceClass.DISK_GB, 2000)
|
tb.add_inventory(ss1, fields.ResourceClass.DISK_GB, 2000)
|
||||||
_set_traits(ss1, 'MISC_SHARES_VIA_AGGREGATE')
|
tb.set_traits(ss1, 'MISC_SHARES_VIA_AGGREGATE')
|
||||||
|
|
||||||
cn2 = self._create_provider('cn2', uuids.agg2)
|
cn2 = self._create_provider('cn2', uuids.agg2)
|
||||||
_add_inventory(cn2, fields.ResourceClass.VCPU, 24)
|
tb.add_inventory(cn2, fields.ResourceClass.VCPU, 24)
|
||||||
ss2_1 = self._create_provider('ss2_1', uuids.agg2)
|
ss2_1 = self._create_provider('ss2_1', uuids.agg2)
|
||||||
_add_inventory(ss2_1, fields.ResourceClass.MEMORY_MB, 2048)
|
tb.add_inventory(ss2_1, fields.ResourceClass.MEMORY_MB, 2048)
|
||||||
_set_traits(ss2_1, 'MISC_SHARES_VIA_AGGREGATE')
|
tb.set_traits(ss2_1, 'MISC_SHARES_VIA_AGGREGATE')
|
||||||
ss2_2 = self._create_provider('ss2_2', uuids.agg2)
|
ss2_2 = self._create_provider('ss2_2', uuids.agg2)
|
||||||
_add_inventory(ss2_2, fields.ResourceClass.DISK_GB, 2000)
|
tb.add_inventory(ss2_2, fields.ResourceClass.DISK_GB, 2000)
|
||||||
_set_traits(ss2_2, 'MISC_SHARES_VIA_AGGREGATE')
|
tb.set_traits(ss2_2, 'MISC_SHARES_VIA_AGGREGATE')
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates()
|
alloc_cands = self._get_allocation_candidates()
|
||||||
expected = [
|
expected = [
|
||||||
@ -1511,23 +1515,23 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
# ss2_1(MEM) ss2_2(DISK) with different resources.
|
# ss2_1(MEM) ss2_2(DISK) with different resources.
|
||||||
|
|
||||||
cn1 = self._create_provider('cn1', uuids.agg1)
|
cn1 = self._create_provider('cn1', uuids.agg1)
|
||||||
_add_inventory(cn1, fields.ResourceClass.VCPU, 24)
|
tb.add_inventory(cn1, fields.ResourceClass.VCPU, 24)
|
||||||
_add_inventory(cn1, fields.ResourceClass.MEMORY_MB, 2048)
|
tb.add_inventory(cn1, fields.ResourceClass.MEMORY_MB, 2048)
|
||||||
ss1_1 = self._create_provider('ss1_1', uuids.agg1)
|
ss1_1 = self._create_provider('ss1_1', uuids.agg1)
|
||||||
_add_inventory(ss1_1, fields.ResourceClass.DISK_GB, 2000)
|
tb.add_inventory(ss1_1, fields.ResourceClass.DISK_GB, 2000)
|
||||||
_set_traits(ss1_1, 'MISC_SHARES_VIA_AGGREGATE')
|
tb.set_traits(ss1_1, 'MISC_SHARES_VIA_AGGREGATE')
|
||||||
ss1_2 = self._create_provider('ss1_2', uuids.agg1)
|
ss1_2 = self._create_provider('ss1_2', uuids.agg1)
|
||||||
_add_inventory(ss1_2, fields.ResourceClass.DISK_GB, 2000)
|
tb.add_inventory(ss1_2, fields.ResourceClass.DISK_GB, 2000)
|
||||||
_set_traits(ss1_2, 'MISC_SHARES_VIA_AGGREGATE')
|
tb.set_traits(ss1_2, 'MISC_SHARES_VIA_AGGREGATE')
|
||||||
|
|
||||||
cn2 = self._create_provider('cn2', uuids.agg2)
|
cn2 = self._create_provider('cn2', uuids.agg2)
|
||||||
_add_inventory(cn2, fields.ResourceClass.VCPU, 24)
|
tb.add_inventory(cn2, fields.ResourceClass.VCPU, 24)
|
||||||
ss2_1 = self._create_provider('ss2_1', uuids.agg2)
|
ss2_1 = self._create_provider('ss2_1', uuids.agg2)
|
||||||
_add_inventory(ss2_1, fields.ResourceClass.MEMORY_MB, 2048)
|
tb.add_inventory(ss2_1, fields.ResourceClass.MEMORY_MB, 2048)
|
||||||
_set_traits(ss2_1, 'MISC_SHARES_VIA_AGGREGATE')
|
tb.set_traits(ss2_1, 'MISC_SHARES_VIA_AGGREGATE')
|
||||||
ss2_2 = self._create_provider('ss2_2', uuids.agg2)
|
ss2_2 = self._create_provider('ss2_2', uuids.agg2)
|
||||||
_add_inventory(ss2_2, fields.ResourceClass.DISK_GB, 2000)
|
tb.add_inventory(ss2_2, fields.ResourceClass.DISK_GB, 2000)
|
||||||
_set_traits(ss2_2, 'MISC_SHARES_VIA_AGGREGATE')
|
tb.set_traits(ss2_2, 'MISC_SHARES_VIA_AGGREGATE')
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates()
|
alloc_cands = self._get_allocation_candidates()
|
||||||
expected = [
|
expected = [
|
||||||
@ -1597,17 +1601,17 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
# the only PF that has the required trait has no inventory left.
|
# the only PF that has the required trait has no inventory left.
|
||||||
cn = self._create_provider('cn')
|
cn = self._create_provider('cn')
|
||||||
|
|
||||||
_add_inventory(cn, fields.ResourceClass.VCPU, 16)
|
tb.add_inventory(cn, fields.ResourceClass.VCPU, 16)
|
||||||
_add_inventory(cn, fields.ResourceClass.MEMORY_MB, 32768)
|
tb.add_inventory(cn, fields.ResourceClass.MEMORY_MB, 32768)
|
||||||
|
|
||||||
numa_cell0 = self._create_provider('cn_numa0', parent=cn.uuid)
|
numa_cell0 = self._create_provider('cn_numa0', parent=cn.uuid)
|
||||||
numa_cell1 = self._create_provider('cn_numa1', parent=cn.uuid)
|
numa_cell1 = self._create_provider('cn_numa1', parent=cn.uuid)
|
||||||
|
|
||||||
pf0 = self._create_provider('cn_numa0_pf0', parent=numa_cell0.uuid)
|
pf0 = self._create_provider('cn_numa0_pf0', parent=numa_cell0.uuid)
|
||||||
_add_inventory(pf0, fields.ResourceClass.SRIOV_NET_VF, 8)
|
tb.add_inventory(pf0, fields.ResourceClass.SRIOV_NET_VF, 8)
|
||||||
pf1 = self._create_provider('cn_numa1_pf1', parent=numa_cell1.uuid)
|
pf1 = self._create_provider('cn_numa1_pf1', parent=numa_cell1.uuid)
|
||||||
_add_inventory(pf1, fields.ResourceClass.SRIOV_NET_VF, 8)
|
tb.add_inventory(pf1, fields.ResourceClass.SRIOV_NET_VF, 8)
|
||||||
_set_traits(pf1, os_traits.HW_NIC_OFFLOAD_GENEVE)
|
tb.set_traits(pf1, os_traits.HW_NIC_OFFLOAD_GENEVE)
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates([
|
alloc_cands = self._get_allocation_candidates([
|
||||||
placement_lib.RequestGroup(
|
placement_lib.RequestGroup(
|
||||||
@ -1724,7 +1728,7 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
# function (the one with HW_NIC_OFFLOAD_GENEVE associated with it) and
|
# function (the one with HW_NIC_OFFLOAD_GENEVE associated with it) and
|
||||||
# verify that the same request still results in 0 results since the
|
# verify that the same request still results in 0 results since the
|
||||||
# function with the required trait no longer has any inventory.
|
# function with the required trait no longer has any inventory.
|
||||||
_allocate_from_provider(pf1, fields.ResourceClass.SRIOV_NET_VF, 8)
|
tb.allocate_from_provider(pf1, fields.ResourceClass.SRIOV_NET_VF, 8)
|
||||||
|
|
||||||
alloc_cands = self._get_allocation_candidates([
|
alloc_cands = self._get_allocation_candidates([
|
||||||
placement_lib.RequestGroup(
|
placement_lib.RequestGroup(
|
||||||
@ -1795,8 +1799,8 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
cn_names.append(cn_name)
|
cn_names.append(cn_name)
|
||||||
cn = self._create_provider(name)
|
cn = self._create_provider(name)
|
||||||
|
|
||||||
_add_inventory(cn, fields.ResourceClass.VCPU, 16)
|
tb.add_inventory(cn, fields.ResourceClass.VCPU, 16)
|
||||||
_add_inventory(cn, fields.ResourceClass.MEMORY_MB, 32768)
|
tb.add_inventory(cn, fields.ResourceClass.MEMORY_MB, 32768)
|
||||||
|
|
||||||
name = 'cn' + x + '_numa0'
|
name = 'cn' + x + '_numa0'
|
||||||
numa_cell0 = self._create_provider(name, parent=cn.uuid)
|
numa_cell0 = self._create_provider(name, parent=cn.uuid)
|
||||||
@ -1805,19 +1809,19 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
|
|
||||||
name = 'cn' + x + '_numa0_pf0'
|
name = 'cn' + x + '_numa0_pf0'
|
||||||
pf0 = self._create_provider(name, parent=numa_cell0.uuid)
|
pf0 = self._create_provider(name, parent=numa_cell0.uuid)
|
||||||
_add_inventory(pf0, fields.ResourceClass.SRIOV_NET_VF, 8)
|
tb.add_inventory(pf0, fields.ResourceClass.SRIOV_NET_VF, 8)
|
||||||
name = 'cn' + x + '_numa1_pf1'
|
name = 'cn' + x + '_numa1_pf1'
|
||||||
pf1 = self._create_provider(name, parent=numa_cell1.uuid)
|
pf1 = self._create_provider(name, parent=numa_cell1.uuid)
|
||||||
_add_inventory(pf1, fields.ResourceClass.SRIOV_NET_VF, 8)
|
tb.add_inventory(pf1, fields.ResourceClass.SRIOV_NET_VF, 8)
|
||||||
# Mark only the second PF on the third compute node as having
|
# Mark only the second PF on the third compute node as having
|
||||||
# GENEVE offload enabled
|
# GENEVE offload enabled
|
||||||
if x == '3':
|
if x == '3':
|
||||||
_set_traits(pf1, os_traits.HW_NIC_OFFLOAD_GENEVE)
|
tb.set_traits(pf1, os_traits.HW_NIC_OFFLOAD_GENEVE)
|
||||||
# Doesn't really make a whole lot of logical sense, but allows
|
# Doesn't really make a whole lot of logical sense, but allows
|
||||||
# us to test situations where the same trait is associated with
|
# us to test situations where the same trait is associated with
|
||||||
# multiple providers in the same tree and one of the providers
|
# multiple providers in the same tree and one of the providers
|
||||||
# has inventory we will use...
|
# has inventory we will use...
|
||||||
_set_traits(cn, os_traits.HW_NIC_OFFLOAD_GENEVE)
|
tb.set_traits(cn, os_traits.HW_NIC_OFFLOAD_GENEVE)
|
||||||
|
|
||||||
trees = rp_obj._get_trees_matching_all(
|
trees = rp_obj._get_trees_matching_all(
|
||||||
self.ctx, resources, req_traits, forbidden_traits, member_of)
|
self.ctx, resources, req_traits, forbidden_traits, member_of)
|
||||||
@ -1831,11 +1835,13 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
# _get_trees_matching_all()
|
# _get_trees_matching_all()
|
||||||
cn2_pf0 = rp_obj.ResourceProvider.get_by_uuid(self.ctx,
|
cn2_pf0 = rp_obj.ResourceProvider.get_by_uuid(self.ctx,
|
||||||
uuids.cn2_numa0_pf0)
|
uuids.cn2_numa0_pf0)
|
||||||
_allocate_from_provider(cn2_pf0, fields.ResourceClass.SRIOV_NET_VF, 8)
|
tb.allocate_from_provider(cn2_pf0, fields.ResourceClass.SRIOV_NET_VF,
|
||||||
|
8)
|
||||||
|
|
||||||
cn2_pf1 = rp_obj.ResourceProvider.get_by_uuid(self.ctx,
|
cn2_pf1 = rp_obj.ResourceProvider.get_by_uuid(self.ctx,
|
||||||
uuids.cn2_numa1_pf1)
|
uuids.cn2_numa1_pf1)
|
||||||
_allocate_from_provider(cn2_pf1, fields.ResourceClass.SRIOV_NET_VF, 8)
|
tb.allocate_from_provider(cn2_pf1, fields.ResourceClass.SRIOV_NET_VF,
|
||||||
|
8)
|
||||||
|
|
||||||
trees = rp_obj._get_trees_matching_all(
|
trees = rp_obj._get_trees_matching_all(
|
||||||
self.ctx, resources, req_traits, forbidden_traits, member_of)
|
self.ctx, resources, req_traits, forbidden_traits, member_of)
|
||||||
@ -1903,18 +1909,22 @@ class AllocationCandidatesTestCase(tb.PlacementDbBaseTestCase):
|
|||||||
# no more providers are returned
|
# no more providers are returned
|
||||||
cn1_pf0 = rp_obj.ResourceProvider.get_by_uuid(self.ctx,
|
cn1_pf0 = rp_obj.ResourceProvider.get_by_uuid(self.ctx,
|
||||||
uuids.cn1_numa0_pf0)
|
uuids.cn1_numa0_pf0)
|
||||||
_allocate_from_provider(cn1_pf0, fields.ResourceClass.SRIOV_NET_VF, 8)
|
tb.allocate_from_provider(
|
||||||
|
cn1_pf0, fields.ResourceClass.SRIOV_NET_VF, 8)
|
||||||
|
|
||||||
cn1_pf1 = rp_obj.ResourceProvider.get_by_uuid(self.ctx,
|
cn1_pf1 = rp_obj.ResourceProvider.get_by_uuid(self.ctx,
|
||||||
uuids.cn1_numa1_pf1)
|
uuids.cn1_numa1_pf1)
|
||||||
_allocate_from_provider(cn1_pf1, fields.ResourceClass.SRIOV_NET_VF, 8)
|
tb.allocate_from_provider(
|
||||||
|
cn1_pf1, fields.ResourceClass.SRIOV_NET_VF, 8)
|
||||||
cn3_pf0 = rp_obj.ResourceProvider.get_by_uuid(self.ctx,
|
cn3_pf0 = rp_obj.ResourceProvider.get_by_uuid(self.ctx,
|
||||||
uuids.cn3_numa0_pf0)
|
uuids.cn3_numa0_pf0)
|
||||||
_allocate_from_provider(cn3_pf0, fields.ResourceClass.SRIOV_NET_VF, 8)
|
tb.allocate_from_provider(
|
||||||
|
cn3_pf0, fields.ResourceClass.SRIOV_NET_VF, 8)
|
||||||
|
|
||||||
cn3_pf1 = rp_obj.ResourceProvider.get_by_uuid(self.ctx,
|
cn3_pf1 = rp_obj.ResourceProvider.get_by_uuid(self.ctx,
|
||||||
uuids.cn3_numa1_pf1)
|
uuids.cn3_numa1_pf1)
|
||||||
_allocate_from_provider(cn3_pf1, fields.ResourceClass.SRIOV_NET_VF, 8)
|
tb.allocate_from_provider(
|
||||||
|
cn3_pf1, fields.ResourceClass.SRIOV_NET_VF, 8)
|
||||||
|
|
||||||
trees = rp_obj._get_trees_matching_all(
|
trees = rp_obj._get_trees_matching_all(
|
||||||
self.ctx, resources, req_traits, forbidden_traits, member_of)
|
self.ctx, resources, req_traits, forbidden_traits, member_of)
|
||||||
|
@ -22,7 +22,7 @@ from nova.tests import fixtures
|
|||||||
from nova.tests import uuidsentinel as uuids
|
from nova.tests import uuidsentinel as uuids
|
||||||
|
|
||||||
|
|
||||||
def _add_inventory(rp, rc, total, **kwargs):
|
def add_inventory(rp, rc, total, **kwargs):
|
||||||
kwargs.setdefault('max_unit', total)
|
kwargs.setdefault('max_unit', total)
|
||||||
inv = rp_obj.Inventory(rp._context, resource_provider=rp,
|
inv = rp_obj.Inventory(rp._context, resource_provider=rp,
|
||||||
resource_class=rc, total=total, **kwargs)
|
resource_class=rc, total=total, **kwargs)
|
||||||
@ -30,7 +30,7 @@ def _add_inventory(rp, rc, total, **kwargs):
|
|||||||
rp.add_inventory(inv)
|
rp.add_inventory(inv)
|
||||||
|
|
||||||
|
|
||||||
def _set_traits(rp, *traits):
|
def set_traits(rp, *traits):
|
||||||
tlist = []
|
tlist = []
|
||||||
for tname in traits:
|
for tname in traits:
|
||||||
try:
|
try:
|
||||||
@ -42,7 +42,7 @@ def _set_traits(rp, *traits):
|
|||||||
rp.set_traits(rp_obj.TraitList(objects=tlist))
|
rp.set_traits(rp_obj.TraitList(objects=tlist))
|
||||||
|
|
||||||
|
|
||||||
def _allocate_from_provider(rp, rc, used):
|
def allocate_from_provider(rp, rc, used):
|
||||||
# NOTE(efried): Always use a random consumer UUID - we don't want to
|
# NOTE(efried): Always use a random consumer UUID - we don't want to
|
||||||
# override any existing allocations from the test case.
|
# override any existing allocations from the test case.
|
||||||
rp_obj.AllocationList(
|
rp_obj.AllocationList(
|
||||||
|
Loading…
Reference in New Issue
Block a user