Add new configuration test in sanity check: vf_extended_management
This test will check if 'ip link' version installed in this server supports extended VF management parameter 'min_tx_rate'. This parameter set the minimum egress rate for an interface. This test is executed when SR-IOV back-end and QoS extension are enabled. DocImpact Partial-Bug: #1560963 Change-Id: Ie9334f4ad2f6b047bf56689edf3333a8a612364a
This commit is contained in:
parent
60325f4ae9
commit
a2dc3c35e3
@ -41,6 +41,7 @@ class IpLinkConstants(object):
|
|||||||
IP_LINK_CAPABILITY_STATE = "state"
|
IP_LINK_CAPABILITY_STATE = "state"
|
||||||
IP_LINK_CAPABILITY_VLAN = "vlan"
|
IP_LINK_CAPABILITY_VLAN = "vlan"
|
||||||
IP_LINK_CAPABILITY_RATE = "rate"
|
IP_LINK_CAPABILITY_RATE = "rate"
|
||||||
|
IP_LINK_CAPABILITY_MIN_TX_RATE = "min_tx_rate"
|
||||||
IP_LINK_CAPABILITY_SPOOFCHK = "spoofchk"
|
IP_LINK_CAPABILITY_SPOOFCHK = "spoofchk"
|
||||||
IP_LINK_SUB_CAPABILITY_QOS = "qos"
|
IP_LINK_SUB_CAPABILITY_QOS = "qos"
|
||||||
|
|
||||||
|
@ -144,12 +144,8 @@ def icmpv6_header_match_supported():
|
|||||||
actions="NORMAL")
|
actions="NORMAL")
|
||||||
|
|
||||||
|
|
||||||
def vf_management_supported():
|
def _vf_management_support(required_caps):
|
||||||
is_supported = True
|
is_supported = True
|
||||||
required_caps = (
|
|
||||||
ip_link_support.IpLinkConstants.IP_LINK_CAPABILITY_STATE,
|
|
||||||
ip_link_support.IpLinkConstants.IP_LINK_CAPABILITY_SPOOFCHK,
|
|
||||||
ip_link_support.IpLinkConstants.IP_LINK_CAPABILITY_RATE)
|
|
||||||
try:
|
try:
|
||||||
vf_section = ip_link_support.IpLinkSupport.get_vf_mgmt_section()
|
vf_section = ip_link_support.IpLinkSupport.get_vf_mgmt_section()
|
||||||
for cap in required_caps:
|
for cap in required_caps:
|
||||||
@ -165,6 +161,24 @@ def vf_management_supported():
|
|||||||
return is_supported
|
return is_supported
|
||||||
|
|
||||||
|
|
||||||
|
def vf_management_supported():
|
||||||
|
required_caps = (
|
||||||
|
ip_link_support.IpLinkConstants.IP_LINK_CAPABILITY_STATE,
|
||||||
|
ip_link_support.IpLinkConstants.IP_LINK_CAPABILITY_SPOOFCHK,
|
||||||
|
ip_link_support.IpLinkConstants.IP_LINK_CAPABILITY_RATE)
|
||||||
|
return _vf_management_support(required_caps)
|
||||||
|
|
||||||
|
|
||||||
|
def vf_extended_management_supported():
|
||||||
|
required_caps = (
|
||||||
|
ip_link_support.IpLinkConstants.IP_LINK_CAPABILITY_STATE,
|
||||||
|
ip_link_support.IpLinkConstants.IP_LINK_CAPABILITY_SPOOFCHK,
|
||||||
|
ip_link_support.IpLinkConstants.IP_LINK_CAPABILITY_RATE,
|
||||||
|
ip_link_support.IpLinkConstants.IP_LINK_CAPABILITY_MIN_TX_RATE,
|
||||||
|
)
|
||||||
|
return _vf_management_support(required_caps)
|
||||||
|
|
||||||
|
|
||||||
def netns_read_requires_helper():
|
def netns_read_requires_helper():
|
||||||
ipw = ip_lib.IPWrapper()
|
ipw = ip_lib.IPWrapper()
|
||||||
nsname = "netnsreadtest-" + uuidutils.generate_uuid()
|
nsname = "netnsreadtest-" + uuidutils.generate_uuid()
|
||||||
|
@ -185,6 +185,16 @@ def check_vf_management():
|
|||||||
return result
|
return result
|
||||||
|
|
||||||
|
|
||||||
|
def check_vf_extended_management():
|
||||||
|
result = checks.vf_extended_management_supported()
|
||||||
|
if not result:
|
||||||
|
LOG.error(_LE('Check for VF extended management support failed. '
|
||||||
|
'Please ensure that the version of ip link '
|
||||||
|
'being used has VF extended support: version '
|
||||||
|
'"iproute2-ss140804", git tag "v3.16.0"'))
|
||||||
|
return result
|
||||||
|
|
||||||
|
|
||||||
def check_ovsdb_native():
|
def check_ovsdb_native():
|
||||||
cfg.CONF.set_override('ovsdb_interface', 'native', group='OVS')
|
cfg.CONF.set_override('ovsdb_interface', 'native', group='OVS')
|
||||||
result = checks.ovsdb_native_supported()
|
result = checks.ovsdb_native_supported()
|
||||||
@ -248,6 +258,8 @@ OPTS = [
|
|||||||
help=_('Check for ICMPv6 header match support')),
|
help=_('Check for ICMPv6 header match support')),
|
||||||
BoolOptCallback('vf_management', check_vf_management,
|
BoolOptCallback('vf_management', check_vf_management,
|
||||||
help=_('Check for VF management support')),
|
help=_('Check for VF management support')),
|
||||||
|
BoolOptCallback('vf_extended_management', check_vf_extended_management,
|
||||||
|
help=_('Check for VF extended management support')),
|
||||||
BoolOptCallback('read_netns', check_read_netns,
|
BoolOptCallback('read_netns', check_read_netns,
|
||||||
help=_('Check netns permission settings')),
|
help=_('Check netns permission settings')),
|
||||||
BoolOptCallback('dnsmasq_version', check_dnsmasq_version,
|
BoolOptCallback('dnsmasq_version', check_dnsmasq_version,
|
||||||
@ -307,6 +319,9 @@ def enable_tests_from_config():
|
|||||||
cfg.CONF.set_default('ipset_installed', True)
|
cfg.CONF.set_default('ipset_installed', True)
|
||||||
if cfg.CONF.SECURITYGROUP.enable_security_group:
|
if cfg.CONF.SECURITYGROUP.enable_security_group:
|
||||||
cfg.CONF.set_default('ip6tables_installed', True)
|
cfg.CONF.set_default('ip6tables_installed', True)
|
||||||
|
if ('sriovnicswitch' in cfg.CONF.ml2.mechanism_drivers and
|
||||||
|
'qos' in cfg.CONF.ml2.extension_drivers):
|
||||||
|
cfg.CONF.set_default('vf_extended_management', True)
|
||||||
|
|
||||||
|
|
||||||
def all_tests_passed():
|
def all_tests_passed():
|
||||||
|
@ -77,6 +77,9 @@ class SanityTestCaseRoot(functional_base.BaseSudoTestCase):
|
|||||||
def test_vf_management_runs(self):
|
def test_vf_management_runs(self):
|
||||||
checks.vf_management_supported()
|
checks.vf_management_supported()
|
||||||
|
|
||||||
|
def test_vf_extended_management_runs(self):
|
||||||
|
checks.vf_extended_management_supported()
|
||||||
|
|
||||||
def test_namespace_root_read_detection_runs(self):
|
def test_namespace_root_read_detection_runs(self):
|
||||||
checks.netns_read_requires_helper()
|
checks.netns_read_requires_helper()
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user