Check usable portgroups and ports

This tries to check whether the portgroups and ports are usable
before return from driver.

Change-Id: I5766a43f9491e599aa649a03e5c523d72c4980b3
This commit is contained in:
Zhenguo Niu 2017-09-11 15:45:52 +08:00
parent ba2aeab9dd
commit e6481c9204
3 changed files with 23 additions and 15 deletions

View File

@ -60,12 +60,10 @@ class BaseEngineDriver(object):
"""
raise NotImplementedError()
def get_ports_from_node(self, node_uuid, detail=True):
"""Get a node's ports info.
def get_portgroups_and_ports(self, node_uuid):
"""Get a node's portgroups and ports info.
:param node_uuid: node id to get ports info.
:param detail: whether to get detailed info of all the ports,
default to False.
"""
raise NotImplementedError()

View File

@ -13,6 +13,8 @@
# License for the specific language governing permissions and limitations
# under the License.
import collections
from ironicclient import exc as ironic_exc
from ironicclient import exceptions as client_e
from oslo_log import log as logging
@ -227,13 +229,24 @@ class IronicDriver(base_driver.BaseEngineDriver):
_log_ironic_polling(message, node, server)
def get_ports_from_node(self, node_uuid, detail=True):
"""List the MAC addresses and the port types from a node."""
ports = self.ironicclient.call("node.list_ports",
node_uuid, detail=detail)
portgroups = self.ironicclient.call("portgroup.list", node=node_uuid,
detail=detail)
return ports + portgroups
def get_portgroups_and_ports(self, node_uuid):
"""List ports and portgroups of a node."""
free_ports = []
ports_by_portgroup = collections.defaultdict(list)
ports = self.ironicclient.call("node.list_ports", node_uuid,
detail=True)
for p in ports:
if p.portgroup_uuid is None:
free_ports.append(p)
else:
ports_by_portgroup[p.portgroup_uuid].append(p)
portgroups = self.ironicclient.call("portgroup.list", node=node_uuid)
for pg in portgroups:
if ports_by_portgroup[pg.uuid]:
free_ports.append(pg)
return free_ports
def plug_vif(self, node_uuid, port_id):
self.ironicclient.call("node.vif_attach", node_uuid, port_id)

View File

@ -134,10 +134,7 @@ class BuildNetworkTask(flow_utils.MoganTask):
self.manager = manager
def _build_networks(self, context, server, requested_networks):
# TODO(zhenguo): This seems not needed as our scheduler has already
# guaranteed this.
ports = self.manager.driver.get_ports_from_node(server.node_uuid)
ports = self.manager.driver.get_portgroups_and_ports(server.node_uuid)
if len(requested_networks) > len(ports):
raise exception.InterfacePlugException(_(
"Ironic node: %(id)s virtual to physical interface count"