update ethernet switch filed
- Add new reosurce field in ethernet switch for RSD v2_3 Change-Id: I2e535254715314bb03188c58100a71e36e6f5031
This commit is contained in:
parent
66c8336e9a
commit
b76ae2d434
0
rsd_lib/resources/v2_3/ethernet_switch/__init__.py
Normal file
0
rsd_lib/resources/v2_3/ethernet_switch/__init__.py
Normal file
92
rsd_lib/resources/v2_3/ethernet_switch/ethernet_switch.py
Normal file
92
rsd_lib/resources/v2_3/ethernet_switch/ethernet_switch.py
Normal file
@ -0,0 +1,92 @@
|
|||||||
|
# Copyright 2018 99cloud, Inc.
|
||||||
|
# All Rights Reserved.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
|
||||||
|
import logging
|
||||||
|
|
||||||
|
from rsd_lib.resources.v2_1.ethernet_switch import ethernet_switch\
|
||||||
|
as v2_1_ethernet_switch
|
||||||
|
from sushy.resources import base
|
||||||
|
|
||||||
|
from rsd_lib import utils as rsd_lib_utils
|
||||||
|
|
||||||
|
LOG = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
class ClassToPriorityMappingField(base.ListField):
|
||||||
|
priority = base.Field('Priority', adapter=int)
|
||||||
|
|
||||||
|
traffic_class = base.Field('TrafficClass', adapter=int)
|
||||||
|
|
||||||
|
|
||||||
|
class PriorityFlowControlField(base.CompositeField):
|
||||||
|
enabled = base.Field('Enabled', adapter=bool)
|
||||||
|
|
||||||
|
lossless_priorities = base.Field('LosslessPriorities', adapter=list)
|
||||||
|
|
||||||
|
|
||||||
|
class PriorityToClassMappingField(base.ListField):
|
||||||
|
priority = base.Field('Priority', adapter=int)
|
||||||
|
|
||||||
|
traffic_class = base.Field('TrafficClass', adapter=int)
|
||||||
|
|
||||||
|
|
||||||
|
class TrafficClassficationField(base.ListField):
|
||||||
|
port = base.Field('Port', adapter=int)
|
||||||
|
|
||||||
|
protocol = base.Field('Protocol')
|
||||||
|
|
||||||
|
traffic_class = base.Field('TrafficClass', adapter=int)
|
||||||
|
|
||||||
|
|
||||||
|
class TransmissionSelectionField(base.ListField):
|
||||||
|
bandwidth_percent = base.Field('BandwidthPercent', adapter=int)
|
||||||
|
|
||||||
|
traffic_class = base.Field('TrafficClass', adapter=int)
|
||||||
|
|
||||||
|
|
||||||
|
class EthernetSwitch(v2_1_ethernet_switch.EthernetSwitch):
|
||||||
|
class_to_priority_mapping = ClassToPriorityMappingField(
|
||||||
|
'ClassToPriorityMapping')
|
||||||
|
"""The ethernet switch class to priority mapping"""
|
||||||
|
|
||||||
|
dcbx_enabled = base.Field('DCBXEnabled', adapter=bool)
|
||||||
|
"""The boolean indicate this dcbx is enabled or not"""
|
||||||
|
|
||||||
|
ets_enabled = base.Field('ETSEnabled', adapter=bool)
|
||||||
|
"""The boolean indicate this etse is enabled or not"""
|
||||||
|
|
||||||
|
lldp_enabled = base.Field('LLDPEnabled', adapter=bool)
|
||||||
|
"""The boolean indicate this lldp is enabled or not"""
|
||||||
|
|
||||||
|
max_acl_number = base.Field('MaxACLNumber')
|
||||||
|
"""The ethernet switch max acl number"""
|
||||||
|
|
||||||
|
metrics = base.Field('Metrics', default=(),
|
||||||
|
adapter=rsd_lib_utils.get_resource_identity)
|
||||||
|
"""The ethernet switch metrics"""
|
||||||
|
|
||||||
|
priority_flow_control = PriorityFlowControlField('PriorityFlowControl')
|
||||||
|
"""The ethernet switch priority flow control"""
|
||||||
|
|
||||||
|
priority_to_class_mapping = PriorityToClassMappingField(
|
||||||
|
'PriorityToClassMapping')
|
||||||
|
"""The ethernet switch priority to class mapping"""
|
||||||
|
|
||||||
|
traffic_classification = TrafficClassficationField('TrafficClassification')
|
||||||
|
"""The ethernet switch traffic classification"""
|
||||||
|
|
||||||
|
transmission_selection = TransmissionSelectionField(
|
||||||
|
'TransmissionSelection')
|
||||||
|
"""The ethernet switch transmission selection"""
|
103
rsd_lib/tests/unit/json_samples/v2_3/ethernet_switch.json
Normal file
103
rsd_lib/tests/unit/json_samples/v2_3/ethernet_switch.json
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
{
|
||||||
|
"@odata.context": "/redfish/v1/$metadata#EthernetSwitch.EthernetSwitch",
|
||||||
|
"@odata.id": "/redfish/v1/EthernetSwitches/Switch1",
|
||||||
|
"@odata.type": "#EthernetSwitch.v1_1_0.EthernetSwitch",
|
||||||
|
"ACLs": {
|
||||||
|
"@odata.id": "/redfish/v1/EthernetSwitches/Switch1/ACLs"
|
||||||
|
},
|
||||||
|
"ClassToPriorityMapping": [
|
||||||
|
{
|
||||||
|
"Priority": 5,
|
||||||
|
"TrafficClass": 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"Priority": 5,
|
||||||
|
"TrafficClass": 2
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"DCBXEnabled": true,
|
||||||
|
"Description": "description-as-string",
|
||||||
|
"ETSEnabled": true,
|
||||||
|
"FirmwareName": "ONIE",
|
||||||
|
"FirmwareVersion": "1.1",
|
||||||
|
"Id": "Switch1",
|
||||||
|
"LLDPEnabled": true,
|
||||||
|
"Links": {
|
||||||
|
"Chassis": {
|
||||||
|
"@odata.id": "/redfish/v1/Chassis/FabricModule1"
|
||||||
|
},
|
||||||
|
"ManagedBy": [
|
||||||
|
{
|
||||||
|
"@odata.id": "/redfish/v1/Managers/PSME"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"Oem": {}
|
||||||
|
},
|
||||||
|
"Manufacturer": "Quanta",
|
||||||
|
"ManufacturingDate": "02/21/2015 00:00:00",
|
||||||
|
"MaxACLNumber": 4,
|
||||||
|
"Metrics": {
|
||||||
|
"@odata.id": "/redfish/v1/EthernetSwitches/Switch1/Metrics"
|
||||||
|
},
|
||||||
|
"Model": "ly8_rangley",
|
||||||
|
"Name": "Switch1",
|
||||||
|
"Oem": {},
|
||||||
|
"PartNumber": "1LY8UZZ0007",
|
||||||
|
"Ports": {
|
||||||
|
"@odata.id": "/redfish/v1/EthernetSwitches/Switch1/Ports"
|
||||||
|
},
|
||||||
|
"PriorityFlowControl": {
|
||||||
|
"Enabled": true,
|
||||||
|
"LosslessPriorities": [
|
||||||
|
0,
|
||||||
|
1,
|
||||||
|
6,
|
||||||
|
7
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"PriorityToClassMapping": [
|
||||||
|
{
|
||||||
|
"Priority": 5,
|
||||||
|
"TrafficClass": 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"Priority": 6,
|
||||||
|
"TrafficClass": 2
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"Role": "TOR",
|
||||||
|
"SerialNumber": "2M220100SL",
|
||||||
|
"Status": {
|
||||||
|
"Health": "OK",
|
||||||
|
"HealthRollup": null,
|
||||||
|
"State": "Enabled"
|
||||||
|
},
|
||||||
|
"SwitchId": "unique switch id",
|
||||||
|
"TrafficClassification": [
|
||||||
|
{
|
||||||
|
"Port": 4791,
|
||||||
|
"Protocol": "UDP",
|
||||||
|
"TrafficClass": 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"Port": 860,
|
||||||
|
"Protocol": "TCP",
|
||||||
|
"TrafficClass": 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"Port": 3260,
|
||||||
|
"Protocol": "TCP",
|
||||||
|
"TrafficClass": 2
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"TransmissionSelection": [
|
||||||
|
{
|
||||||
|
"BandwidthPercent": 60,
|
||||||
|
"TrafficClass": 1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"BandwidthPercent": 30,
|
||||||
|
"TrafficClass": 2
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
@ -0,0 +1,13 @@
|
|||||||
|
{
|
||||||
|
"@odata.context": "/redfish/v1/$metadata#EthernetSwitches",
|
||||||
|
"@odata.id": "/redfish/v1/EthernetSwitches",
|
||||||
|
"@odata.type": "#EthernetSwitchesCollection.EthernetSwitchesCollection",
|
||||||
|
"Name": "Ethernet Switches Collection",
|
||||||
|
"Description": "Network Switches Collection",
|
||||||
|
"Members@odata.count": 1,
|
||||||
|
"Members": [
|
||||||
|
{
|
||||||
|
"@odata.id": "/redfish/v1/EthernetSwitches/Switch1"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
@ -0,0 +1,136 @@
|
|||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
|
||||||
|
import json
|
||||||
|
|
||||||
|
import mock
|
||||||
|
|
||||||
|
from sushy.tests.unit import base
|
||||||
|
|
||||||
|
from rsd_lib.resources.v2_3.ethernet_switch import ethernet_switch
|
||||||
|
|
||||||
|
|
||||||
|
class TestEthernetSwtich(base.TestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(TestEthernetSwtich, self).setUp()
|
||||||
|
self.conn = mock.Mock()
|
||||||
|
|
||||||
|
with open('rsd_lib/tests/unit/json_samples/v2_3/ethernet_switch.json',
|
||||||
|
'r') as f:
|
||||||
|
self.conn.get.return_value.json.return_value = json.loads(f.read())
|
||||||
|
|
||||||
|
self.ethernet_switch_inst = ethernet_switch.EthernetSwitch(
|
||||||
|
self.conn,
|
||||||
|
'/redfish/v1/EthernetSwitches/Switch1',
|
||||||
|
redfish_version='1.0.2')
|
||||||
|
|
||||||
|
def test_parse_attributes(self):
|
||||||
|
self.ethernet_switch_inst._parse_attributes()
|
||||||
|
self.assertEqual('1.0.2', self.ethernet_switch_inst.redfish_version)
|
||||||
|
self.assertEqual('Switch1', self.ethernet_switch_inst.identity)
|
||||||
|
self.assertEqual('Switch1', self.ethernet_switch_inst.name)
|
||||||
|
self.assertEqual('description-as-string',
|
||||||
|
self.ethernet_switch_inst.description)
|
||||||
|
self.assertEqual('Quanta', self.ethernet_switch_inst.manufacturer)
|
||||||
|
self.assertEqual('ly8_rangley', self.ethernet_switch_inst.model)
|
||||||
|
self.assertEqual('02/21/2015 00:00:00',
|
||||||
|
self.ethernet_switch_inst.manufacturing_date)
|
||||||
|
self.assertEqual('2M220100SL', self.ethernet_switch_inst.seria_number)
|
||||||
|
self.assertEqual('1LY8UZZ0007', self.ethernet_switch_inst.part_number)
|
||||||
|
self.assertEqual('ONIE', self.ethernet_switch_inst.firmware_name)
|
||||||
|
self.assertEqual('1.1', self.ethernet_switch_inst.firmware_version)
|
||||||
|
self.assertEqual('TOR', self.ethernet_switch_inst.role)
|
||||||
|
self.assertEqual('Enabled', self.ethernet_switch_inst.status.state)
|
||||||
|
self.assertEqual('OK', self.ethernet_switch_inst.status.health)
|
||||||
|
self.assertEqual('/redfish/v1/EthernetSwitches/Switch1/ACLs',
|
||||||
|
self.ethernet_switch_inst.acls)
|
||||||
|
self.assertIsNone(self.ethernet_switch_inst._ports)
|
||||||
|
self.assertEqual('/redfish/v1/Chassis/FabricModule1',
|
||||||
|
self.ethernet_switch_inst.links.chassis)
|
||||||
|
self.assertEqual(('/redfish/v1/Managers/PSME',),
|
||||||
|
self.ethernet_switch_inst.links.managed_by)
|
||||||
|
self.assertEqual(5,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
class_to_priority_mapping[0].priority)
|
||||||
|
self.assertEqual(1,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
class_to_priority_mapping[0].traffic_class)
|
||||||
|
self.assertEqual(5,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
class_to_priority_mapping[1].priority)
|
||||||
|
self.assertEqual(2,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
class_to_priority_mapping[1].traffic_class)
|
||||||
|
self.assertEqual(True, self.ethernet_switch_inst.dcbx_enabled)
|
||||||
|
self.assertEqual(True, self.ethernet_switch_inst.ets_enabled)
|
||||||
|
self.assertEqual(True, self.ethernet_switch_inst.lldp_enabled)
|
||||||
|
self.assertEqual(4, self.ethernet_switch_inst.max_acl_number)
|
||||||
|
self.assertEqual('/redfish/v1/EthernetSwitches/Switch1/Metrics',
|
||||||
|
self.ethernet_switch_inst.metrics)
|
||||||
|
self.assertEqual(True,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
priority_flow_control.enabled)
|
||||||
|
self.assertEqual([0, 1, 6, 7],
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
priority_flow_control.lossless_priorities)
|
||||||
|
self.assertEqual(5,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
priority_to_class_mapping[0].priority)
|
||||||
|
self.assertEqual(1,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
priority_to_class_mapping[0].traffic_class)
|
||||||
|
self.assertEqual(6,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
priority_to_class_mapping[1].priority)
|
||||||
|
self.assertEqual(2,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
priority_to_class_mapping[1].traffic_class)
|
||||||
|
self.assertEqual(4791,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
traffic_classification[0].port)
|
||||||
|
self.assertEqual('UDP',
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
traffic_classification[0].protocol)
|
||||||
|
self.assertEqual(1,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
traffic_classification[0].traffic_class)
|
||||||
|
self.assertEqual(860,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
traffic_classification[1].port)
|
||||||
|
self.assertEqual('TCP',
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
traffic_classification[1].protocol)
|
||||||
|
self.assertEqual(2,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
traffic_classification[1].traffic_class)
|
||||||
|
self.assertEqual(3260,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
traffic_classification[2].port)
|
||||||
|
self.assertEqual('TCP',
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
traffic_classification[2].protocol)
|
||||||
|
self.assertEqual(2,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
traffic_classification[2].traffic_class)
|
||||||
|
self.assertEqual(60,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
transmission_selection[0].bandwidth_percent)
|
||||||
|
self.assertEqual(1,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
transmission_selection[0].traffic_class)
|
||||||
|
self.assertEqual(30,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
transmission_selection[1].bandwidth_percent)
|
||||||
|
self.assertEqual(2,
|
||||||
|
self.ethernet_switch_inst.
|
||||||
|
transmission_selection[1].traffic_class)
|
Loading…
x
Reference in New Issue
Block a user