
Now that we are python3 only, we should move to using the built in version of mock that supports all of our testing needs and remove the dependency on the "mock" package. Also see commit: Ifcaf1c21bea0ec3c35278e49cecc90a101a82113 Change-Id: I58da980351fe14357c210c02eb167a6c0af9d09e
190 lines
6.4 KiB
Python
190 lines
6.4 KiB
Python
# Copyright 2015 VMware, 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 time
|
|
|
|
from unittest import mock
|
|
|
|
from oslo_config import cfg
|
|
from oslo_log import log as logging
|
|
|
|
from neutron_lib import context as neutron_context
|
|
from neutron_lib.plugins import directory
|
|
|
|
from vmware_nsx.common import config
|
|
from vmware_nsx.extensions import projectpluginmap
|
|
from vmware_nsx import plugin
|
|
from vmware_nsx.plugins.nsx_v.vshield import vcns
|
|
from vmware_nsx.shell.admin.plugins.common import utils as admin_utils
|
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
|
|
def get_nsxv_client():
|
|
return vcns.Vcns(
|
|
address=cfg.CONF.nsxv.manager_uri,
|
|
user=cfg.CONF.nsxv.user,
|
|
password=cfg.CONF.nsxv.password,
|
|
ca_file=cfg.CONF.nsxv.ca_file,
|
|
insecure=cfg.CONF.nsxv.insecure)
|
|
|
|
|
|
def get_plugin_filters(context):
|
|
return admin_utils.get_plugin_filters(
|
|
context, projectpluginmap.NsxPlugins.NSX_V)
|
|
|
|
|
|
class NeutronDbClient(object):
|
|
def __init__(self):
|
|
super(NeutronDbClient, self)
|
|
self.context = neutron_context.get_admin_context()
|
|
|
|
|
|
class NsxVPluginWrapper(plugin.NsxVPlugin):
|
|
|
|
def __init__(self):
|
|
config.register_nsxv_azs(cfg.CONF, cfg.CONF.nsxv.availability_zones)
|
|
self.context = neutron_context.get_admin_context()
|
|
self.filters = get_plugin_filters(self.context)
|
|
super(NsxVPluginWrapper, self).__init__()
|
|
# Make this the core plugin
|
|
directory.add_plugin('CORE', self)
|
|
# finish the plugin initialization
|
|
# (with md-proxy config, but without housekeeping)
|
|
with mock.patch("vmware_nsx.plugins.common.housekeeper."
|
|
"housekeeper.NsxHousekeeper"):
|
|
self.init_complete(0, 0, 0)
|
|
|
|
def start_rpc_listeners(self):
|
|
pass
|
|
|
|
def _extend_get_network_dict_provider(self, context, net):
|
|
self._extend_network_dict_provider(context, net)
|
|
# skip getting the Qos policy ID because get_object calls
|
|
# plugin init again on admin-util environment
|
|
|
|
def count_spawn_jobs(self):
|
|
# check if there are any spawn jobs running
|
|
return self.edge_manager._get_worker_pool().running()
|
|
|
|
# Define enter & exit to be used in with statements
|
|
def __enter__(self):
|
|
return self
|
|
|
|
def __exit__(self, type, value, traceback):
|
|
"""Wait until no more jobs are pending
|
|
|
|
We want to wait until all spawn edge creation are done, or else the
|
|
edges might be in PERNDING_CREATE state in the nsx DB
|
|
"""
|
|
if not self.count_spawn_jobs():
|
|
return
|
|
|
|
LOG.warning("Waiting for plugin jobs to finish properly...")
|
|
sleep_time = 1
|
|
print_time = 20
|
|
max_loop = 600
|
|
for print_index in range(1, max_loop):
|
|
n_jobs = self.count_spawn_jobs()
|
|
if n_jobs > 0:
|
|
if (print_index % print_time) == 0:
|
|
LOG.warning("Still Waiting on %(jobs)s "
|
|
"job%(plural)s",
|
|
{'jobs': n_jobs,
|
|
'plural': 's' if n_jobs > 1 else ''})
|
|
time.sleep(sleep_time)
|
|
else:
|
|
LOG.warning("Done.")
|
|
return
|
|
|
|
LOG.warning("Sorry. Waited for too long. Some jobs are still "
|
|
"running.")
|
|
|
|
def _update_filters(self, requested_filters):
|
|
filters = self.filters.copy()
|
|
if requested_filters:
|
|
filters.update(requested_filters)
|
|
return filters
|
|
|
|
def get_networks(self, context, filters=None, fields=None,
|
|
filter_project=True):
|
|
if filter_project:
|
|
filters = self._update_filters(filters)
|
|
return super(NsxVPluginWrapper, self).get_networks(
|
|
context, filters=filters, fields=fields)
|
|
|
|
def get_subnets(self, context, filters=None, fields=None,
|
|
filter_project=True):
|
|
if filter_project:
|
|
filters = self._update_filters(filters)
|
|
return super(NsxVPluginWrapper, self).get_subnets(
|
|
context, filters=filters, fields=fields)
|
|
|
|
def get_ports(self, context, filters=None, fields=None,
|
|
filter_project=True):
|
|
if filter_project:
|
|
filters = self._update_filters(filters)
|
|
return super(NsxVPluginWrapper, self).get_ports(
|
|
context, filters=filters, fields=fields)
|
|
|
|
def get_routers(self, context, filters=None, fields=None,
|
|
filter_project=True):
|
|
if filter_project:
|
|
filters = self._update_filters(filters)
|
|
return super(NsxVPluginWrapper, self).get_routers(
|
|
context, filters=filters, fields=fields)
|
|
|
|
|
|
def get_nsxv_backend_edges():
|
|
"""Get a list of all the backend edges and some of their attributes
|
|
"""
|
|
nsxv = get_nsxv_client()
|
|
edges = nsxv.get_edges()
|
|
backend_edges = []
|
|
for edge in edges:
|
|
summary = edge.get('appliancesSummary')
|
|
size = ha = None
|
|
if summary:
|
|
size = summary.get('applianceSize')
|
|
deployed_vms = summary.get('numberOfDeployedVms', 1)
|
|
ha = 'Enabled' if deployed_vms > 1 else 'Disabled'
|
|
# get all the relevant backend information for this edge
|
|
edge_data = {
|
|
'id': edge.get('id'),
|
|
'name': edge.get('name'),
|
|
'size': size,
|
|
'type': edge.get('edgeType'),
|
|
'ha': ha,
|
|
}
|
|
backend_edges.append(edge_data)
|
|
return backend_edges
|
|
|
|
|
|
def get_edge_syslog_info(edge_id):
|
|
"""Get syslog information for specific edge id"""
|
|
|
|
nsxv = get_nsxv_client()
|
|
syslog_info = nsxv.get_edge_syslog(edge_id)[1]
|
|
if not syslog_info['enabled']:
|
|
return 'Disabled'
|
|
|
|
output = ""
|
|
if 'protocol' in syslog_info:
|
|
output += syslog_info['protocol']
|
|
if 'serverAddresses' in syslog_info:
|
|
for server_address in syslog_info['serverAddresses']['ipAddress']:
|
|
output += "\n" + server_address
|
|
|
|
return output
|