Merge "NSX: return 400 if dscp set for trusted queue"
This commit is contained in:
commit
d00ea0727b
@ -288,8 +288,11 @@ class QoSDbMixin(qos.QueuePluginBase):
|
|||||||
raise qos.DefaultQueueCreateNotAdmin()
|
raise qos.DefaultQueueCreateNotAdmin()
|
||||||
if qos_queue.get('qos_marking') == 'trusted':
|
if qos_queue.get('qos_marking') == 'trusted':
|
||||||
dscp = qos_queue.pop('dscp')
|
dscp = qos_queue.pop('dscp')
|
||||||
|
if dscp:
|
||||||
|
# must raise because a non-zero dscp was provided
|
||||||
|
raise qos.QueueInvalidMarking()
|
||||||
LOG.info(_("DSCP value (%s) will be ignored with 'trusted' "
|
LOG.info(_("DSCP value (%s) will be ignored with 'trusted' "
|
||||||
"marking"), dscp)
|
"marking"), dscp)
|
||||||
max = qos_queue.get('max')
|
max = qos_queue.get('max')
|
||||||
min = qos_queue.get('min')
|
min = qos_queue.get('min')
|
||||||
# Max can be None
|
# Max can be None
|
||||||
|
@ -43,6 +43,11 @@ class QueueInvalidDscp(qexception.InvalidInput):
|
|||||||
" between 0 and 63.")
|
" between 0 and 63.")
|
||||||
|
|
||||||
|
|
||||||
|
class QueueInvalidMarking(qexception.InvalidInput):
|
||||||
|
message = _("The qos marking cannot be set to 'trusted' "
|
||||||
|
"when the DSCP field is set")
|
||||||
|
|
||||||
|
|
||||||
class QueueMinGreaterMax(qexception.InvalidInput):
|
class QueueMinGreaterMax(qexception.InvalidInput):
|
||||||
message = _("Invalid bandwidth rate, min greater than max.")
|
message = _("Invalid bandwidth rate, min greater than max.")
|
||||||
|
|
||||||
@ -86,16 +91,19 @@ def convert_to_unsigned_int_or_none_max_63(val):
|
|||||||
# As per NSX API, if a queue is trusted, DSCP must be omitted; if a queue is
|
# As per NSX API, if a queue is trusted, DSCP must be omitted; if a queue is
|
||||||
# untrusted, DSCP must be specified. Whichever default values we choose for
|
# untrusted, DSCP must be specified. Whichever default values we choose for
|
||||||
# the tuple (qos_marking, dscp), there will be at least one combination of a
|
# the tuple (qos_marking, dscp), there will be at least one combination of a
|
||||||
# request with conflicting values: for instance, with the following default:
|
# request with conflicting values: for instance given the default values below,
|
||||||
#
|
# requests with qos_marking = 'trusted' and the default dscp value will fail.
|
||||||
# qos_marking = 'untrusted', dscp = '0'
|
# In order to avoid API users to explicitly specify a setting for clearing
|
||||||
#
|
# the DSCP field when a trusted queue is created, the code serving this API
|
||||||
# requests with qos_marking = 'trusted' and a default dscp will fail. Since
|
# will adopt the following behaviour when qos_marking is set to 'trusted':
|
||||||
# it is convoluted to ask the admin to specify a None value for dscp when
|
# - if the DSCP attribute is set to the default value (0), silently drop
|
||||||
# qos_marking is 'trusted', it is best to ignore the dscp value, regardless
|
# its value
|
||||||
# of whether it has been specified or not. This preserves the chosen default
|
# - if the DSCP attribute is set to anything than 0 (but still a valid DSCP
|
||||||
# and keeps backward compatibility with the API. A warning will be logged, as
|
# value) return a 400 error as qos_marking and DSCP setting conflict.
|
||||||
# the server is overriding a potentially conflicting request from the admin
|
# TODO(salv-orlando): Evaluate whether it will be possible from a backward
|
||||||
|
# compatibility perspective to change the default value for DSCP in order to
|
||||||
|
# avoid this peculiar behaviour
|
||||||
|
|
||||||
RESOURCE_ATTRIBUTE_MAP = {
|
RESOURCE_ATTRIBUTE_MAP = {
|
||||||
'qos_queues': {
|
'qos_queues': {
|
||||||
'id': {'allow_post': False, 'allow_put': False,
|
'id': {'allow_post': False, 'allow_put': False,
|
||||||
|
@ -227,6 +227,13 @@ class TestQoSQueue(test_nsx_plugin.NsxPluginV2TestCase):
|
|||||||
res = self._create_qos_queue('json', body)
|
res = self._create_qos_queue('json', body)
|
||||||
self.assertEqual(res.status_int, 400)
|
self.assertEqual(res.status_int, 400)
|
||||||
|
|
||||||
|
def test_dscp_value_with_qos_marking_trusted_returns_400(self):
|
||||||
|
body = {'qos_queue': {'tenant_id': 'admin', 'dscp': '1',
|
||||||
|
'qos_marking': 'trusted',
|
||||||
|
'name': 'foo', 'min': 20, 'max': 20}}
|
||||||
|
res = self._create_qos_queue('json', body)
|
||||||
|
self.assertEqual(res.status_int, 400)
|
||||||
|
|
||||||
def test_non_admin_cannot_create_queue(self):
|
def test_non_admin_cannot_create_queue(self):
|
||||||
body = {'qos_queue': {'tenant_id': 'not_admin',
|
body = {'qos_queue': {'tenant_id': 'not_admin',
|
||||||
'name': 'foo', 'min': 20, 'max': 20}}
|
'name': 'foo', 'min': 20, 'max': 20}}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user