Update codebase for HACKING compliance.
* This is a massive patch that aims to clean up the codebase and bring it into compliance with HACKING.rst and PEP8 in one fell swoop. * Cleaned up use of gettext. * Updated log usage for consistency. * The tests run successfully against all plugins except cisco and nicira (due to dependency issues with these plugins). * Addresses bug 981208 Change-Id: I4d8c7ab138d8f7bb906d18dc34f88f8bd0581c19
This commit is contained in:
parent
f6c71b52e9
commit
6c97b81bf3
@ -14,3 +14,8 @@
|
||||
# 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 gettext
|
||||
|
||||
|
||||
gettext.install('quantum', unicode=1)
|
||||
|
@ -60,6 +60,9 @@ class APIRouter(wsgi.Router):
|
||||
plugin = manager.QuantumManager.get_plugin(options)
|
||||
|
||||
uri_prefix = '/tenants/{tenant_id}/'
|
||||
attachment_path = (
|
||||
'%snetworks/{network_id}/ports/{id}/attachment{.format}' %
|
||||
uri_prefix)
|
||||
mapper.resource('network', 'networks',
|
||||
controller=networks.create_resource(plugin, version),
|
||||
collection={'detail': 'GET'},
|
||||
@ -69,25 +72,22 @@ class APIRouter(wsgi.Router):
|
||||
controller=ports.create_resource(plugin, version),
|
||||
collection={'detail': 'GET'},
|
||||
member={'detail': 'GET'},
|
||||
parent_resource=dict(member_name='network',
|
||||
collection_name=uri_prefix +\
|
||||
'networks'))
|
||||
parent_resource=dict(
|
||||
member_name='network',
|
||||
collection_name='%snetworks' % uri_prefix))
|
||||
attachments_ctrl = attachments.create_resource(plugin, version)
|
||||
mapper.connect("get_resource",
|
||||
uri_prefix + 'networks/{network_id}/' \
|
||||
'ports/{id}/attachment{.format}',
|
||||
attachment_path,
|
||||
controller=attachments_ctrl,
|
||||
action="get_resource",
|
||||
conditions=dict(method=['GET']))
|
||||
mapper.connect("attach_resource",
|
||||
uri_prefix + 'networks/{network_id}/' \
|
||||
'ports/{id}/attachment{.format}',
|
||||
attachment_path,
|
||||
controller=attachments_ctrl,
|
||||
action="attach_resource",
|
||||
conditions=dict(method=['PUT']))
|
||||
mapper.connect("detach_resource",
|
||||
uri_prefix + 'networks/{network_id}/' \
|
||||
'ports/{id}/attachment{.format}',
|
||||
attachment_path,
|
||||
controller=attachments_ctrl,
|
||||
action="detach_resource",
|
||||
conditions=dict(method=['DELETE']))
|
||||
|
@ -22,6 +22,7 @@ from webob import exc
|
||||
from quantum import wsgi
|
||||
from quantum.api import faults
|
||||
|
||||
|
||||
XML_NS_V10 = 'http://openstack.org/quantum/api/v1.0'
|
||||
XML_NS_V11 = 'http://openstack.org/quantum/api/v1.1'
|
||||
LOG = logging.getLogger('quantum.api.api_common')
|
||||
|
@ -30,21 +30,26 @@ def create_resource(plugin, version):
|
||||
common.XML_NS_V10],
|
||||
'1.1': [ControllerV11(plugin),
|
||||
ControllerV11._serialization_metadata,
|
||||
common.XML_NS_V11]}
|
||||
common.XML_NS_V11],
|
||||
}
|
||||
return common.create_resource(version, controller_dict)
|
||||
|
||||
|
||||
class Controller(common.QuantumController):
|
||||
""" Port API controller for Quantum API """
|
||||
|
||||
_attachment_ops_param_list = [{
|
||||
_attachment_ops_param_list = [
|
||||
{
|
||||
'param-name': 'id',
|
||||
'required': True}, ]
|
||||
'required': True,
|
||||
},
|
||||
]
|
||||
|
||||
_serialization_metadata = {
|
||||
"application/xml": {
|
||||
"attributes": {
|
||||
"attachment": ["id"], }
|
||||
"attachment": ["id"],
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
@ -55,8 +60,7 @@ class Controller(common.QuantumController):
|
||||
@common.APIFaultWrapper([exception.NetworkNotFound,
|
||||
exception.PortNotFound])
|
||||
def get_resource(self, request, tenant_id, network_id, id):
|
||||
att_data = self._plugin.get_port_details(
|
||||
tenant_id, network_id, id)
|
||||
att_data = self._plugin.get_port_details(tenant_id, network_id, id)
|
||||
builder = attachments_view.get_view_builder(request)
|
||||
result = builder.build(att_data)['attachment']
|
||||
return dict(attachment=result)
|
||||
@ -74,8 +78,7 @@ class Controller(common.QuantumController):
|
||||
@common.APIFaultWrapper([exception.NetworkNotFound,
|
||||
exception.PortNotFound])
|
||||
def detach_resource(self, request, tenant_id, network_id, id):
|
||||
self._plugin.unplug_interface(tenant_id,
|
||||
network_id, id)
|
||||
self._plugin.unplug_interface(tenant_id, network_id, id)
|
||||
|
||||
|
||||
class ControllerV10(Controller):
|
||||
|
@ -20,6 +20,7 @@ import webob.exc
|
||||
|
||||
from quantum.common import exceptions
|
||||
|
||||
|
||||
_NETNOTFOUND_EXPL = 'Unable to find a network with the specified identifier.'
|
||||
_NETINUSE_EXPL = 'Unable to remove the network: attachments still plugged.'
|
||||
_PORTNOTFOUND_EXPL = 'Unable to find a port with the specified identifier.'
|
||||
@ -39,13 +40,15 @@ def fault_body_function_v10(wrapped_exc):
|
||||
:rtype: tuple
|
||||
"""
|
||||
code = wrapped_exc.status_int
|
||||
fault_name = hasattr(wrapped_exc, 'title') and \
|
||||
wrapped_exc.title or "quantumServiceFault"
|
||||
fault_name = (hasattr(wrapped_exc, 'title') and
|
||||
wrapped_exc.title or "quantumServiceFault")
|
||||
fault_data = {
|
||||
fault_name: {
|
||||
'code': code,
|
||||
'message': wrapped_exc.explanation,
|
||||
'detail': str(wrapped_exc.detail)}}
|
||||
'detail': str(wrapped_exc.detail),
|
||||
},
|
||||
}
|
||||
metadata = {'attributes': {fault_name: ['code']}}
|
||||
return fault_data, metadata
|
||||
|
||||
@ -59,15 +62,17 @@ def fault_body_function_v11(wrapped_exc):
|
||||
:returns: response body contents and serialization metadata
|
||||
:rtype: tuple
|
||||
"""
|
||||
fault_name = hasattr(wrapped_exc, 'type') and \
|
||||
wrapped_exc.type or "QuantumServiceFault"
|
||||
fault_name = (hasattr(wrapped_exc, 'type') and
|
||||
wrapped_exc.type or "QuantumServiceFault")
|
||||
# Ensure first letter is capital
|
||||
fault_name = fault_name[0].upper() + fault_name[1:]
|
||||
fault_data = {
|
||||
'QuantumError': {
|
||||
'type': fault_name,
|
||||
'message': wrapped_exc.explanation,
|
||||
'detail': str(wrapped_exc.detail)}}
|
||||
'detail': str(wrapped_exc.detail),
|
||||
},
|
||||
}
|
||||
# Metadata not required for v11
|
||||
return fault_data, None
|
||||
|
||||
|
@ -19,10 +19,11 @@ from webob import exc
|
||||
|
||||
from quantum.api import api_common as common
|
||||
from quantum.api import faults
|
||||
from quantum.api.views import networks as networks_view
|
||||
from quantum.api.views import filters
|
||||
from quantum.api.views import networks as networks_view
|
||||
from quantum.common import exceptions as exception
|
||||
|
||||
|
||||
LOG = logging.getLogger('quantum.api.networks')
|
||||
|
||||
|
||||
@ -33,16 +34,17 @@ def create_resource(plugin, version):
|
||||
common.XML_NS_V10],
|
||||
'1.1': [ControllerV11(plugin),
|
||||
ControllerV11._serialization_metadata,
|
||||
common.XML_NS_V11]}
|
||||
common.XML_NS_V11],
|
||||
}
|
||||
return common.create_resource(version, controller_dict)
|
||||
|
||||
|
||||
class Controller(common.QuantumController):
|
||||
""" Network API controller for Quantum API """
|
||||
|
||||
_network_ops_param_list = [{
|
||||
'param-name': 'name',
|
||||
'required': True}, ]
|
||||
_network_ops_param_list = [
|
||||
{'param-name': 'name', 'required': True},
|
||||
]
|
||||
|
||||
def __init__(self, plugin):
|
||||
self._resource_name = 'network'
|
||||
@ -52,16 +54,16 @@ class Controller(common.QuantumController):
|
||||
net_details=True, port_details=False):
|
||||
# We expect get_network_details to return information
|
||||
# concerning logical ports as well.
|
||||
network = self._plugin.get_network_details(
|
||||
tenant_id, network_id)
|
||||
network = self._plugin.get_network_details(tenant_id, network_id)
|
||||
# Doing this in the API is inefficient
|
||||
# TODO(salvatore-orlando): This should be fixed with Bug #834012
|
||||
# Don't pass filter options
|
||||
ports_data = None
|
||||
if port_details:
|
||||
port_list = self._plugin.get_all_ports(tenant_id, network_id)
|
||||
ports_data = [self._plugin.get_port_details(
|
||||
tenant_id, network_id, port['port-id'])
|
||||
ports_data = [
|
||||
self._plugin.get_port_details(tenant_id, network_id,
|
||||
port['port-id'])
|
||||
for port in port_list]
|
||||
builder = networks_view.get_view_builder(request, self.version)
|
||||
result = builder.build(network, net_details,
|
||||
@ -128,8 +130,7 @@ class Controller(common.QuantumController):
|
||||
# request_params but that would mean all the plugins would need to
|
||||
# change.
|
||||
body = self._prepare_request_body(body, self._network_ops_param_list)
|
||||
network = self._plugin.\
|
||||
create_network(tenant_id,
|
||||
network = self._plugin.create_network(tenant_id,
|
||||
body['network']['name'],
|
||||
**body)
|
||||
builder = networks_view.get_view_builder(request, self.version)
|
||||
@ -156,9 +157,12 @@ class ControllerV10(Controller):
|
||||
"attributes": {
|
||||
"network": ["id", "name"],
|
||||
"port": ["id", "state"],
|
||||
"attachment": ["id"]},
|
||||
"plurals": {"networks": "network",
|
||||
"ports": "port"}
|
||||
"attachment": ["id"],
|
||||
},
|
||||
"plurals": {
|
||||
"networks": "network",
|
||||
"ports": "port",
|
||||
},
|
||||
}
|
||||
|
||||
def __init__(self, plugin):
|
||||
@ -179,9 +183,12 @@ class ControllerV11(Controller):
|
||||
"attributes": {
|
||||
"network": ["id", "name", "op-status"],
|
||||
"port": ["id", "state", "op-status"],
|
||||
"attachment": ["id"]},
|
||||
"plurals": {"networks": "network",
|
||||
"ports": "port"}
|
||||
"attachment": ["id"],
|
||||
},
|
||||
"plurals": {
|
||||
"networks": "network",
|
||||
"ports": "port",
|
||||
},
|
||||
}
|
||||
|
||||
def __init__(self, plugin):
|
||||
|
@ -31,17 +31,17 @@ def create_resource(plugin, version):
|
||||
common.XML_NS_V10],
|
||||
'1.1': [ControllerV11(plugin),
|
||||
ControllerV11._serialization_metadata,
|
||||
common.XML_NS_V11]}
|
||||
common.XML_NS_V11],
|
||||
}
|
||||
return common.create_resource(version, controller_dict)
|
||||
|
||||
|
||||
class Controller(common.QuantumController):
|
||||
""" Port API controller for Quantum API """
|
||||
|
||||
_port_ops_param_list = [{
|
||||
'param-name': 'state',
|
||||
'default-value': 'DOWN',
|
||||
'required': False}, ]
|
||||
_port_ops_param_list = [
|
||||
{'param-name': 'state', 'default-value': 'DOWN', 'required': False},
|
||||
]
|
||||
|
||||
def __init__(self, plugin):
|
||||
self._resource_name = 'port'
|
||||
@ -69,9 +69,9 @@ class Controller(common.QuantumController):
|
||||
# This can be inefficient.
|
||||
# TODO(salvatore-orlando): the fix for bug #834012 should deal with it
|
||||
if port_details:
|
||||
port_list_detail = \
|
||||
[self._plugin.get_port_details(
|
||||
tenant_id, network_id, port['port-id'])
|
||||
port_list_detail = [
|
||||
self._plugin.get_port_details(tenant_id, network_id,
|
||||
port['port-id'])
|
||||
for port in port_list]
|
||||
port_list = port_list_detail
|
||||
|
||||
@ -92,8 +92,7 @@ class Controller(common.QuantumController):
|
||||
def _item(self, request, tenant_id, network_id, port_id,
|
||||
att_details=False):
|
||||
""" Returns a specific port. """
|
||||
port = self._plugin.get_port_details(
|
||||
tenant_id, network_id, port_id)
|
||||
port = self._plugin.get_port_details(tenant_id, network_id, port_id)
|
||||
builder = ports_view.get_view_builder(request, self.version)
|
||||
result = builder.build(port, port_details=True,
|
||||
att_details=att_details)['port']
|
||||
@ -162,8 +161,11 @@ class ControllerV10(Controller):
|
||||
_serialization_metadata = {
|
||||
"attributes": {
|
||||
"port": ["id", "state"],
|
||||
"attachment": ["id"]},
|
||||
"plurals": {"ports": "port"}
|
||||
"attachment": ["id"],
|
||||
},
|
||||
"plurals": {
|
||||
"ports": "port",
|
||||
},
|
||||
}
|
||||
|
||||
def __init__(self, plugin):
|
||||
@ -177,8 +179,11 @@ class ControllerV11(Controller):
|
||||
_serialization_metadata = {
|
||||
"attributes": {
|
||||
"port": ["id", "state", "op-status"],
|
||||
"attachment": ["id"]},
|
||||
"plurals": {"ports": "port"}
|
||||
"attachment": ["id"],
|
||||
},
|
||||
"plurals": {
|
||||
"ports": "port",
|
||||
},
|
||||
}
|
||||
|
||||
def __init__(self, plugin):
|
||||
|
@ -31,8 +31,9 @@ import socket
|
||||
|
||||
from paste import deploy
|
||||
|
||||
from quantum.common import flags
|
||||
from quantum.common import exceptions as exception
|
||||
from quantum.common import flags
|
||||
|
||||
|
||||
DEFAULT_LOG_FORMAT = "%(asctime)s %(levelname)8s [%(name)s] %(message)s"
|
||||
DEFAULT_LOG_DATE_FORMAT = "%Y-%m-%d %H:%M:%S"
|
||||
@ -142,10 +143,10 @@ def setup_logging(options, conf):
|
||||
|
||||
# If either the CLI option or the conf value
|
||||
# is True, we set to True
|
||||
debug = options.get('debug') or \
|
||||
get_option(conf, 'debug', type='bool', default=False)
|
||||
verbose = options.get('verbose') or \
|
||||
get_option(conf, 'verbose', type='bool', default=False)
|
||||
debug = (options.get('debug') or
|
||||
get_option(conf, 'debug', type='bool', default=False))
|
||||
verbose = (options.get('verbose') or
|
||||
get_option(conf, 'verbose', type='bool', default=False))
|
||||
root_logger = logging.root
|
||||
if debug:
|
||||
root_logger.setLevel(logging.DEBUG)
|
||||
@ -239,9 +240,10 @@ def find_config_file(options, args, config_file='quantum.conf'):
|
||||
'/etc']
|
||||
|
||||
if 'plugin' in options:
|
||||
config_file_dirs = [os.path.join(x, 'quantum', 'plugins',
|
||||
options['plugin'])
|
||||
for x in config_file_dirs]
|
||||
config_file_dirs = [
|
||||
os.path.join(x, 'quantum', 'plugins', options['plugin'])
|
||||
for x in config_file_dirs
|
||||
]
|
||||
|
||||
if os.path.exists(os.path.join(root, 'plugins')):
|
||||
plugins = [fix_path(os.path.join(root, 'plugins', p, 'etc'))
|
||||
|
@ -56,7 +56,7 @@ class NetworkNotFound(NotFound):
|
||||
|
||||
|
||||
class PortNotFound(NotFound):
|
||||
message = _("Port %(port_id)s could not be found " \
|
||||
message = _("Port %(port_id)s could not be found "
|
||||
"on network %(net_id)s")
|
||||
|
||||
|
||||
@ -65,19 +65,19 @@ class StateInvalid(QuantumException):
|
||||
|
||||
|
||||
class NetworkInUse(QuantumException):
|
||||
message = _("Unable to complete operation on network %(net_id)s. " \
|
||||
message = _("Unable to complete operation on network %(net_id)s. "
|
||||
"There is one or more attachments plugged into its ports.")
|
||||
|
||||
|
||||
class PortInUse(QuantumException):
|
||||
message = _("Unable to complete operation on port %(port_id)s " \
|
||||
"for network %(net_id)s. The attachment '%(att_id)s" \
|
||||
message = _("Unable to complete operation on port %(port_id)s "
|
||||
"for network %(net_id)s. The attachment '%(att_id)s"
|
||||
"is plugged into the logical port.")
|
||||
|
||||
|
||||
class AlreadyAttached(QuantumException):
|
||||
message = _("Unable to plug the attachment %(att_id)s into port " \
|
||||
"%(port_id)s for network %(net_id)s. The attachment is " \
|
||||
message = _("Unable to plug the attachment %(att_id)s into port "
|
||||
"%(port_id)s for network %(net_id)s. The attachment is "
|
||||
"already plugged into port %(att_port_id)s")
|
||||
|
||||
|
||||
|
@ -37,15 +37,14 @@
|
||||
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||
# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||
|
||||
import gettext
|
||||
import os
|
||||
import unittest
|
||||
import sys
|
||||
import logging
|
||||
import os
|
||||
import sys
|
||||
import unittest
|
||||
|
||||
from nose import result
|
||||
from nose import core
|
||||
from nose import config
|
||||
from nose import core
|
||||
from nose import result
|
||||
|
||||
|
||||
class _AnsiColorizer(object):
|
||||
|
@ -20,27 +20,28 @@
|
||||
|
||||
"""Utilities and helper functions."""
|
||||
|
||||
|
||||
import base64
|
||||
import ConfigParser
|
||||
import datetime
|
||||
import functools
|
||||
import inspect
|
||||
import json
|
||||
import logging
|
||||
import os
|
||||
import random
|
||||
import subprocess
|
||||
import socket
|
||||
import sys
|
||||
import base64
|
||||
import functools
|
||||
import json
|
||||
import re
|
||||
import socket
|
||||
import string
|
||||
import struct
|
||||
import subprocess
|
||||
import sys
|
||||
import time
|
||||
import types
|
||||
|
||||
from quantum.common import flags
|
||||
from quantum.common import exceptions as exception
|
||||
from quantum.common.exceptions import ProcessExecutionError
|
||||
from quantum.common import flags
|
||||
|
||||
|
||||
def import_class(import_str):
|
||||
@ -96,6 +97,7 @@ def dumps(value):
|
||||
def loads(s):
|
||||
return json.loads(s)
|
||||
|
||||
|
||||
TIME_FORMAT = "%Y-%m-%dT%H:%M:%SZ"
|
||||
FLAGS = flags.FLAGS
|
||||
|
||||
@ -173,7 +175,6 @@ def abspath(s):
|
||||
|
||||
# TODO(sirp): when/if utils is extracted to common library, we should remove
|
||||
# the argument's default.
|
||||
#def default_flagfile(filename='nova.conf'):
|
||||
def default_flagfile(filename='quantum.conf'):
|
||||
for arg in sys.argv:
|
||||
if arg.find('flagfile') != -1:
|
||||
@ -184,8 +185,7 @@ def default_flagfile(filename='quantum.conf'):
|
||||
script_dir = os.path.dirname(inspect.stack()[-1][1])
|
||||
filename = os.path.abspath(os.path.join(script_dir, filename))
|
||||
if os.path.exists(filename):
|
||||
sys.argv = \
|
||||
sys.argv[:1] + ['--flagfile=%s' % filename] + sys.argv[1:]
|
||||
sys.argv.insert(1, '--flagfile=%s' % filename)
|
||||
|
||||
|
||||
def debug(arg):
|
||||
@ -251,7 +251,7 @@ class LazyPluggable(object):
|
||||
raise exception.Error('Invalid backend: %s' % backend_name)
|
||||
|
||||
backend = self.__backends[backend_name]
|
||||
if type(backend) == type(tuple()):
|
||||
if isinstance(backend, tuple):
|
||||
name = backend[0]
|
||||
fromlist = backend[1]
|
||||
else:
|
||||
|
@ -18,6 +18,7 @@
|
||||
# @author: Dan Wendlandt, Nicira Networks, Inc.
|
||||
|
||||
import logging
|
||||
|
||||
import sqlalchemy as sql
|
||||
from sqlalchemy import create_engine
|
||||
from sqlalchemy.exc import DisconnectionError
|
||||
@ -127,17 +128,17 @@ def network_all_tenant_list():
|
||||
|
||||
def network_list(tenant_id):
|
||||
session = get_session()
|
||||
return session.query(models.Network).\
|
||||
filter_by(tenant_id=tenant_id).\
|
||||
all()
|
||||
return (session.query(models.Network).
|
||||
filter_by(tenant_id=tenant_id).
|
||||
all())
|
||||
|
||||
|
||||
def network_get(net_id):
|
||||
session = get_session()
|
||||
try:
|
||||
return session.query(models.Network).\
|
||||
filter_by(uuid=net_id).\
|
||||
one()
|
||||
return (session.query(models.Network).
|
||||
filter_by(uuid=net_id).
|
||||
one())
|
||||
except exc.NoResultFound, e:
|
||||
raise q_exc.NetworkNotFound(net_id=net_id)
|
||||
|
||||
@ -155,13 +156,13 @@ def network_update(net_id, tenant_id, **kwargs):
|
||||
def network_destroy(net_id):
|
||||
session = get_session()
|
||||
try:
|
||||
net = session.query(models.Network).\
|
||||
filter_by(uuid=net_id).\
|
||||
one()
|
||||
net = (session.query(models.Network).
|
||||
filter_by(uuid=net_id).
|
||||
one())
|
||||
|
||||
ports = session.query(models.Port).\
|
||||
filter_by(network_id=net_id).\
|
||||
all()
|
||||
ports = (session.query(models.Port).
|
||||
filter_by(network_id=net_id).
|
||||
all())
|
||||
for p in ports:
|
||||
session.delete(p)
|
||||
|
||||
@ -175,10 +176,10 @@ def network_destroy(net_id):
|
||||
def validate_network_ownership(tenant_id, net_id):
|
||||
session = get_session()
|
||||
try:
|
||||
return session.query(models.Network).\
|
||||
filter_by(uuid=net_id).\
|
||||
filter_by(tenant_id=tenant_id).\
|
||||
one()
|
||||
return (session.query(models.Network).
|
||||
filter_by(uuid=net_id).
|
||||
filter_by(tenant_id=tenant_id).
|
||||
one())
|
||||
except exc.NoResultFound, e:
|
||||
raise q_exc.NetworkNotFound(net_id=net_id)
|
||||
|
||||
@ -204,9 +205,9 @@ def port_list(net_id):
|
||||
# confirm network exists
|
||||
network_get(net_id)
|
||||
session = get_session()
|
||||
return session.query(models.Port).\
|
||||
filter_by(network_id=net_id).\
|
||||
all()
|
||||
return (session.query(models.Port).
|
||||
filter_by(network_id=net_id).
|
||||
all())
|
||||
|
||||
|
||||
def port_get(port_id, net_id, session=None):
|
||||
@ -215,10 +216,10 @@ def port_get(port_id, net_id, session=None):
|
||||
if not session:
|
||||
session = get_session()
|
||||
try:
|
||||
return session.query(models.Port).\
|
||||
filter_by(uuid=port_id).\
|
||||
filter_by(network_id=net_id).\
|
||||
one()
|
||||
return (session.query(models.Port).
|
||||
filter_by(uuid=port_id).
|
||||
filter_by(network_id=net_id).
|
||||
one())
|
||||
except exc.NoResultFound:
|
||||
raise q_exc.PortNotFound(net_id=net_id, port_id=port_id)
|
||||
|
||||
@ -228,7 +229,7 @@ def port_update(port_id, net_id, **kwargs):
|
||||
network_get(net_id)
|
||||
port = port_get(port_id, net_id)
|
||||
session = get_session()
|
||||
for key in kwargs.keys():
|
||||
for key in kwargs:
|
||||
if key == "state":
|
||||
if kwargs[key] not in ('ACTIVE', 'DOWN'):
|
||||
raise q_exc.StateInvalid(port_state=kwargs[key])
|
||||
@ -252,9 +253,9 @@ def port_set_attachment(port_id, net_id, new_interface_id):
|
||||
att_id=port['interface_id'])
|
||||
|
||||
try:
|
||||
port = session.query(models.Port).\
|
||||
filter_by(interface_id=new_interface_id).\
|
||||
one()
|
||||
port = (session.query(models.Port).
|
||||
filter_by(interface_id=new_interface_id).
|
||||
one())
|
||||
raise q_exc.AlreadyAttached(net_id=net_id,
|
||||
port_id=port_id,
|
||||
att_id=new_interface_id,
|
||||
@ -285,10 +286,10 @@ def port_destroy(port_id, net_id):
|
||||
|
||||
session = get_session()
|
||||
try:
|
||||
port = session.query(models.Port).\
|
||||
filter_by(uuid=port_id).\
|
||||
filter_by(network_id=net_id).\
|
||||
one()
|
||||
port = (session.query(models.Port).
|
||||
filter_by(uuid=port_id).
|
||||
filter_by(network_id=net_id).
|
||||
one())
|
||||
if port['interface_id']:
|
||||
raise q_exc.PortInUse(net_id=net_id, port_id=port_id,
|
||||
att_id=port['interface_id'])
|
||||
|
@ -26,6 +26,7 @@ from sqlalchemy.orm import relation, object_mapper
|
||||
|
||||
from quantum.api import api_common as common
|
||||
|
||||
|
||||
BASE = declarative_base()
|
||||
|
||||
|
||||
@ -76,8 +77,7 @@ class Port(BASE, QuantumBase):
|
||||
state = Column(String(8))
|
||||
op_status = Column(String(16))
|
||||
|
||||
def __init__(self, network_id,
|
||||
op_status=common.OperationalStatus.UNKNOWN):
|
||||
def __init__(self, network_id, op_status=common.OperationalStatus.UNKNOWN):
|
||||
self.uuid = str(uuid.uuid4())
|
||||
self.network_id = network_id
|
||||
self.interface_id = None
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -17,7 +16,6 @@
|
||||
#
|
||||
# @author: Ying Liu, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
|
||||
def get_view_builder(req):
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -17,7 +16,7 @@
|
||||
#
|
||||
# @author: Ying Liu, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
|
||||
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Nicira Networks, Inc. All rights reserved.
|
||||
@ -17,7 +16,6 @@
|
||||
#
|
||||
# @author: Brad Hall, Nicira Networks, Inc
|
||||
#
|
||||
"""
|
||||
|
||||
|
||||
def get_view_builder(req):
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,8 +15,6 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Ying Liu, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
|
||||
def get_view_builder(req):
|
||||
@ -52,11 +49,15 @@ class ViewBuilder(object):
|
||||
def _build_detail(self, portprofile_data):
|
||||
"""Return a detailed info of a portprofile."""
|
||||
if (portprofile_data['assignment'] is None):
|
||||
return dict(portprofile=dict(id=portprofile_data['profile_id'],
|
||||
name=portprofile_data['profile_name'],
|
||||
qos_name=portprofile_data['qos_name']))
|
||||
else:
|
||||
return dict(portprofile=dict(id=portprofile_data['profile_id'],
|
||||
return dict(portprofile=dict(
|
||||
id=portprofile_data['profile_id'],
|
||||
name=portprofile_data['profile_name'],
|
||||
qos_name=portprofile_data['qos_name'],
|
||||
assignment=portprofile_data['assignment']))
|
||||
))
|
||||
else:
|
||||
return dict(portprofile=dict(
|
||||
id=portprofile_data['profile_id'],
|
||||
name=portprofile_data['profile_name'],
|
||||
qos_name=portprofile_data['qos_name'],
|
||||
assignment=portprofile_data['assignment'],
|
||||
))
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -17,7 +16,6 @@
|
||||
#
|
||||
# @author: Ying Liu, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
|
||||
def get_view_builder(req):
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,18 +15,19 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Ying Liu, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import logging
|
||||
|
||||
from webob import exc
|
||||
from quantum import wsgi
|
||||
from quantum.extensions import _credential_view as credential_view
|
||||
|
||||
from quantum.api import api_common as common
|
||||
from quantum.extensions import _credential_view as credential_view
|
||||
from quantum.extensions import extensions
|
||||
from quantum.manager import QuantumManager
|
||||
from quantum.plugins.cisco.common import cisco_exceptions as exception
|
||||
from quantum.plugins.cisco.common import cisco_faults as faults
|
||||
from quantum import wsgi
|
||||
|
||||
|
||||
LOG = logging.getLogger('quantum.api.credentials')
|
||||
|
||||
@ -76,13 +76,11 @@ class CredentialController(common.QuantumController, wsgi.Controller):
|
||||
""" credential API controller
|
||||
based on QuantumController """
|
||||
|
||||
_credential_ops_param_list = [{
|
||||
'param-name': 'credential_name',
|
||||
'required': True}, {
|
||||
'param-name': 'user_name',
|
||||
'required': True}, {
|
||||
'param-name': 'password',
|
||||
'required': True}]
|
||||
_credential_ops_param_list = [
|
||||
{'param-name': 'credential_name', 'required': True},
|
||||
{'param-name': 'user_name', 'required': True},
|
||||
{'param-name': 'password', 'required': True},
|
||||
]
|
||||
|
||||
_serialization_metadata = {
|
||||
"application/xml": {
|
||||
@ -112,8 +110,7 @@ class CredentialController(common.QuantumController, wsgi.Controller):
|
||||
def show(self, request, tenant_id, id):
|
||||
""" Returns credential details for the given credential id """
|
||||
try:
|
||||
credential = self._plugin.get_credential_details(
|
||||
tenant_id, id)
|
||||
credential = self._plugin.get_credential_details(tenant_id, id)
|
||||
builder = credential_view.get_view_builder(request)
|
||||
#build response with details
|
||||
result = builder.build(credential, True)
|
||||
@ -125,15 +122,14 @@ class CredentialController(common.QuantumController, wsgi.Controller):
|
||||
""" Creates a new credential for a given tenant """
|
||||
try:
|
||||
body = self._deserialize(request.body, request.get_content_type())
|
||||
req_body = \
|
||||
self._prepare_request_body(body,
|
||||
self._credential_ops_param_list)
|
||||
req_body = self._prepare_request_body(
|
||||
body, self._credential_ops_param_list)
|
||||
req_params = req_body[self._resource_name]
|
||||
|
||||
except exc.HTTPError as exp:
|
||||
return faults.Fault(exp)
|
||||
credential = self._plugin.\
|
||||
create_credential(tenant_id,
|
||||
credential = self._plugin.create_credential(
|
||||
tenant_id,
|
||||
req_params['credential_name'],
|
||||
req_params['user_name'],
|
||||
req_params['password'])
|
||||
@ -145,16 +141,14 @@ class CredentialController(common.QuantumController, wsgi.Controller):
|
||||
""" Updates the name for the credential with the given id """
|
||||
try:
|
||||
body = self._deserialize(request.body, request.get_content_type())
|
||||
req_body = \
|
||||
self._prepare_request_body(body,
|
||||
self._credential_ops_param_list)
|
||||
req_body = self._prepare_request_body(
|
||||
body, self._credential_ops_param_list)
|
||||
req_params = req_body[self._resource_name]
|
||||
except exc.HTTPError as exp:
|
||||
return faults.Fault(exp)
|
||||
try:
|
||||
credential = self._plugin.\
|
||||
rename_credential(tenant_id,
|
||||
id, req_params['credential_name'])
|
||||
credential = self._plugin.rename_credential(
|
||||
tenant_id, id, req_params['credential_name'])
|
||||
|
||||
builder = credential_view.get_view_builder(request)
|
||||
result = builder.build(credential, True)
|
||||
|
@ -16,20 +16,22 @@
|
||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
|
||||
from abc import ABCMeta
|
||||
import imp
|
||||
import logging
|
||||
import os
|
||||
|
||||
import routes
|
||||
import webob.dec
|
||||
import webob.exc
|
||||
|
||||
from gettext import gettext as _
|
||||
from abc import ABCMeta
|
||||
from quantum.common import exceptions
|
||||
import quantum.extensions
|
||||
from quantum.manager import QuantumManager
|
||||
from quantum import wsgi
|
||||
|
||||
|
||||
LOG = logging.getLogger('quantum.extensions.extensions')
|
||||
|
||||
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,18 +15,19 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Ying Liu, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import logging
|
||||
|
||||
from webob import exc
|
||||
from quantum import wsgi
|
||||
|
||||
from quantum.api import api_common as common
|
||||
from quantum.api.views import ports as port_view
|
||||
from quantum.extensions import extensions
|
||||
from quantum.manager import QuantumManager
|
||||
from quantum.plugins.cisco.common import cisco_exceptions as exception
|
||||
from quantum.plugins.cisco.common import cisco_faults as faults
|
||||
from quantum import wsgi
|
||||
|
||||
|
||||
LOG = logging.getLogger('quantum.api.multiports')
|
||||
|
||||
@ -76,13 +76,11 @@ class MultiportController(common.QuantumController, wsgi.Controller):
|
||||
""" multiport API controller
|
||||
based on QuantumController """
|
||||
|
||||
_multiport_ops_param_list = [{
|
||||
'param-name': 'net_id_list',
|
||||
'required': True}, {
|
||||
'param-name': 'status',
|
||||
'required': True}, {
|
||||
'param-name': 'ports_desc',
|
||||
'required': True}]
|
||||
_multiport_ops_param_list = [
|
||||
{'param-name': 'net_id_list', 'required': True},
|
||||
{'param-name': 'status', 'required': True},
|
||||
{'param-name': 'ports_desc', 'required': True},
|
||||
]
|
||||
|
||||
_serialization_metadata = {
|
||||
"application/xml": {
|
||||
@ -102,19 +100,16 @@ class MultiportController(common.QuantumController, wsgi.Controller):
|
||||
""" Creates a new multiport for a given tenant """
|
||||
try:
|
||||
body = self._deserialize(request.body, request.get_content_type())
|
||||
req_body = \
|
||||
self._prepare_request_body(body,
|
||||
self._multiport_ops_param_list)
|
||||
req_body = self._prepare_request_body(
|
||||
body, self._multiport_ops_param_list)
|
||||
req_params = req_body[self._resource_name]
|
||||
|
||||
except exc.HTTPError as exp:
|
||||
return faults.Fault(exp)
|
||||
multiports = self._plugin.\
|
||||
create_multiport(tenant_id,
|
||||
multiports = self._plugin.create_multiport(tenant_id,
|
||||
req_params['net_id_list'],
|
||||
req_params['status'],
|
||||
req_params['ports_desc'])
|
||||
builder = port_view.get_view_builder(request, self.version)
|
||||
result = [builder.build(port)['port']
|
||||
for port in multiports]
|
||||
result = [builder.build(port)['port'] for port in multiports]
|
||||
return dict(ports=result)
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,16 +15,16 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Ying Liu, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
from webob import exc
|
||||
from quantum import wsgi
|
||||
from quantum.extensions import _novatenant_view as novatenant_view
|
||||
|
||||
from quantum.api import api_common as common
|
||||
from quantum.common import exceptions as qexception
|
||||
from quantum.extensions import extensions
|
||||
from quantum.extensions import _novatenant_view as novatenant_view
|
||||
from quantum.manager import QuantumManager
|
||||
from quantum.plugins.cisco.common import cisco_faults as faults
|
||||
from quantum import wsgi
|
||||
|
||||
|
||||
class Novatenant(object):
|
||||
@ -76,15 +75,14 @@ class NovatenantsController(common.QuantumController, wsgi.Controller):
|
||||
""" Novatenant API controller
|
||||
based on QuantumController """
|
||||
|
||||
_Novatenant_ops_param_list = [{
|
||||
'param-name': 'novatenant_name',
|
||||
'required': True}]
|
||||
_Novatenant_ops_param_list = [
|
||||
{'param-name': 'novatenant_name', 'required': True},
|
||||
]
|
||||
|
||||
_schedule_host_ops_param_list = [{
|
||||
'param-name': 'instance_id',
|
||||
'required': True}, {
|
||||
'param-name': 'instance_desc',
|
||||
'required': True}]
|
||||
_schedule_host_ops_param_list = [
|
||||
{'param-name': 'instance_id', 'required': True},
|
||||
{'param-name': 'instance_desc', 'required': True},
|
||||
]
|
||||
|
||||
_serialization_metadata = {
|
||||
"application/xml": {
|
||||
@ -122,9 +120,8 @@ class NovatenantsController(common.QuantumController, wsgi.Controller):
|
||||
|
||||
try:
|
||||
body = self._deserialize(request.body, content_type)
|
||||
req_body = \
|
||||
self._prepare_request_body(body,
|
||||
self._schedule_host_ops_param_list)
|
||||
req_body = self._prepare_request_body(
|
||||
body, self._schedule_host_ops_param_list)
|
||||
req_params = req_body[self._resource_name]
|
||||
|
||||
except exc.HTTPError as exp:
|
||||
@ -132,8 +129,9 @@ class NovatenantsController(common.QuantumController, wsgi.Controller):
|
||||
instance_id = req_params['instance_id']
|
||||
instance_desc = req_params['instance_desc']
|
||||
try:
|
||||
host = self._plugin.\
|
||||
schedule_host(tenant_id, instance_id, instance_desc)
|
||||
host = self._plugin.schedule_host(tenant_id,
|
||||
instance_id,
|
||||
instance_desc)
|
||||
builder = novatenant_view.get_view_builder(request)
|
||||
result = builder.build_host(host)
|
||||
return result
|
||||
@ -144,9 +142,8 @@ class NovatenantsController(common.QuantumController, wsgi.Controller):
|
||||
content_type = request.best_match_content_type()
|
||||
try:
|
||||
body = self._deserialize(request.body, content_type)
|
||||
req_body = \
|
||||
self._prepare_request_body(body,
|
||||
self._schedule_host_ops_param_list)
|
||||
req_body = self._prepare_request_body(
|
||||
body, self._schedule_host_ops_param_list)
|
||||
req_params = req_body[self._resource_name]
|
||||
|
||||
except exc.HTTPError as exp:
|
||||
@ -154,8 +151,9 @@ class NovatenantsController(common.QuantumController, wsgi.Controller):
|
||||
instance_id = req_params['instance_id']
|
||||
instance_desc = req_params['instance_desc']
|
||||
try:
|
||||
vif = self._plugin. \
|
||||
associate_port(tenant_id, instance_id, instance_desc)
|
||||
vif = self._plugin.associate_port(tenant_id,
|
||||
instance_id,
|
||||
instance_desc)
|
||||
builder = novatenant_view.get_view_builder(request)
|
||||
result = builder.build_vif(vif)
|
||||
return result
|
||||
@ -166,9 +164,8 @@ class NovatenantsController(common.QuantumController, wsgi.Controller):
|
||||
content_type = request.best_match_content_type()
|
||||
try:
|
||||
body = self._deserialize(request.body, content_type)
|
||||
req_body = \
|
||||
self._prepare_request_body(body,
|
||||
self._schedule_host_ops_param_list)
|
||||
req_body = self._prepare_request_body(
|
||||
body, self._schedule_host_ops_param_list)
|
||||
req_params = req_body[self._resource_name]
|
||||
|
||||
except exc.HTTPError as exp:
|
||||
@ -178,8 +175,9 @@ class NovatenantsController(common.QuantumController, wsgi.Controller):
|
||||
instance_desc = req_params['instance_desc']
|
||||
|
||||
try:
|
||||
vif = self._plugin. \
|
||||
detach_port(tenant_id, instance_id, instance_desc)
|
||||
vif = self._plugin.detach_port(tenant_id,
|
||||
instance_id,
|
||||
instance_desc)
|
||||
builder = novatenant_view.get_view_builder(request)
|
||||
result = builder.build_result(True)
|
||||
return result
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,18 +15,17 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Ying Liu, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
from webob import exc
|
||||
from quantum import wsgi
|
||||
from quantum.extensions import _pprofiles as pprofiles_view
|
||||
|
||||
from quantum.api import api_common as common
|
||||
from quantum.common import exceptions as qexception
|
||||
from quantum.extensions import _pprofiles as pprofiles_view
|
||||
from quantum.extensions import extensions
|
||||
from quantum.manager import QuantumManager
|
||||
from quantum.plugins.cisco.common import cisco_exceptions as exception
|
||||
from quantum.plugins.cisco.common import cisco_faults as faults
|
||||
from quantum import wsgi
|
||||
|
||||
|
||||
class Portprofile(object):
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Nicira Networks, Inc. All rights reserved.
|
||||
@ -16,17 +15,15 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Brad Hall, Nicira Networks, Inc
|
||||
#
|
||||
"""
|
||||
|
||||
import logging
|
||||
|
||||
from quantum import wsgi
|
||||
from quantum.extensions import _portstats_view as portstats_view
|
||||
from quantum.api import faults
|
||||
from quantum.common import exceptions as qexception
|
||||
from quantum.common import extensions
|
||||
from quantum.extensions import _portstats_view as portstats_view
|
||||
from quantum.manager import QuantumManager
|
||||
from quantum import wsgi
|
||||
|
||||
|
||||
LOG = logging.getLogger("quantum.api.portstats")
|
||||
@ -61,8 +58,8 @@ class Portstats(object):
|
||||
""" Returns all defined resources """
|
||||
controller = StatsController(QuantumManager.get_plugin())
|
||||
parent_resource = dict(member_name="port",
|
||||
collection_name="extensions/ovs/tenants/" + \
|
||||
":(tenant_id)/networks/:(network_id)/ports")
|
||||
collection_name="extensions/ovs/tenants/"
|
||||
":(tenant_id)/ networks/:(network_id)/ports")
|
||||
return [extensions.ResourceExtension('stats', controller,
|
||||
parent=parent_resource)]
|
||||
|
||||
@ -84,12 +81,10 @@ class StatsController(wsgi.Controller):
|
||||
def _show(self, request, tenant_id, network_id, port_id):
|
||||
"""Returns port statistics for a given port"""
|
||||
if not hasattr(self._plugin, "get_port_stats"):
|
||||
return \
|
||||
faults.QuantumHTTPError(
|
||||
return faults.QuantumHTTPError(
|
||||
qexception.NotImplementedError("get_port_stats"))
|
||||
|
||||
stats = self._plugin.get_port_stats(tenant_id, network_id,
|
||||
port_id)
|
||||
stats = self._plugin.get_port_stats(tenant_id, network_id, port_id)
|
||||
builder = portstats_view.get_view_builder(request)
|
||||
result = builder.build(stats, True)
|
||||
return dict(stats=result)
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,18 +15,18 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Ying Liu, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import logging
|
||||
|
||||
from quantum import wsgi
|
||||
from webob import exc
|
||||
from quantum.extensions import _qos_view as qos_view
|
||||
|
||||
from quantum.api import api_common as common
|
||||
from quantum.extensions import _qos_view as qos_view
|
||||
from quantum.extensions import extensions
|
||||
from quantum.manager import QuantumManager
|
||||
from quantum.plugins.cisco.common import cisco_exceptions as exception
|
||||
from quantum.plugins.cisco.common import cisco_faults as faults
|
||||
from quantum import wsgi
|
||||
|
||||
|
||||
LOG = logging.getLogger('quantum.api.qoss')
|
||||
@ -78,11 +77,11 @@ class QosController(common.QuantumController, wsgi.Controller):
|
||||
""" qos API controller
|
||||
based on QuantumController """
|
||||
|
||||
_qos_ops_param_list = [{
|
||||
'param-name': 'qos_name',
|
||||
'required': True}, {
|
||||
'param-name': 'qos_desc',
|
||||
'required': True}]
|
||||
_qos_ops_param_list = [
|
||||
{'param-name': 'qos_name', 'required': True},
|
||||
{'param-name': 'qos_desc', 'required': True},
|
||||
]
|
||||
|
||||
_serialization_metadata = {
|
||||
"application/xml": {
|
||||
"attributes": {
|
||||
@ -103,16 +102,14 @@ class QosController(common.QuantumController, wsgi.Controller):
|
||||
""" Returns a list of qoss. """
|
||||
qoss = self._plugin.get_all_qoss(tenant_id)
|
||||
builder = qos_view.get_view_builder(request)
|
||||
result = [builder.build(qos, is_detail)['qos']
|
||||
for qos in qoss]
|
||||
result = [builder.build(qos, is_detail)['qos'] for qos in qoss]
|
||||
return dict(qoss=result)
|
||||
|
||||
# pylint: disable-msg=E1101
|
||||
def show(self, request, tenant_id, id):
|
||||
""" Returns qos details for the given qos id """
|
||||
try:
|
||||
qos = self._plugin.get_qos_details(
|
||||
tenant_id, id)
|
||||
qos = self._plugin.get_qos_details(tenant_id, id)
|
||||
builder = qos_view.get_view_builder(request)
|
||||
#build response with details
|
||||
result = builder.build(qos, True)
|
||||
@ -125,14 +122,12 @@ class QosController(common.QuantumController, wsgi.Controller):
|
||||
#look for qos name in request
|
||||
try:
|
||||
body = self._deserialize(request.body, request.get_content_type())
|
||||
req_body = \
|
||||
self._prepare_request_body(body,
|
||||
req_body = self._prepare_request_body(body,
|
||||
self._qos_ops_param_list)
|
||||
req_params = req_body[self._resource_name]
|
||||
except exc.HTTPError as exp:
|
||||
return faults.Fault(exp)
|
||||
qos = self._plugin.\
|
||||
create_qos(tenant_id,
|
||||
qos = self._plugin.create_qos(tenant_id,
|
||||
req_params['qos_name'],
|
||||
req_params['qos_desc'])
|
||||
builder = qos_view.get_view_builder(request)
|
||||
@ -143,16 +138,14 @@ class QosController(common.QuantumController, wsgi.Controller):
|
||||
""" Updates the name for the qos with the given id """
|
||||
try:
|
||||
body = self._deserialize(request.body, request.get_content_type())
|
||||
req_body = \
|
||||
self._prepare_request_body(body,
|
||||
req_body = self._prepare_request_body(body,
|
||||
self._qos_ops_param_list)
|
||||
req_params = req_body[self._resource_name]
|
||||
except exc.HTTPError as exp:
|
||||
return faults.Fault(exp)
|
||||
try:
|
||||
qos = self._plugin.\
|
||||
rename_qos(tenant_id,
|
||||
id, req_params['qos_name'])
|
||||
qos = self._plugin.rename_qos(tenant_id, id,
|
||||
req_params['qos_name'])
|
||||
|
||||
builder = qos_view.get_view_builder(request)
|
||||
result = builder.build(qos, True)
|
||||
|
@ -16,27 +16,26 @@
|
||||
# under the License.
|
||||
# @author: Somik Behera, Nicira Networks, Inc.
|
||||
|
||||
|
||||
"""
|
||||
Quantum's Manager class is responsible for parsing a config file and
|
||||
instantiating the correct plugin that concretely implement quantum_plugin_base
|
||||
class.
|
||||
The caller should make sure that QuantumManager is a singleton.
|
||||
"""
|
||||
import gettext
|
||||
|
||||
import logging
|
||||
import os
|
||||
|
||||
gettext.install('quantum', unicode=1)
|
||||
|
||||
from quantum.common import utils
|
||||
from quantum.common.config import find_config_file
|
||||
from quantum.common.exceptions import ClassNotFound
|
||||
from quantum_plugin_base import QuantumPluginBase
|
||||
from quantum.quantum_plugin_base import QuantumPluginBase
|
||||
|
||||
|
||||
LOG = logging.getLogger('quantum.manager')
|
||||
|
||||
|
||||
CONFIG_FILE = "plugins.ini"
|
||||
LOG = logging.getLogger('quantum.manager')
|
||||
|
||||
|
||||
def find_config(basepath):
|
||||
@ -61,23 +60,23 @@ class QuantumManager(object):
|
||||
self.configuration_file = find_config_file(options, config_file,
|
||||
CONFIG_FILE)
|
||||
if not 'plugin_provider' in options:
|
||||
options['plugin_provider'] = \
|
||||
utils.get_plugin_from_config(self.configuration_file)
|
||||
options['plugin_provider'] = utils.get_plugin_from_config(
|
||||
self.configuration_file)
|
||||
LOG.debug("Plugin location:%s", options['plugin_provider'])
|
||||
|
||||
# If the plugin can't be found let them know gracefully
|
||||
try:
|
||||
plugin_klass = utils.import_class(options['plugin_provider'])
|
||||
except ClassNotFound:
|
||||
raise Exception("Plugin not found. You can install a " \
|
||||
"plugin with: pip install <plugin-name>\n" \
|
||||
raise Exception("Plugin not found. You can install a "
|
||||
"plugin with: pip install <plugin-name>\n"
|
||||
"Example: pip install quantum-sample-plugin")
|
||||
|
||||
if not issubclass(plugin_klass, QuantumPluginBase):
|
||||
raise Exception("Configured Quantum plug-in " \
|
||||
raise Exception("Configured Quantum plug-in "
|
||||
"didn't pass compatibility test")
|
||||
else:
|
||||
LOG.debug("Successfully imported Quantum plug-in." \
|
||||
LOG.debug("Successfully imported Quantum plug-in."
|
||||
"All compatibility tests passed")
|
||||
self.plugin = plugin_klass()
|
||||
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -17,4 +16,3 @@
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,5 +15,3 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -24,27 +23,22 @@
|
||||
# Cisco adaptation for extensions
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
# @author: Ying Liu, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import gettext
|
||||
import logging
|
||||
import logging.handlers
|
||||
from optparse import OptionParser
|
||||
import os
|
||||
import sys
|
||||
import subprocess
|
||||
|
||||
from optparse import OptionParser
|
||||
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantumclient import Client
|
||||
import quantumclient.cli as qcli
|
||||
|
||||
|
||||
gettext.install('quantum', unicode=1)
|
||||
|
||||
|
||||
LOG = logging.getLogger('quantum')
|
||||
|
||||
|
||||
FORMAT = 'json'
|
||||
ACTION_PREFIX_EXT = '/v1.0'
|
||||
ACTION_PREFIX_CSCO = ACTION_PREFIX_EXT + \
|
||||
@ -58,8 +52,8 @@ def help():
|
||||
"""Help for CLI"""
|
||||
print "\nCisco Extension Commands:"
|
||||
for key in COMMANDS.keys():
|
||||
print " %s %s" % (key,
|
||||
" ".join(["<%s>" % y for y in COMMANDS[key]["args"]]))
|
||||
print " %s %s" % (
|
||||
key, " ".join(["<%s>" % y for y in COMMANDS[key]["args"]]))
|
||||
|
||||
|
||||
def build_args(cmd, cmdargs, arglist):
|
||||
@ -73,14 +67,14 @@ def build_args(cmd, cmdargs, arglist):
|
||||
except:
|
||||
LOG.error("Not enough arguments for \"%s\" (expected: %d, got: %d)" % (
|
||||
cmd, len(cmdargs), len(orig_arglist)))
|
||||
print "Usage:\n %s %s" % (cmd,
|
||||
" ".join(["<%s>" % y for y in COMMANDS[cmd]["args"]]))
|
||||
print "Usage:\n %s %s" % (
|
||||
cmd, " ".join(["<%s>" % y for y in COMMANDS[cmd]["args"]]))
|
||||
sys.exit()
|
||||
if len(arglist) > 0:
|
||||
LOG.error("Too many arguments for \"%s\" (expected: %d, got: %d)" % (
|
||||
cmd, len(cmdargs), len(orig_arglist)))
|
||||
print "Usage:\n %s %s" % (cmd,
|
||||
" ".join(["<%s>" % y for y in COMMANDS[cmd]["args"]]))
|
||||
print "Usage:\n %s %s" % (
|
||||
cmd, " ".join(["<%s>" % y for y in COMMANDS[cmd]["args"]]))
|
||||
sys.exit()
|
||||
return args
|
||||
|
||||
@ -98,12 +92,15 @@ def schedule_host(tenant_id, instance_id, user_id=None):
|
||||
"""Gets the host name from the Quantum service"""
|
||||
project_id = tenant_id
|
||||
|
||||
instance_data_dict = \
|
||||
{'novatenant': \
|
||||
{'instance_id': instance_id,
|
||||
'instance_desc': \
|
||||
{'user_id': user_id,
|
||||
'project_id': project_id}}}
|
||||
instance_data_dict = {
|
||||
'novatenant': {
|
||||
'instance_id': instance_id,
|
||||
'instance_desc': {
|
||||
'user_id': user_id,
|
||||
'project_id': project_id,
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
request_url = "/novatenants/" + project_id + "/schedule_host"
|
||||
client = Client(HOST, PORT, USE_SSL, format='json', tenant=TENANT_ID,
|
||||
@ -112,8 +109,8 @@ def schedule_host(tenant_id, instance_id, user_id=None):
|
||||
|
||||
hostname = data["host_list"]["host_1"]
|
||||
if not hostname:
|
||||
print("Scheduler was unable to locate a host" + \
|
||||
" for this request. Is the appropriate" + \
|
||||
print("Scheduler was unable to locate a host"
|
||||
" for this request. Is the appropriate"
|
||||
" service running?")
|
||||
|
||||
print("Quantum service returned host: %s" % hostname)
|
||||
@ -122,7 +119,7 @@ def schedule_host(tenant_id, instance_id, user_id=None):
|
||||
def create_multiport(tenant_id, net_id_list, *args):
|
||||
"""Creates ports on a single host"""
|
||||
net_list = net_id_list.split(",")
|
||||
ports_info = {'multiport': \
|
||||
ports_info = {'multiport':
|
||||
{'status': 'ACTIVE',
|
||||
'net_id_list': net_list,
|
||||
'ports_desc': {'key': 'value'}}}
|
||||
@ -139,13 +136,17 @@ COMMANDS = {
|
||||
"create_multiport": {
|
||||
"func": create_multiport,
|
||||
"args": ["tenant-id",
|
||||
"net-id-list (comma separated list of netword IDs)"]},
|
||||
"net-id-list (comma separated list of netword IDs)"],
|
||||
},
|
||||
"list_extensions": {
|
||||
"func": list_extensions,
|
||||
"args": []},
|
||||
"args": [],
|
||||
},
|
||||
"schedule_host": {
|
||||
"func": schedule_host,
|
||||
"args": ["tenant-id", "instance-id"]}, }
|
||||
"args": ["tenant-id", "instance-id"],
|
||||
},
|
||||
}
|
||||
|
||||
|
||||
def main():
|
||||
@ -153,16 +154,19 @@ def main():
|
||||
usagestr = "Usage: %prog [OPTIONS] <command> [args]"
|
||||
PARSER = OptionParser(usage=usagestr)
|
||||
PARSER.add_option("-H", "--host", dest="host",
|
||||
type="string", default="127.0.0.1", help="ip address of api host")
|
||||
type="string", default="127.0.0.1",
|
||||
help="ip address of api host")
|
||||
PARSER.add_option("-p", "--port", dest="port",
|
||||
type="int", default=9696, help="api poort")
|
||||
PARSER.add_option("-s", "--ssl", dest="ssl",
|
||||
action="store_true", default=False, help="use ssl")
|
||||
PARSER.add_option("-v", "--verbose", dest="verbose",
|
||||
action="store_true", default=False, help="turn on verbose logging")
|
||||
action="store_true", default=False,
|
||||
help="turn on verbose logging")
|
||||
PARSER.add_option("-f", "--logfile", dest="logfile",
|
||||
type="string", default="syslog", help="log file path")
|
||||
PARSER.add_option('--version', default=DEFAULT_QUANTUM_VERSION,
|
||||
PARSER.add_option(
|
||||
'--version', default=DEFAULT_QUANTUM_VERSION,
|
||||
help='Accepts 1.1 and 1.0, defaults to env[QUANTUM_VERSION].')
|
||||
options, args = PARSER.parse_args()
|
||||
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,5 +15,3 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,10 +15,9 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
from configobj import ConfigObj
|
||||
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
|
||||
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,8 +15,7 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
|
||||
PLUGINS = 'PLUGINS'
|
||||
INVENTORY = 'INVENTORY'
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,8 +15,6 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import os
|
||||
import logging as LOG
|
||||
@ -28,6 +25,7 @@ from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.common import cisco_exceptions as cexc
|
||||
from quantum.plugins.cisco.db import l2network_db as cdb
|
||||
|
||||
|
||||
LOG.basicConfig(level=LOG.WARN)
|
||||
LOG.getLogger(const.LOGGER_COMPONENT_NAME)
|
||||
|
||||
|
@ -20,68 +20,69 @@
|
||||
"""
|
||||
Exceptions used by the Cisco plugin
|
||||
"""
|
||||
|
||||
from quantum.common import exceptions
|
||||
|
||||
|
||||
class NoMoreNics(exceptions.QuantumException):
|
||||
"""No more dynamic nics are available in the system"""
|
||||
message = _("Unable to complete operation. No more dynamic nics are " \
|
||||
message = _("Unable to complete operation. No more dynamic nics are "
|
||||
"available in the system.")
|
||||
|
||||
|
||||
class PortProfileLimit(exceptions.QuantumException):
|
||||
"""Port profile limit has been hit"""
|
||||
message = _("Unable to complete operation on port %(port_id)s " \
|
||||
"for network %(net_id)s. The system has reached the maximum" \
|
||||
message = _("Unable to complete operation on port %(port_id)s "
|
||||
"for network %(net_id)s. The system has reached the maximum"
|
||||
"limit of allowed port profiles.")
|
||||
|
||||
|
||||
class UCSMPortProfileLimit(exceptions.QuantumException):
|
||||
"""UCSM Port profile limit has been hit"""
|
||||
message = _("Unable to complete operation on port %(port_id)s " \
|
||||
"for network %(net_id)s. The system has reached the maximum" \
|
||||
message = _("Unable to complete operation on port %(port_id)s "
|
||||
"for network %(net_id)s. The system has reached the maximum"
|
||||
"limit of allowed UCSM port profiles.")
|
||||
|
||||
|
||||
class NetworksLimit(exceptions.QuantumException):
|
||||
"""Total number of network objects limit has been hit"""
|
||||
message = _("Unable to create new network. Number of networks" \
|
||||
message = _("Unable to create new network. Number of networks"
|
||||
"for the system has exceeded the limit")
|
||||
|
||||
|
||||
class PortProfileNotFound(exceptions.QuantumException):
|
||||
"""Port profile cannot be found"""
|
||||
message = _("Port profile %(portprofile_id)s could not be found " \
|
||||
message = _("Port profile %(portprofile_id)s could not be found "
|
||||
"for tenant %(tenant_id)s")
|
||||
|
||||
|
||||
class MultiportNotFound(exceptions.QuantumException):
|
||||
"""Multiport cannot be found"""
|
||||
message = _("Multiports %(port_id)s could not be found " \
|
||||
message = _("Multiports %(port_id)s could not be found "
|
||||
"for tenant %(tenant_id)s")
|
||||
|
||||
|
||||
class PortProfileInvalidDelete(exceptions.QuantumException):
|
||||
"""Port profile cannot be deleted since its being used"""
|
||||
message = _("Port profile %(profile_id)s could not be deleted " \
|
||||
message = _("Port profile %(profile_id)s could not be deleted "
|
||||
"for tenant %(tenant_id)s since port associations exist")
|
||||
|
||||
|
||||
class NetworkVlanBindingAlreadyExists(exceptions.QuantumException):
|
||||
"""Binding cannot be created, since it already exists"""
|
||||
message = _("NetworkVlanBinding for %(vlan_id)s and network " \
|
||||
message = _("NetworkVlanBinding for %(vlan_id)s and network "
|
||||
"%(network_id)s already exists")
|
||||
|
||||
|
||||
class PortProfileAlreadyExists(exceptions.QuantumException):
|
||||
"""Port profile cannot be created since it already exisits"""
|
||||
message = _("PortProfile %(pp_name) for %(tenant_id)s " \
|
||||
message = _("PortProfile %(pp_name) for %(tenant_id)s "
|
||||
"already exists")
|
||||
|
||||
|
||||
class PortProfileBindingAlreadyExists(exceptions.QuantumException):
|
||||
"""Binding cannot be created, since it already exists"""
|
||||
message = _("PortProfileBinding for port profile %(pp_id)s to " \
|
||||
message = _("PortProfileBinding for port profile %(pp_id)s to "
|
||||
"port %(port_id) already exists")
|
||||
|
||||
|
||||
@ -97,37 +98,37 @@ class VlanIDNotAvailable(exceptions.QuantumException):
|
||||
|
||||
class QosNotFound(exceptions.QuantumException):
|
||||
"""QoS level with this ID cannot be found"""
|
||||
message = _("QoS level %(qos_id)s could not be found " \
|
||||
message = _("QoS level %(qos_id)s could not be found "
|
||||
"for tenant %(tenant_id)s")
|
||||
|
||||
|
||||
class QoSLevelInvalidDelete(exceptions.QuantumException):
|
||||
"""QoS is associated with a port profile, hence cannot be deleted"""
|
||||
message = _("QoS level %(qos_id)s could not be deleted " \
|
||||
message = _("QoS level %(qos_id)s could not be deleted "
|
||||
"for tenant %(tenant_id)s since association exists")
|
||||
|
||||
|
||||
class QosNameAlreadyExists(exceptions.QuantumException):
|
||||
"""QoS Name already exists"""
|
||||
message = _("QoS level with name %(qos_name)s already exists " \
|
||||
message = _("QoS level with name %(qos_name)s already exists "
|
||||
"for tenant %(tenant_id)s")
|
||||
|
||||
|
||||
class CredentialNotFound(exceptions.QuantumException):
|
||||
"""Credential with this ID cannot be found"""
|
||||
message = _("Credential %(credential_id)s could not be found " \
|
||||
message = _("Credential %(credential_id)s could not be found "
|
||||
"for tenant %(tenant_id)s")
|
||||
|
||||
|
||||
class CredentialNameNotFound(exceptions.QuantumException):
|
||||
"""Credential Name could not be found"""
|
||||
message = _("Credential %(credential_name)s could not be found " \
|
||||
message = _("Credential %(credential_name)s could not be found "
|
||||
"for tenant %(tenant_id)s")
|
||||
|
||||
|
||||
class CredentialAlreadyExists(exceptions.QuantumException):
|
||||
"""Credential ID already exists"""
|
||||
message = _("Credential %(credential_id)s already exists " \
|
||||
message = _("Credential %(credential_id)s already exists "
|
||||
"for tenant %(tenant_id)s")
|
||||
|
||||
|
||||
@ -177,23 +178,8 @@ class PortVnicNotFound(exceptions.QuantumException):
|
||||
|
||||
|
||||
class InvalidAttach(exceptions.QuantumException):
|
||||
message = _("Unable to plug the attachment %(att_id)s into port " \
|
||||
"%(port_id)s for network %(net_id)s. Association of " \
|
||||
"attachment ID with port ID happens implicitly when " \
|
||||
"VM is instantiated; attach operation can be " \
|
||||
message = _("Unable to plug the attachment %(att_id)s into port "
|
||||
"%(port_id)s for network %(net_id)s. Association of "
|
||||
"attachment ID with port ID happens implicitly when "
|
||||
"VM is instantiated; attach operation can be "
|
||||
"performed subsequently.")
|
||||
|
||||
|
||||
try:
|
||||
_("test")
|
||||
except NameError:
|
||||
|
||||
def _(a_string):
|
||||
"""
|
||||
Default implementation of the gettext string
|
||||
translation function: no translation
|
||||
"""
|
||||
return a_string
|
||||
except TypeError:
|
||||
# during doctesting, _ might mean something else
|
||||
pass
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,8 +15,7 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Ying Liu, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import webob.dec
|
||||
|
||||
from quantum import wsgi
|
||||
@ -73,7 +71,7 @@ class PortprofileNotFound(webob.exc.HTTPClientError):
|
||||
code = 450
|
||||
title = 'Portprofile Not Found'
|
||||
explanation = ('Unable to find a Portprofile with'
|
||||
+ ' the specified identifier.')
|
||||
' the specified identifier.')
|
||||
|
||||
|
||||
class PortNotFound(webob.exc.HTTPClientError):
|
||||
@ -102,7 +100,7 @@ class CredentialNotFound(webob.exc.HTTPClientError):
|
||||
code = 451
|
||||
title = 'Credential Not Found'
|
||||
explanation = ('Unable to find a Credential with'
|
||||
+ ' the specified identifier.')
|
||||
' the specified identifier.')
|
||||
|
||||
|
||||
class QosNotFound(webob.exc.HTTPClientError):
|
||||
@ -117,7 +115,7 @@ class QosNotFound(webob.exc.HTTPClientError):
|
||||
code = 452
|
||||
title = 'QoS Not Found'
|
||||
explanation = ('Unable to find a QoS with'
|
||||
+ ' the specified identifier.')
|
||||
' the specified identifier.')
|
||||
|
||||
|
||||
class NovatenantNotFound(webob.exc.HTTPClientError):
|
||||
@ -132,7 +130,7 @@ class NovatenantNotFound(webob.exc.HTTPClientError):
|
||||
code = 453
|
||||
title = 'Nova tenant Not Found'
|
||||
explanation = ('Unable to find a Novatenant with'
|
||||
+ ' the specified identifier.')
|
||||
' the specified identifier.')
|
||||
|
||||
|
||||
class MultiportNotFound(webob.exc.HTTPClientError):
|
||||
@ -147,7 +145,7 @@ class MultiportNotFound(webob.exc.HTTPClientError):
|
||||
code = 454
|
||||
title = 'Multiport Not Found'
|
||||
explanation = ('Unable to find Multiport with'
|
||||
+ ' the specified identifier.')
|
||||
' the specified identifier.')
|
||||
|
||||
|
||||
class RequestedStateInvalid(webob.exc.HTTPClientError):
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,18 +15,18 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import hashlib
|
||||
import logging
|
||||
import MySQLdb
|
||||
import traceback
|
||||
|
||||
import MySQLdb
|
||||
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.db import api as db
|
||||
from quantum.plugins.cisco.db import l2network_db as cdb
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,11 +15,9 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import inspect
|
||||
from abc import ABCMeta, abstractmethod
|
||||
import inspect
|
||||
|
||||
|
||||
class L2NetworkDeviceInventoryBase(object):
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,11 +15,9 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import inspect
|
||||
from abc import ABCMeta, abstractmethod
|
||||
import inspect
|
||||
|
||||
|
||||
class L2DevicePluginBase(object):
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,11 +15,9 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import inspect
|
||||
from abc import ABCMeta, abstractmethod
|
||||
import inspect
|
||||
|
||||
|
||||
class L2NetworkModelBase(object):
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,8 +15,6 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import inspect
|
||||
import logging
|
||||
@ -26,7 +23,6 @@ import re
|
||||
from quantum.common import exceptions as exc
|
||||
from quantum.common import utils
|
||||
from quantum.quantum_plugin_base import QuantumPluginBase
|
||||
|
||||
from quantum.plugins.cisco import l2network_plugin_configuration as conf
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.common import cisco_credentials as cred
|
||||
@ -35,6 +31,7 @@ from quantum.plugins.cisco.common import cisco_utils as cutil
|
||||
from quantum.plugins.cisco.db import api as db
|
||||
from quantum.plugins.cisco.db import l2network_db as cdb
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
@ -491,7 +488,8 @@ class L2Network(QuantumPluginBase):
|
||||
def schedule_host(self, tenant_id, instance_id, instance_desc):
|
||||
"""Provides the hostname on which a dynamic vnic is reserved"""
|
||||
LOG.debug("schedule_host() called\n")
|
||||
host_list = self._invoke_device_plugins(self._func_name(), [tenant_id,
|
||||
host_list = self._invoke_device_plugins(self._func_name(),
|
||||
[tenant_id,
|
||||
instance_id,
|
||||
instance_desc])
|
||||
return host_list
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -17,18 +16,18 @@
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
# @author: Rohit Agarwalla, Cisco Systems, Inc.
|
||||
"""
|
||||
|
||||
import os
|
||||
|
||||
from quantum.common.config import find_config_file
|
||||
from quantum.plugins.cisco.common import cisco_configparser as confp
|
||||
|
||||
|
||||
CONF_FILE = find_config_file({'plugin': 'cisco'}, None, "l2network_plugin.ini")
|
||||
CONF_PARSER_OBJ = confp.CiscoConfigParser(CONF_FILE)
|
||||
|
||||
"""
|
||||
Reading the conf for the l2network_plugin
|
||||
"""
|
||||
|
||||
# Read the conf for the l2network_plugin
|
||||
SECTION_CONF = CONF_PARSER_OBJ['VLANS']
|
||||
VLAN_NAME_PREFIX = SECTION_CONF['vlan_name_prefix']
|
||||
VLAN_START = SECTION_CONF['vlan_start']
|
||||
@ -54,18 +53,16 @@ MANAGER_CLASS = SECTION_CONF['manager_class']
|
||||
|
||||
CONF_PARSER_OBJ = confp.CiscoConfigParser(CONF_FILE)
|
||||
|
||||
"""
|
||||
Reading the config for the device plugins
|
||||
"""
|
||||
|
||||
# Read the config for the device plugins
|
||||
PLUGINS = CONF_PARSER_OBJ.walk(CONF_PARSER_OBJ.dummy)
|
||||
|
||||
CONF_FILE = find_config_file({'plugin': 'cisco'}, None, "db_conn.ini")
|
||||
|
||||
CONF_PARSER_OBJ = confp.CiscoConfigParser(CONF_FILE)
|
||||
|
||||
"""
|
||||
Reading DB config for the Quantum DB
|
||||
"""
|
||||
|
||||
# Read DB config for the Quantum DB
|
||||
SECTION_CONF = CONF_PARSER_OBJ['DATABASE']
|
||||
DB_NAME = SECTION_CONF['name']
|
||||
DB_USER = SECTION_CONF['user']
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,11 +15,9 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import inspect
|
||||
from abc import ABCMeta, abstractmethod
|
||||
import inspect
|
||||
|
||||
|
||||
class L2NetworkSegmentationMgrBase(object):
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,5 +15,3 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,8 +15,6 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
from copy import deepcopy
|
||||
import inspect
|
||||
@ -31,6 +28,7 @@ from quantum.plugins.cisco import l2network_plugin_configuration as conf
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.common import cisco_exceptions as cexc
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
@ -49,12 +47,12 @@ class L2NetworkMultiBlade(L2NetworkModelBase):
|
||||
for key in conf.PLUGINS[const.PLUGINS].keys():
|
||||
self._plugins[key] = utils.import_object(
|
||||
conf.PLUGINS[const.PLUGINS][key])
|
||||
LOG.debug("Loaded device plugin %s\n" % \
|
||||
LOG.debug("Loaded device plugin %s\n" %
|
||||
conf.PLUGINS[const.PLUGINS][key])
|
||||
if key in conf.PLUGINS[const.INVENTORY].keys():
|
||||
self._inventory[key] = utils.import_object(
|
||||
conf.PLUGINS[const.INVENTORY][key])
|
||||
LOG.debug("Loaded device inventory %s\n" % \
|
||||
LOG.debug("Loaded device inventory %s\n" %
|
||||
conf.PLUGINS[const.INVENTORY][key])
|
||||
|
||||
def _func_name(self, offset=0):
|
||||
@ -65,8 +63,8 @@ class L2NetworkMultiBlade(L2NetworkModelBase):
|
||||
"""Invoke only device plugin for all the devices in the system"""
|
||||
if not plugin_key in self._plugins.keys():
|
||||
LOG.info("No %s Plugin loaded" % plugin_key)
|
||||
LOG.info("%s: %s with args %s ignored" \
|
||||
% (plugin_key, function_name, args))
|
||||
LOG.info("%s: %s with args %s ignored" %
|
||||
(plugin_key, function_name, args))
|
||||
return
|
||||
device_params = self._invoke_inventory(plugin_key, function_name,
|
||||
args)
|
||||
@ -89,8 +87,8 @@ class L2NetworkMultiBlade(L2NetworkModelBase):
|
||||
"""Invoke only the inventory implementation"""
|
||||
if not plugin_key in self._inventory.keys():
|
||||
LOG.warn("No %s inventory loaded" % plugin_key)
|
||||
LOG.warn("%s: %s with args %s ignored" \
|
||||
% (plugin_key, function_name, args))
|
||||
LOG.warn("%s: %s with args %s ignored" %
|
||||
(plugin_key, function_name, args))
|
||||
return {const.DEVICE_IP: []}
|
||||
else:
|
||||
return getattr(self._inventory[plugin_key], function_name)(args)
|
||||
@ -101,8 +99,7 @@ class L2NetworkMultiBlade(L2NetworkModelBase):
|
||||
|
||||
# If there are more args than needed, add them to kwargs
|
||||
args_copy = deepcopy(args)
|
||||
if args.__len__() + 1 > \
|
||||
inspect.getargspec(func).args.__len__():
|
||||
if (args.__len__() + 1) > inspect.getargspec(func).args.__len__():
|
||||
kwargs.update(args_copy.pop())
|
||||
|
||||
return func(*args_copy, **kwargs)
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,8 +15,6 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
from copy import deepcopy
|
||||
import inspect
|
||||
@ -31,6 +28,7 @@ from quantum.plugins.cisco import l2network_plugin_configuration as conf
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.common import cisco_exceptions as cexc
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
@ -46,12 +44,12 @@ class L2NetworkSingleBlade(L2NetworkModelBase):
|
||||
for key in conf.PLUGINS[const.PLUGINS].keys():
|
||||
self._plugins[key] = utils.import_object(
|
||||
conf.PLUGINS[const.PLUGINS][key])
|
||||
LOG.debug("Loaded device plugin %s\n" % \
|
||||
LOG.debug("Loaded device plugin %s\n" %
|
||||
conf.PLUGINS[const.PLUGINS][key])
|
||||
if key in conf.PLUGINS[const.INVENTORY].keys():
|
||||
self._inventory[key] = utils.import_object(
|
||||
conf.PLUGINS[const.INVENTORY][key])
|
||||
LOG.debug("Loaded device inventory %s\n" % \
|
||||
LOG.debug("Loaded device inventory %s\n" %
|
||||
conf.PLUGINS[const.INVENTORY][key])
|
||||
|
||||
def _func_name(self, offset=0):
|
||||
@ -62,8 +60,8 @@ class L2NetworkSingleBlade(L2NetworkModelBase):
|
||||
"""Invoke only device plugin for all the devices in the system"""
|
||||
if not plugin_key in self._plugins.keys():
|
||||
LOG.info("No %s Plugin loaded" % plugin_key)
|
||||
LOG.info("%s: %s with args %s ignored" \
|
||||
% (plugin_key, function_name, args))
|
||||
LOG.info("%s: %s with args %s ignored" %
|
||||
(plugin_key, function_name, args))
|
||||
return
|
||||
device_params = self._invoke_inventory(plugin_key, function_name,
|
||||
args)
|
||||
@ -82,8 +80,8 @@ class L2NetworkSingleBlade(L2NetworkModelBase):
|
||||
"""Invoke only the inventory implementation"""
|
||||
if not plugin_key in self._inventory.keys():
|
||||
LOG.warn("No %s inventory loaded" % plugin_key)
|
||||
LOG.warn("%s: %s with args %s ignored" \
|
||||
% (plugin_key, function_name, args))
|
||||
LOG.warn("%s: %s with args %s ignored" %
|
||||
(plugin_key, function_name, args))
|
||||
return {const.DEVICE_IP: []}
|
||||
else:
|
||||
return getattr(self._inventory[plugin_key], function_name)(args)
|
||||
|
@ -27,6 +27,7 @@ import os
|
||||
from quantum.common.config import find_config_file
|
||||
from quantum.plugins.cisco.common import cisco_configparser as confp
|
||||
|
||||
|
||||
CP = confp.CiscoConfigParser(find_config_file({'plugin': 'cisco'}, None,
|
||||
"nexus.ini"))
|
||||
|
||||
|
@ -23,11 +23,12 @@ Implements a Nexus-OS NETCONF over SSHv2 API Client
|
||||
|
||||
import logging
|
||||
|
||||
from ncclient import manager
|
||||
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.db import l2network_db as cdb
|
||||
from quantum.plugins.cisco.nexus import cisco_nexus_snippets as snipp
|
||||
|
||||
from ncclient import manager
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
@ -32,6 +32,7 @@ from quantum.plugins.cisco.db import nexus_db as nxos_db
|
||||
from quantum.plugins.cisco.l2device_plugin_base import L2DevicePluginBase
|
||||
from quantum.plugins.cisco.nexus import cisco_nexus_configuration as conf
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
@ -70,7 +71,8 @@ class NexusPlugin(L2DevicePluginBase):
|
||||
for this VLAN
|
||||
"""
|
||||
LOG.debug("NexusPlugin:create_network() called\n")
|
||||
self._client.create_vlan(vlan_name, str(vlan_id), self._nexus_ip,
|
||||
self._client.create_vlan(
|
||||
vlan_name, str(vlan_id), self._nexus_ip,
|
||||
self._nexus_username, self._nexus_password,
|
||||
self._nexus_first_port, self._nexus_second_port,
|
||||
self._nexus_ssh_port)
|
||||
@ -97,7 +99,8 @@ class NexusPlugin(L2DevicePluginBase):
|
||||
nxos_db.remove_nexusport_binding(vlan_id)
|
||||
net = self._get_network(tenant_id, net_id)
|
||||
if net:
|
||||
self._client.delete_vlan(str(vlan_id), self._nexus_ip,
|
||||
self._client.delete_vlan(
|
||||
str(vlan_id), self._nexus_ip,
|
||||
self._nexus_username, self._nexus_password,
|
||||
self._nexus_first_port, self._nexus_second_port,
|
||||
self._nexus_ssh_port)
|
||||
|
@ -24,6 +24,7 @@ import logging
|
||||
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
|
@ -26,13 +26,14 @@ from nova import exception as excp
|
||||
from nova import flags
|
||||
from nova import log as logging
|
||||
from nova.openstack.common import cfg
|
||||
from nova.scheduler import driver
|
||||
from nova.scheduler import chance
|
||||
from quantum.client import Client
|
||||
from nova.scheduler import driver
|
||||
from quantumclient import Client
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
quantum_opts = [
|
||||
cfg.StrOpt('quantum_connection_host',
|
||||
default='127.0.0.1',
|
||||
@ -45,6 +46,7 @@ quantum_opts = [
|
||||
help='Default tenant id when creating quantum networks'),
|
||||
]
|
||||
|
||||
|
||||
FLAGS = flags.FLAGS
|
||||
FLAGS.register_opts(quantum_opts)
|
||||
|
||||
@ -88,15 +90,12 @@ class QuantumPortAwareScheduler(chance.ChanceScheduler):
|
||||
"""Gets the host name from the Quantum service"""
|
||||
LOG.debug("Cisco Quantum Port-aware Scheduler is scheduling...")
|
||||
instance_id = request_spec['instance_properties']['uuid']
|
||||
user_id = \
|
||||
request_spec['instance_properties']['user_id']
|
||||
project_id = \
|
||||
request_spec['instance_properties']['project_id']
|
||||
user_id = request_spec['instance_properties']['user_id']
|
||||
project_id = request_spec['instance_properties']['project_id']
|
||||
|
||||
instance_data_dict = \
|
||||
{'novatenant': \
|
||||
instance_data_dict = {'novatenant':
|
||||
{'instance_id': instance_id,
|
||||
'instance_desc': \
|
||||
'instance_desc':
|
||||
{'user_id': user_id,
|
||||
'project_id': project_id}}}
|
||||
|
||||
|
@ -24,7 +24,7 @@ from nova import flags
|
||||
from nova import log as logging
|
||||
from nova.openstack.common import cfg
|
||||
from nova.virt.vif import VIFDriver
|
||||
from quantum.client import Client
|
||||
from quantumclient import Client
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
@ -26,9 +26,12 @@ export PLUGIN_DIR=quantum/plugins/cisco
|
||||
|
||||
import os
|
||||
import sys
|
||||
|
||||
from nose import config
|
||||
|
||||
sys.path.append(os.getcwd())
|
||||
sys.path.append(os.path.dirname(__file__))
|
||||
|
||||
from quantum.common.test_lib import run_tests, test_config
|
||||
import quantum.tests.unit
|
||||
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -17,4 +16,3 @@
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -17,14 +16,15 @@
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import logging
|
||||
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.db import l2network_db as cdb
|
||||
from quantum.plugins.cisco.l2network_segmentation_base \
|
||||
import L2NetworkSegmentationMgrBase
|
||||
from quantum.plugins.cisco.l2network_segmentation_base import (
|
||||
L2NetworkSegmentationMgrBase,
|
||||
)
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
@ -26,22 +26,21 @@ Currently has four functionalities:
|
||||
4. disconnect_vm <vm_instance_id>
|
||||
"""
|
||||
|
||||
|
||||
import logging
|
||||
import logging.handlers
|
||||
from optparse import OptionParser
|
||||
import os
|
||||
import subprocess
|
||||
import re
|
||||
import subprocess
|
||||
import sys
|
||||
|
||||
from optparse import OptionParser
|
||||
from quantum.client import Client
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.db import api as db
|
||||
from quantum.plugins.cisco.db import l2network_db as l2db
|
||||
from quantum.plugins.cisco.db import services_db as sdb
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.services import services_constants as servconts
|
||||
from quantum.plugins.cisco.services import services_logistics as servlogcs
|
||||
from quantumclient import Client
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
@ -62,8 +61,8 @@ def insert_inpath_service(tenant_id, service_image_id,
|
||||
data = {servconts.NETWORK: {servconts.NAME: net}}
|
||||
net_list[net] = client.create_network(data)
|
||||
net_list[net][servconts.PORTS] = []
|
||||
LOG.debug("Network %s Created with ID: %s " % (net, \
|
||||
net_list[net][servconts.NETWORK][servconts.ID]))
|
||||
LOG.debug("Network %s Created with ID: %s " % (
|
||||
net, net_list[net][servconts.NETWORK][servconts.ID]))
|
||||
print "Completed"
|
||||
print ("Creating Ports on Services and Server Networks")
|
||||
LOG.debug("Operation 'create_port' executed.")
|
||||
@ -82,7 +81,7 @@ def insert_inpath_service(tenant_id, service_image_id,
|
||||
for net in networks_name_list:
|
||||
port_id = data[servconts.PORTS][net_idx][servconts.ID]
|
||||
net_list[net][servconts.PORTS].append(port_id)
|
||||
LOG.debug("Port UUID: %s on network: %s" % \
|
||||
LOG.debug("Port UUID: %s on network: %s" %
|
||||
(data[servconts.PORTS][net_idx][servconts.ID], net))
|
||||
net_idx = net_idx + 1
|
||||
print "Completed"
|
||||
@ -110,8 +109,8 @@ def insert_inpath_service(tenant_id, service_image_id,
|
||||
port_id = net_list[net][servconts.PORTS][idx]
|
||||
attachment = client.show_port_attachment(network_id, port_id)
|
||||
attachment = attachment[servconts.ATTACHMENT][servconts.ID][:36]
|
||||
LOG.debug("Plugging virtual interface: %s of VM %s \
|
||||
into port: %s on network: %s" %
|
||||
LOG.debug(("Plugging virtual interface: %s of VM %s"
|
||||
"into port: %s on network: %s") %
|
||||
(attachment, service_vm_name, port_id, net))
|
||||
attach_data = {servconts.ATTACHMENT: {servconts.ID: '%s' %
|
||||
attachment}}
|
||||
@ -222,8 +221,8 @@ def connect_vm(tenant_id, vm_image_id, service_instance_id, *args):
|
||||
south_net = service_nets.sbnet_id
|
||||
attachment = client.show_port_attachment(south_net, new_port_id)
|
||||
attachment = attachment[servconts.ATTACHMENT][servconts.ID][:36]
|
||||
LOG.debug("Plugging virtual interface: %s of VM %s \
|
||||
into port: %s on network: %s" %
|
||||
LOG.debug(("Plugging virtual interface: %s of VM %s "
|
||||
"into port: %s on network: %s") %
|
||||
(attachment, vm_name, new_port_id, service_nets.sbnet_id))
|
||||
attach_data = {servconts.ATTACHMENT: {servconts.ID: '%s' % attachment}}
|
||||
client.attach_resource(service_nets.sbnet_id, new_port_id, attach_data)
|
||||
@ -232,7 +231,7 @@ def connect_vm(tenant_id, vm_image_id, service_instance_id, *args):
|
||||
|
||||
def create_multiport(tenant_id, networks_list, *args):
|
||||
"""Creates ports on a single host"""
|
||||
ports_info = {'multiport': \
|
||||
ports_info = {'multiport':
|
||||
{'status': 'ACTIVE',
|
||||
'net_id_list': networks_list,
|
||||
'ports_desc': {'key': 'value'}}}
|
||||
@ -252,16 +251,16 @@ def build_args(cmd, cmdargs, arglist):
|
||||
args.append(arglist[0])
|
||||
del arglist[0]
|
||||
except:
|
||||
LOG.debug("Not enough arguments for \"%s\" (expected: %d, got: %d)"
|
||||
% (cmd, len(cmdargs), len(orig_arglist)))
|
||||
print "Service Insertion Usage:\n %s %s" % (cmd,
|
||||
" ".join(["<%s>" % y for y in SERVICE_COMMANDS[cmd]["args"]]))
|
||||
LOG.debug("Not enough arguments for \"%s\" (expected: %d, got: %d)" %
|
||||
(cmd, len(cmdargs), len(orig_arglist)))
|
||||
print "Service Insertion Usage:\n %s %s" % (
|
||||
cmd, " ".join(["<%s>" % y for y in SERVICE_COMMANDS[cmd]["args"]]))
|
||||
sys.exit()
|
||||
if len(arglist) > 0:
|
||||
LOG.debug("Too many arguments for \"%s\" (expected: %d, got: %d)" \
|
||||
% (cmd, len(cmdargs), len(orig_arglist)))
|
||||
print "Service Insertion Usage:\n %s %s" % (cmd,
|
||||
" ".join(["<%s>" % y for y in SERVICE_COMMANDS[cmd]["args"]]))
|
||||
print "Service Insertion Usage:\n %s %s" % (
|
||||
cmd, " ".join(["<%s>" % y for y in SERVICE_COMMANDS[cmd]["args"]]))
|
||||
sys.exit()
|
||||
return args
|
||||
|
||||
@ -269,19 +268,22 @@ def build_args(cmd, cmdargs, arglist):
|
||||
SERVICE_COMMANDS = {
|
||||
"insert_inpath_service": {
|
||||
"func": insert_inpath_service,
|
||||
"args": ["tenant_id", "service_image_id",
|
||||
"management_net_name", "northbound_net_name",
|
||||
"southbound_net_name"]},
|
||||
"args": ["tenant_id", "service_image_id", "management_net_name",
|
||||
"northbound_net_name", "southbound_net_name"],
|
||||
},
|
||||
"delete_service": {
|
||||
"func": delete_service,
|
||||
"args": ["tenant_id", "service_instance_id"]},
|
||||
"args": ["tenant_id", "service_instance_id"],
|
||||
},
|
||||
"connect_vm": {
|
||||
"func": connect_vm,
|
||||
"args": ["tenant_id", "vm_image_id",
|
||||
"service_instance_id"]},
|
||||
"args": ["tenant_id", "vm_image_id", "service_instance_id"],
|
||||
},
|
||||
"disconnect_vm": {
|
||||
"func": disconnect_vm,
|
||||
"args": ["vm_instance_id"]}}
|
||||
"args": ["vm_instance_id"],
|
||||
},
|
||||
}
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
@ -289,13 +291,15 @@ if __name__ == "__main__":
|
||||
usagestr = "Usage: %prog [OPTIONS] <command> [args]"
|
||||
PARSER = OptionParser(usage=usagestr)
|
||||
PARSER.add_option("-H", "--host", dest="host",
|
||||
type="string", default="127.0.0.1", help="ip address of api host")
|
||||
type="string", default="127.0.0.1",
|
||||
help="ip address of api host")
|
||||
PARSER.add_option("-p", "--port", dest="port",
|
||||
type="int", default=9696, help="api port")
|
||||
PARSER.add_option("-s", "--ssl", dest="ssl",
|
||||
action="store_true", default=False, help="use ssl")
|
||||
PARSER.add_option("-v", "--verbose", dest="verbose",
|
||||
action="store_true", default=False, help="turn on verbose logging")
|
||||
action="store_true", default=False,
|
||||
help="turn on verbose logging")
|
||||
PARSER.add_option("-f", "--logfile", dest="logfile",
|
||||
type="string", default="syslog", help="log file path")
|
||||
options, args = PARSER.parse_args()
|
||||
|
@ -22,8 +22,7 @@ Services Constants for the Services insertion Library
|
||||
|
||||
FORMAT = 'json'
|
||||
ACTION_PREFIX_EXT = '/v1.0'
|
||||
ACTION_PREFIX_CSCO = ACTION_PREFIX_EXT + \
|
||||
'/extensions/csco/tenants/{tenant_id}'
|
||||
ACTION_PREFIX_CSCO = ACTION_PREFIX_EXT + '/extensions/csco/tenants/{tenant_id}'
|
||||
NETWORK = 'network'
|
||||
ID = 'id'
|
||||
PORTS = 'ports'
|
||||
|
@ -26,10 +26,11 @@ import time
|
||||
|
||||
from quantum.common import utils
|
||||
from quantum.plugins.cisco import l2network_plugin_configuration as conf
|
||||
from quantum.plugins.cisco.db import services_db as sdb
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.db import services_db as sdb
|
||||
from quantum.plugins.cisco.services import services_constants as servconts
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
@ -53,7 +54,7 @@ class ServicesLogistics():
|
||||
while not flag and counter <= 5:
|
||||
counter = counter + 1
|
||||
time.sleep(2.5)
|
||||
process = subprocess.Popen(service_args, \
|
||||
process = subprocess.Popen(service_args,
|
||||
stdout=subprocess.PIPE)
|
||||
result = process.stdout.readlines()
|
||||
if not result:
|
||||
@ -74,7 +75,7 @@ class ServicesLogistics():
|
||||
while not flag and counter <= 10:
|
||||
counter = counter + 1
|
||||
time.sleep(2.5)
|
||||
process = subprocess.Popen(service_args, \
|
||||
process = subprocess.Popen(service_args,
|
||||
stdout=subprocess.PIPE)
|
||||
result = process.stdout.readlines()
|
||||
if result:
|
||||
@ -105,8 +106,8 @@ class ServicesLogistics():
|
||||
"""
|
||||
_plugins = {}
|
||||
for key in conf.PLUGINS[const.PLUGINS].keys():
|
||||
_plugins[key] = \
|
||||
utils.import_object(conf.PLUGINS[const.PLUGINS][key])
|
||||
_plugins[key] = (
|
||||
utils.import_object(conf.PLUGINS[const.PLUGINS][key]))
|
||||
if not plugin_key in _plugins.keys():
|
||||
LOG.debug("No %s Plugin loaded" % plugin_key)
|
||||
return False
|
||||
|
@ -17,37 +17,46 @@
|
||||
# @authors: Shweta Padubidri, Cisco Systems, Inc.
|
||||
# Peter Strunk , Cisco Systems, Inc.
|
||||
# Shubhangi Satras , Cisco Systems, Inc.
|
||||
import unittest
|
||||
import logging
|
||||
import webob
|
||||
|
||||
import json
|
||||
import logging
|
||||
import os.path
|
||||
import unittest
|
||||
|
||||
import routes
|
||||
import webob
|
||||
from webtest import TestApp
|
||||
from quantum.extensions import credential
|
||||
from quantum.extensions import portprofile
|
||||
from quantum.extensions import novatenant
|
||||
from quantum.extensions import qos
|
||||
from quantum.extensions import multiport
|
||||
from quantum.plugins.cisco.db import api as db
|
||||
from quantum import wsgi
|
||||
from quantum.common import config
|
||||
from quantum.extensions import extensions
|
||||
|
||||
from quantum import api as server
|
||||
from quantum.common import config
|
||||
from quantum.extensions import (
|
||||
credential,
|
||||
extensions,
|
||||
multiport,
|
||||
novatenant,
|
||||
portprofile,
|
||||
qos,
|
||||
)
|
||||
from quantum.extensions.extensions import (
|
||||
ExtensionMiddleware,
|
||||
PluginAwareExtensionManager,
|
||||
)
|
||||
from quantum.manager import QuantumManager
|
||||
from quantum.plugins.cisco.db import api as db
|
||||
from quantum.plugins.cisco import l2network_plugin
|
||||
from quantum.plugins.cisco.l2network_plugin import L2Network
|
||||
from quantum.tests.unit.extension_stubs import StubBaseAppController
|
||||
from quantum.extensions.extensions import (PluginAwareExtensionManager,
|
||||
ExtensionMiddleware)
|
||||
from quantum.manager import QuantumManager
|
||||
from quantum.plugins.cisco import l2network_plugin
|
||||
from quantum import wsgi
|
||||
|
||||
|
||||
LOG = logging.getLogger('quantum.plugins.cisco.tests.test_cisco_extensions')
|
||||
|
||||
|
||||
TEST_CONF_FILE = config.find_config_file({'plugin': 'cisco'}, None,
|
||||
'quantum.conf.ciscoext')
|
||||
EXTENSIONS_PATH = os.path.join(os.path.dirname(__file__), os.pardir, os.pardir,
|
||||
os.pardir, os.pardir, "extensions")
|
||||
|
||||
LOG = logging.getLogger('quantum.plugins.cisco.tests.test_cisco_extensions')
|
||||
|
||||
|
||||
class ExtensionsTestApp(wsgi.Router):
|
||||
|
||||
@ -80,14 +89,17 @@ class PortprofileExtensionTest(unittest.TestCase):
|
||||
self.contenttype = 'application/json'
|
||||
self.profile_path = '/extensions/csco/tenants/tt/portprofiles'
|
||||
self.portprofile_path = '/extensions/csco/tenants/tt/portprofiles/'
|
||||
self.test_port_profile = {'portprofile':
|
||||
{'portprofile_name': 'cisco_test_portprofile',
|
||||
'qos_name': 'test-qos1'}}
|
||||
self.test_port_profile = {
|
||||
'portprofile': {
|
||||
'portprofile_name': 'cisco_test_portprofile',
|
||||
'qos_name': 'test-qos1',
|
||||
},
|
||||
}
|
||||
self.tenant_id = "test_tenant"
|
||||
self.network_name = "test_network"
|
||||
options = {}
|
||||
options['plugin_provider'] = 'quantum.plugins.cisco.l2network_plugin'\
|
||||
'.L2Network'
|
||||
options['plugin_provider'] = ('quantum.plugins.cisco.l2network_plugin'
|
||||
'.L2Network')
|
||||
self.api = server.APIRouterV10(options)
|
||||
self._l2network_plugin = l2network_plugin.L2Network()
|
||||
|
||||
@ -100,9 +112,12 @@ class PortprofileExtensionTest(unittest.TestCase):
|
||||
create_response1 = self.test_app.post(
|
||||
self.profile_path, req_body1,
|
||||
content_type=self.contenttype)
|
||||
req_body2 = json.dumps({'portprofile':
|
||||
{'portprofile_name': 'cisco_test_portprofile2',
|
||||
'qos_name': 'test-qos2'}})
|
||||
req_body2 = json.dumps({
|
||||
'portprofile': {
|
||||
'portprofile_name': 'cisco_test_portprofile2',
|
||||
'qos_name': 'test-qos2',
|
||||
},
|
||||
})
|
||||
create_response2 = self.test_app.post(
|
||||
self.profile_path, req_body2,
|
||||
content_type=self.contenttype)
|
||||
@ -114,8 +129,9 @@ class PortprofileExtensionTest(unittest.TestCase):
|
||||
|
||||
resp_body1 = wsgi.Serializer().deserialize(create_response1.body,
|
||||
self.contenttype)
|
||||
portprofile_path1_temp = self.portprofile_path +\
|
||||
resp_body1['portprofiles']['portprofile']['id']
|
||||
portprofile_path1_temp = (
|
||||
self.portprofile_path +
|
||||
resp_body1['portprofiles']['portprofile']['id'])
|
||||
portprofile_path1 = str(portprofile_path1_temp)
|
||||
resp_body2 = wsgi.Serializer().deserialize(create_response2.body,
|
||||
self.contenttype)
|
||||
@ -125,8 +141,9 @@ class PortprofileExtensionTest(unittest.TestCase):
|
||||
list_all_portprofiles)
|
||||
self.assertTrue(index_resp_body['portprofiles'][1] in
|
||||
list_all_portprofiles)
|
||||
portprofile_path2_temp = self.portprofile_path +\
|
||||
resp_body2['portprofiles']['portprofile']['id']
|
||||
portprofile_path2_temp = (
|
||||
self.portprofile_path +
|
||||
resp_body2['portprofiles']['portprofile']['id'])
|
||||
portprofile_path2 = str(portprofile_path2_temp)
|
||||
|
||||
# Clean Up - Delete the Port Profiles
|
||||
@ -147,8 +164,9 @@ class PortprofileExtensionTest(unittest.TestCase):
|
||||
# Clean Up - Delete the Port Profile
|
||||
resp_body = wsgi.Serializer().deserialize(index_response.body,
|
||||
self.contenttype)
|
||||
portprofile_path_temp = self.portprofile_path +\
|
||||
resp_body['portprofiles']['portprofile']['id']
|
||||
portprofile_path_temp = (
|
||||
self.portprofile_path +
|
||||
resp_body['portprofiles']['portprofile']['id'])
|
||||
portprofile_path = str(portprofile_path_temp)
|
||||
self.tear_down_profile(portprofile_path)
|
||||
LOG.debug("test_create_portprofile - END")
|
||||
@ -174,8 +192,8 @@ class PortprofileExtensionTest(unittest.TestCase):
|
||||
content_type=self.contenttype)
|
||||
resp_body = wsgi.Serializer().deserialize(index_response.body,
|
||||
self.contenttype)
|
||||
show_path_temp = self.portprofile_path +\
|
||||
resp_body['portprofiles']['portprofile']['id']
|
||||
show_path_temp = (self.portprofile_path +
|
||||
resp_body['portprofiles']['portprofile']['id'])
|
||||
show_port_path = str(show_path_temp)
|
||||
show_response = self.test_app.get(show_port_path)
|
||||
show_resp_dict = wsgi.Serializer().deserialize(show_response.body,
|
||||
@ -214,12 +232,15 @@ class PortprofileExtensionTest(unittest.TestCase):
|
||||
content_type=self.contenttype)
|
||||
resp_body = wsgi.Serializer().deserialize(index_response.body,
|
||||
self.contenttype)
|
||||
rename_port_profile = {'portprofile':
|
||||
{'portprofile_name': 'cisco_rename_portprofile',
|
||||
'qos_name': 'test-qos1'}}
|
||||
rename_port_profile = {
|
||||
'portprofile': {
|
||||
'portprofile_name': 'cisco_rename_portprofile',
|
||||
'qos_name': 'test-qos1',
|
||||
},
|
||||
}
|
||||
rename_req_body = json.dumps(rename_port_profile)
|
||||
rename_path_temp = self.portprofile_path +\
|
||||
resp_body['portprofiles']['portprofile']['id']
|
||||
rename_path_temp = (self.portprofile_path +
|
||||
resp_body['portprofiles']['portprofile']['id'])
|
||||
rename_path = str(rename_path_temp)
|
||||
rename_response = self.test_app.put(rename_path, rename_req_body,
|
||||
content_type=self.contenttype)
|
||||
@ -248,8 +269,8 @@ class PortprofileExtensionTest(unittest.TestCase):
|
||||
content_type=self.contenttype)
|
||||
resp_body = wsgi.Serializer().deserialize(index_response.body,
|
||||
self.contenttype)
|
||||
rename_path_temp = self.portprofile_path +\
|
||||
resp_body['portprofiles']['portprofile']['id']
|
||||
rename_path_temp = (self.portprofile_path +
|
||||
resp_body['portprofiles']['portprofile']['id'])
|
||||
rename_path = str(rename_path_temp)
|
||||
rename_response = self.test_app.put(rename_path, 'BAD_REQUEST',
|
||||
status='*')
|
||||
@ -264,9 +285,12 @@ class PortprofileExtensionTest(unittest.TestCase):
|
||||
""" Test update Portprofile does not exist"""
|
||||
|
||||
LOG.debug("test_update_portprofileiDNE - START")
|
||||
rename_port_profile = {'portprofile':
|
||||
{'portprofile_name': 'cisco_rename_portprofile',
|
||||
'qos_name': 'test-qos1'}}
|
||||
rename_port_profile = {
|
||||
'portprofile': {
|
||||
'portprofile_name': 'cisco_rename_portprofile',
|
||||
'qos_name': 'test-qos1',
|
||||
},
|
||||
}
|
||||
rename_req_body = json.dumps(rename_port_profile)
|
||||
update_path_temp = self.portprofile_path + portprofile_id
|
||||
update_path = str(update_path_temp)
|
||||
@ -287,8 +311,8 @@ class PortprofileExtensionTest(unittest.TestCase):
|
||||
content_type=self.contenttype)
|
||||
resp_body = wsgi.Serializer().deserialize(index_response.body,
|
||||
self.contenttype)
|
||||
delete_path_temp = self.portprofile_path +\
|
||||
resp_body['portprofiles']['portprofile']['id']
|
||||
delete_path_temp = (self.portprofile_path +
|
||||
resp_body['portprofiles']['portprofile']['id'])
|
||||
delete_path = str(delete_path_temp)
|
||||
delete_response = self.test_app.delete(delete_path)
|
||||
|
||||
@ -359,8 +383,8 @@ class PortprofileExtensionTest(unittest.TestCase):
|
||||
def _delete_port(self, network_id, port_id):
|
||||
""" Delete port """
|
||||
LOG.debug("Deleting port for network %s - START", network_id)
|
||||
port_path = "/tenants/tt/networks/%(network_id)s/ports/"\
|
||||
"%(port_id)s" % locals()
|
||||
port_path = ("/tenants/tt/networks/%(network_id)s/ports/%(port_id)s" %
|
||||
locals())
|
||||
port_req = self.create_request(port_path, None,
|
||||
self.contenttype, 'DELETE')
|
||||
port_req.get_response(self.api)
|
||||
@ -388,12 +412,17 @@ class PortprofileExtensionTest(unittest.TestCase):
|
||||
content_type=self.contenttype)
|
||||
resp_body = wsgi.Serializer().deserialize(index_response.body,
|
||||
self.contenttype)
|
||||
test_port_assign_data = {'portprofile': {'network-id': net_id,
|
||||
'port-id': port_id}}
|
||||
test_port_assign_data = {
|
||||
'portprofile': {
|
||||
'network-id': net_id,
|
||||
'port-id': port_id,
|
||||
},
|
||||
}
|
||||
req_assign_body = json.dumps(test_port_assign_data)
|
||||
associate_path_temp = self.portprofile_path +\
|
||||
resp_body['portprofiles']['portprofile']['id'] +\
|
||||
"/associate_portprofile"
|
||||
associate_path_temp = (
|
||||
self.portprofile_path +
|
||||
resp_body['portprofiles']['portprofile']['id'] +
|
||||
"/associate_portprofile")
|
||||
associate_path = str(associate_path_temp)
|
||||
associate_response = self.test_app.put(
|
||||
associate_path, req_assign_body,
|
||||
@ -401,12 +430,13 @@ class PortprofileExtensionTest(unittest.TestCase):
|
||||
self.assertEqual(200, associate_response.status_int)
|
||||
|
||||
# Clean Up - Disassociate and Delete the Port Profile
|
||||
disassociate_path_temp = self.portprofile_path +\
|
||||
resp_body['portprofiles']['portprofile']['id'] +\
|
||||
"/disassociate_portprofile"
|
||||
disassociate_path_temp = (
|
||||
self.portprofile_path +
|
||||
resp_body['portprofiles']['portprofile']['id'] +
|
||||
"/disassociate_portprofile")
|
||||
disassociate_path = str(disassociate_path_temp)
|
||||
delete_path_temp = self.portprofile_path +\
|
||||
resp_body['portprofiles']['portprofile']['id']
|
||||
delete_path_temp = (self.portprofile_path +
|
||||
resp_body['portprofiles']['portprofile']['id'])
|
||||
delete_path = str(delete_path_temp)
|
||||
self.tear_down_associate_profile(delete_path, disassociate_path,
|
||||
req_assign_body)
|
||||
@ -418,11 +448,16 @@ class PortprofileExtensionTest(unittest.TestCase):
|
||||
""" Test associate portprofile does not exist"""
|
||||
|
||||
LOG.debug("test_associate_portprofileDNE - START")
|
||||
test_port_assign_data = {'portprofile': {'network-id': '001',
|
||||
'port-id': '1'}}
|
||||
test_port_assign_data = {
|
||||
'portprofile': {
|
||||
'network-id': '001',
|
||||
'port-id': '1',
|
||||
},
|
||||
}
|
||||
req_assign_body = json.dumps(test_port_assign_data)
|
||||
associate_path = self.portprofile_path + portprofile_id +\
|
||||
"/associate_portprofile"
|
||||
associate_path = (self.portprofile_path +
|
||||
portprofile_id +
|
||||
"/associate_portprofile")
|
||||
associate_response = self.test_app.put(
|
||||
associate_path, req_assign_body,
|
||||
content_type=self.contenttype, status='*')
|
||||
@ -444,18 +479,23 @@ class PortprofileExtensionTest(unittest.TestCase):
|
||||
resp_body = wsgi.Serializer().deserialize(index_response.body,
|
||||
self.contenttype)
|
||||
|
||||
test_port_assign_data = {'portprofile': {'network-id': net_id,
|
||||
'port-id': port_id}}
|
||||
test_port_assign_data = {
|
||||
'portprofile': {
|
||||
'network-id': net_id,
|
||||
'port-id': port_id,
|
||||
},
|
||||
}
|
||||
req_assign_body = json.dumps(test_port_assign_data)
|
||||
associate_path_temp = self.portprofile_path +\
|
||||
resp_body['portprofiles']['portprofile']['id'] +\
|
||||
"/associate_portprofile"
|
||||
associate_path_temp = (self.portprofile_path +
|
||||
resp_body['portprofiles']['portprofile']['id'] +
|
||||
"/associate_portprofile")
|
||||
associate_path = str(associate_path_temp)
|
||||
self.test_app.put(associate_path, req_assign_body,
|
||||
content_type=self.contenttype)
|
||||
disassociate_path_temp = self.portprofile_path +\
|
||||
resp_body['portprofiles']['portprofile']['id'] +\
|
||||
"/disassociate_portprofile"
|
||||
disassociate_path_temp = (
|
||||
self.portprofile_path +
|
||||
resp_body['portprofiles']['portprofile']['id'] +
|
||||
"/disassociate_portprofile")
|
||||
|
||||
disassociate_path = str(disassociate_path_temp)
|
||||
disassociate_response = self.test_app.put(
|
||||
@ -464,8 +504,8 @@ class PortprofileExtensionTest(unittest.TestCase):
|
||||
self.assertEqual(200, disassociate_response.status_int)
|
||||
resp_body = wsgi.Serializer().deserialize(index_response.body,
|
||||
self.contenttype)
|
||||
delete_path_temp = self.portprofile_path +\
|
||||
resp_body['portprofiles']['portprofile']['id']
|
||||
delete_path_temp = (self.portprofile_path +
|
||||
resp_body['portprofiles']['portprofile']['id'])
|
||||
delete_path = str(delete_path_temp)
|
||||
self.tear_down_profile(delete_path)
|
||||
self.tear_down_port_network(net_id, port_id)
|
||||
@ -518,12 +558,25 @@ class NovatenantExtensionTest(unittest.TestCase):
|
||||
SimpleExtensionManager(res_ext))
|
||||
self.contenttype = 'application/json'
|
||||
self.novatenants_path = '/extensions/csco/tenants/tt/novatenants/'
|
||||
self.test_associate_port_data = {'novatenant': {'instance_id': 1,
|
||||
'instance_desc': {'project_id': 'demo',
|
||||
'user_id': 'root', 'vif_id': '23432423'}}}
|
||||
self.test_associate_data = {'novatenant': {'instance_id': 1,
|
||||
'instance_desc': {'project_id': 'demo',
|
||||
'user_id': 'root'}}}
|
||||
self.test_associate_port_data = {
|
||||
'novatenant': {
|
||||
'instance_id': 1,
|
||||
'instance_desc': {
|
||||
'project_id': 'demo',
|
||||
'user_id': 'root',
|
||||
'vif_id': '23432423',
|
||||
},
|
||||
},
|
||||
}
|
||||
self.test_associate_data = {
|
||||
'novatenant': {
|
||||
'instance_id': 1,
|
||||
'instance_desc': {
|
||||
'project_id': 'demo',
|
||||
'user_id': 'root',
|
||||
},
|
||||
},
|
||||
}
|
||||
self._l2network_plugin = l2network_plugin.L2Network()
|
||||
|
||||
def test_schedule_host(self):
|
||||
@ -581,8 +634,15 @@ class QosExtensionTest(unittest.TestCase):
|
||||
self.contenttype = 'application/json'
|
||||
self.qos_path = '/extensions/csco/tenants/tt/qos'
|
||||
self.qos_second_path = '/extensions/csco/tenants/tt/qos/'
|
||||
self.test_qos_data = {'qos': {'qos_name': 'cisco_test_qos',
|
||||
'qos_desc': {'PPS': 50, 'TTL': 5}}}
|
||||
self.test_qos_data = {
|
||||
'qos': {
|
||||
'qos_name': 'cisco_test_qos',
|
||||
'qos_desc': {
|
||||
'PPS': 50,
|
||||
'TTL': 5,
|
||||
},
|
||||
},
|
||||
}
|
||||
self._l2network_plugin = l2network_plugin.L2Network()
|
||||
|
||||
def test_create_qos(self):
|
||||
@ -599,8 +659,7 @@ class QosExtensionTest(unittest.TestCase):
|
||||
# Clean Up - Delete the qos
|
||||
resp_body = wsgi.Serializer().deserialize(index_response.body,
|
||||
self.contenttype)
|
||||
qos_path_temp = self.qos_second_path +\
|
||||
resp_body['qoss']['qos']['id']
|
||||
qos_path_temp = self.qos_second_path + resp_body['qoss']['qos']['id']
|
||||
qos_path = str(qos_path_temp)
|
||||
self.tearDownQos(qos_path)
|
||||
LOG.debug("test_create_qos - END")
|
||||
@ -625,8 +684,15 @@ class QosExtensionTest(unittest.TestCase):
|
||||
req_body1 = json.dumps(self.test_qos_data)
|
||||
create_resp1 = self.test_app.post(self.qos_path, req_body1,
|
||||
content_type=self.contenttype)
|
||||
req_body2 = json.dumps({'qos': {'qos_name': 'cisco_test_qos2',
|
||||
'qos_desc': {'PPS': 50, 'TTL': 5}}})
|
||||
req_body2 = json.dumps({
|
||||
'qos': {
|
||||
'qos_name': 'cisco_test_qos2',
|
||||
'qos_desc': {
|
||||
'PPS': 50,
|
||||
'TTL': 5,
|
||||
},
|
||||
},
|
||||
})
|
||||
create_resp2 = self.test_app.post(self.qos_path, req_body2,
|
||||
content_type=self.contenttype)
|
||||
index_response = self.test_app.get(self.qos_path)
|
||||
@ -637,16 +703,14 @@ class QosExtensionTest(unittest.TestCase):
|
||||
# Clean Up - Delete the qos's
|
||||
resp_body1 = wsgi.Serializer().deserialize(create_resp1.body,
|
||||
self.contenttype)
|
||||
qos_path1_temp = self.qos_second_path +\
|
||||
resp_body1['qoss']['qos']['id']
|
||||
qos_path1_temp = self.qos_second_path + resp_body1['qoss']['qos']['id']
|
||||
qos_path1 = str(qos_path1_temp)
|
||||
resp_body2 = wsgi.Serializer().deserialize(create_resp2.body,
|
||||
self.contenttype)
|
||||
list_all_qos = [resp_body1['qoss']['qos'], resp_body2['qoss']['qos']]
|
||||
self.assertTrue(index_resp_body['qoss'][0] in list_all_qos)
|
||||
self.assertTrue(index_resp_body['qoss'][1] in list_all_qos)
|
||||
qos_path2_temp = self.qos_second_path +\
|
||||
resp_body2['qoss']['qos']['id']
|
||||
qos_path2_temp = self.qos_second_path + resp_body2['qoss']['qos']['id']
|
||||
qos_path2 = str(qos_path2_temp)
|
||||
self.tearDownQos(qos_path1)
|
||||
self.tearDownQos(qos_path2)
|
||||
@ -662,14 +726,12 @@ class QosExtensionTest(unittest.TestCase):
|
||||
content_type=self.contenttype)
|
||||
resp_body = wsgi.Serializer().deserialize(index_response.body,
|
||||
self.contenttype)
|
||||
show_path_temp = self.qos_second_path +\
|
||||
resp_body['qoss']['qos']['id']
|
||||
show_path_temp = self.qos_second_path + resp_body['qoss']['qos']['id']
|
||||
show_qos_path = str(show_path_temp)
|
||||
show_response = self.test_app.get(show_qos_path)
|
||||
show_resp_dict = wsgi.Serializer().deserialize(show_response.body,
|
||||
self.contenttype)
|
||||
self.assertEqual(
|
||||
show_resp_dict['qoss']['qos']['name'],
|
||||
self.assertEqual(show_resp_dict['qoss']['qos']['name'],
|
||||
self.test_qos_data['qos']['qos_name'])
|
||||
|
||||
self.assertEqual(200, show_response.status_int)
|
||||
@ -699,10 +761,17 @@ class QosExtensionTest(unittest.TestCase):
|
||||
content_type=self.contenttype)
|
||||
resp_body = wsgi.Serializer().deserialize(index_response.body,
|
||||
self.contenttype)
|
||||
rename_req_body = json.dumps({'qos': {'qos_name': 'cisco_rename_qos',
|
||||
'qos_desc': {'PPS': 50, 'TTL': 5}}})
|
||||
rename_path_temp = self.qos_second_path +\
|
||||
resp_body['qoss']['qos']['id']
|
||||
rename_req_body = json.dumps({
|
||||
'qos': {
|
||||
'qos_name': 'cisco_rename_qos',
|
||||
'qos_desc': {
|
||||
'PPS': 50,
|
||||
'TTL': 5,
|
||||
},
|
||||
},
|
||||
})
|
||||
rename_path_temp = (self.qos_second_path +
|
||||
resp_body['qoss']['qos']['id'])
|
||||
rename_path = str(rename_path_temp)
|
||||
rename_response = self.test_app.put(rename_path, rename_req_body,
|
||||
content_type=self.contenttype)
|
||||
@ -720,8 +789,15 @@ class QosExtensionTest(unittest.TestCase):
|
||||
""" Test update qos does not exist """
|
||||
|
||||
LOG.debug("test_update_qosDNE - START")
|
||||
rename_req_body = json.dumps({'qos': {'qos_name': 'cisco_rename_qos',
|
||||
'qos_desc': {'PPS': 50, 'TTL': 5}}})
|
||||
rename_req_body = json.dumps({
|
||||
'qos': {
|
||||
'qos_name': 'cisco_rename_qos',
|
||||
'qos_desc': {
|
||||
'PPS': 50,
|
||||
'TTL': 5,
|
||||
},
|
||||
},
|
||||
})
|
||||
rename_path_temp = self.qos_second_path + qos_id
|
||||
rename_path = str(rename_path_temp)
|
||||
rename_response = self.test_app.put(rename_path, rename_req_body,
|
||||
@ -740,8 +816,8 @@ class QosExtensionTest(unittest.TestCase):
|
||||
content_type=self.contenttype)
|
||||
resp_body = wsgi.Serializer().deserialize(index_response.body,
|
||||
self.contenttype)
|
||||
rename_path_temp = self.qos_second_path +\
|
||||
resp_body['qoss']['qos']['id']
|
||||
rename_path_temp = (self.qos_second_path +
|
||||
resp_body['qoss']['qos']['id'])
|
||||
rename_path = str(rename_path_temp)
|
||||
rename_response = self.test_app.put(rename_path, 'BAD_REQUEST',
|
||||
status="*")
|
||||
@ -756,14 +832,21 @@ class QosExtensionTest(unittest.TestCase):
|
||||
""" Test delte qos """
|
||||
|
||||
LOG.debug("test_delete_qos - START")
|
||||
req_body = json.dumps({'qos': {'qos_name': 'cisco_test_qos',
|
||||
'qos_desc': {'PPS': 50, 'TTL': 5}}})
|
||||
req_body = json.dumps({
|
||||
'qos': {
|
||||
'qos_name': 'cisco_test_qos',
|
||||
'qos_desc': {
|
||||
'PPS': 50,
|
||||
'TTL': 5,
|
||||
},
|
||||
},
|
||||
})
|
||||
index_response = self.test_app.post(self.qos_path, req_body,
|
||||
content_type=self.contenttype)
|
||||
resp_body = wsgi.Serializer().deserialize(index_response.body,
|
||||
self.contenttype)
|
||||
delete_path_temp = self.qos_second_path +\
|
||||
resp_body['qoss']['qos']['id']
|
||||
delete_path_temp = (self.qos_second_path +
|
||||
resp_body['qoss']['qos']['id'])
|
||||
delete_path = str(delete_path_temp)
|
||||
delete_response = self.test_app.delete(delete_path)
|
||||
self.assertEqual(200, delete_response.status_int)
|
||||
@ -807,10 +890,13 @@ class CredentialExtensionTest(unittest.TestCase):
|
||||
self.contenttype = 'application/json'
|
||||
self.credential_path = '/extensions/csco/tenants/tt/credentials'
|
||||
self.cred_second_path = '/extensions/csco/tenants/tt/credentials/'
|
||||
self.test_credential_data = {'credential':
|
||||
{'credential_name': 'cred8',
|
||||
self.test_credential_data = {
|
||||
'credential': {
|
||||
'credential_name': 'cred8',
|
||||
'user_name': 'newUser2',
|
||||
'password': 'newPasswd1'}}
|
||||
'password': 'newPasswd1',
|
||||
},
|
||||
}
|
||||
self._l2network_plugin = l2network_plugin.L2Network()
|
||||
|
||||
def test_list_credentials(self):
|
||||
@ -823,34 +909,36 @@ class CredentialExtensionTest(unittest.TestCase):
|
||||
create_response1 = self.test_app.post(
|
||||
self.credential_path, req_body1,
|
||||
content_type=self.contenttype)
|
||||
req_body2 = json.dumps({'credential':
|
||||
{'credential_name': 'cred9',
|
||||
req_body2 = json.dumps({
|
||||
'credential': {
|
||||
'credential_name': 'cred9',
|
||||
'user_name': 'newUser2',
|
||||
'password': 'newPasswd2'}})
|
||||
'password': 'newPasswd2',
|
||||
},
|
||||
})
|
||||
create_response2 = self.test_app.post(
|
||||
self.credential_path, req_body2,
|
||||
content_type=self.contenttype)
|
||||
index_response = self.test_app.get(
|
||||
self.credential_path)
|
||||
index_response = self.test_app.get(self.credential_path)
|
||||
index_resp_body = wsgi.Serializer().deserialize(index_response.body,
|
||||
self.contenttype)
|
||||
self.assertEqual(200, index_response.status_int)
|
||||
#CLean Up - Deletion of the Credentials
|
||||
resp_body1 = wsgi.Serializer().deserialize(
|
||||
create_response1.body, self.contenttype)
|
||||
delete_path1_temp = self.cred_second_path +\
|
||||
resp_body1['credentials']['credential']['id']
|
||||
resp_body1 = wsgi.Serializer().deserialize(create_response1.body,
|
||||
self.contenttype)
|
||||
delete_path1_temp = (self.cred_second_path +
|
||||
resp_body1['credentials']['credential']['id'])
|
||||
delete_path1 = str(delete_path1_temp)
|
||||
resp_body2 = wsgi.Serializer().deserialize(
|
||||
create_response2.body, self.contenttype)
|
||||
resp_body2 = wsgi.Serializer().deserialize(create_response2.body,
|
||||
self.contenttype)
|
||||
list_all_credential = [resp_body1['credentials']['credential'],
|
||||
resp_body2['credentials']['credential']]
|
||||
self.assertTrue(index_resp_body['credentials'][0] in
|
||||
list_all_credential)
|
||||
self.assertTrue(index_resp_body['credentials'][1] in
|
||||
list_all_credential)
|
||||
delete_path2_temp = self.cred_second_path +\
|
||||
resp_body2['credentials']['credential']['id']
|
||||
self.assertTrue(
|
||||
index_resp_body['credentials'][0] in list_all_credential)
|
||||
self.assertTrue(
|
||||
index_resp_body['credentials'][1] in list_all_credential)
|
||||
delete_path2_temp = (self.cred_second_path +
|
||||
resp_body2['credentials']['credential']['id'])
|
||||
delete_path2 = str(delete_path2_temp)
|
||||
self.tearDownCredential(delete_path1)
|
||||
self.tearDownCredential(delete_path2)
|
||||
@ -869,8 +957,8 @@ class CredentialExtensionTest(unittest.TestCase):
|
||||
#CLean Up - Deletion of the Credentials
|
||||
resp_body = wsgi.Serializer().deserialize(
|
||||
index_response.body, self.contenttype)
|
||||
delete_path_temp = self.cred_second_path +\
|
||||
resp_body['credentials']['credential']['id']
|
||||
delete_path_temp = (self.cred_second_path +
|
||||
resp_body['credentials']['credential']['id'])
|
||||
delete_path = str(delete_path_temp)
|
||||
self.tearDownCredential(delete_path)
|
||||
LOG.debug("test_create_credential - END")
|
||||
@ -895,16 +983,15 @@ class CredentialExtensionTest(unittest.TestCase):
|
||||
index_response = self.test_app.post(
|
||||
self.credential_path, req_body,
|
||||
content_type=self.contenttype)
|
||||
resp_body = wsgi.Serializer().deserialize(
|
||||
index_response.body, self.contenttype)
|
||||
show_path_temp = self.cred_second_path +\
|
||||
resp_body['credentials']['credential']['id']
|
||||
resp_body = wsgi.Serializer().deserialize(index_response.body,
|
||||
self.contenttype)
|
||||
show_path_temp = (self.cred_second_path +
|
||||
resp_body['credentials']['credential']['id'])
|
||||
show_cred_path = str(show_path_temp)
|
||||
show_response = self.test_app.get(show_cred_path)
|
||||
show_resp_dict = wsgi.Serializer().deserialize(show_response.body,
|
||||
self.contenttype)
|
||||
self.assertEqual(
|
||||
show_resp_dict['credentials']['credential']['name'],
|
||||
self.assertEqual(show_resp_dict['credentials']['credential']['name'],
|
||||
self.test_credential_data['credential']['user_name'])
|
||||
self.assertEqual(
|
||||
show_resp_dict['credentials']['credential']['password'],
|
||||
@ -935,19 +1022,21 @@ class CredentialExtensionTest(unittest.TestCase):
|
||||
content_type=self.contenttype)
|
||||
resp_body = wsgi.Serializer().deserialize(
|
||||
index_response.body, self.contenttype)
|
||||
rename_req_body = json.dumps({'credential':
|
||||
{'credential_name': 'cred3',
|
||||
rename_req_body = json.dumps({
|
||||
'credential': {
|
||||
'credential_name': 'cred3',
|
||||
'user_name': 'RenamedUser',
|
||||
'password': 'Renamedpassword'}})
|
||||
rename_path_temp = self.cred_second_path +\
|
||||
resp_body['credentials']['credential']['id']
|
||||
'password': 'Renamedpassword',
|
||||
},
|
||||
})
|
||||
rename_path_temp = (self.cred_second_path +
|
||||
resp_body['credentials']['credential']['id'])
|
||||
rename_path = str(rename_path_temp)
|
||||
rename_response = self.test_app.put(rename_path, rename_req_body,
|
||||
content_type=self.contenttype)
|
||||
rename_resp_dict = wsgi.Serializer().deserialize(rename_response.body,
|
||||
self.contenttype)
|
||||
self.assertEqual(
|
||||
rename_resp_dict['credentials']['credential']['name'],
|
||||
self.assertEqual(rename_resp_dict['credentials']['credential']['name'],
|
||||
'cred3')
|
||||
self.assertEqual(
|
||||
rename_resp_dict['credentials']['credential']['password'],
|
||||
@ -968,8 +1057,8 @@ class CredentialExtensionTest(unittest.TestCase):
|
||||
content_type=self.contenttype)
|
||||
resp_body = wsgi.Serializer().deserialize(
|
||||
index_response.body, self.contenttype)
|
||||
rename_path_temp = self.cred_second_path +\
|
||||
resp_body['credentials']['credential']['id']
|
||||
rename_path_temp = (self.cred_second_path +
|
||||
resp_body['credentials']['credential']['id'])
|
||||
rename_path = str(rename_path_temp)
|
||||
rename_response = self.test_app.put(rename_path, 'BAD_REQUEST',
|
||||
status='*')
|
||||
@ -981,10 +1070,13 @@ class CredentialExtensionTest(unittest.TestCase):
|
||||
""" Test update credential does not exist"""
|
||||
|
||||
LOG.debug("test_update_credentialDNE - START")
|
||||
rename_req_body = json.dumps({'credential':
|
||||
{'credential_name': 'cred3',
|
||||
rename_req_body = json.dumps({
|
||||
'credential': {
|
||||
'credential_name': 'cred3',
|
||||
'user_name': 'RenamedUser',
|
||||
'password': 'Renamedpassword'}})
|
||||
'password': 'Renamedpassword',
|
||||
},
|
||||
})
|
||||
rename_path_temp = self.cred_second_path + credential_id
|
||||
rename_path = str(rename_path_temp)
|
||||
rename_response = self.test_app.put(rename_path, rename_req_body,
|
||||
@ -1004,8 +1096,8 @@ class CredentialExtensionTest(unittest.TestCase):
|
||||
content_type=self.contenttype)
|
||||
resp_body = wsgi.Serializer().deserialize(
|
||||
index_response.body, self.contenttype)
|
||||
delete_path_temp = self.cred_second_path +\
|
||||
resp_body['credentials']['credential']['id']
|
||||
delete_path_temp = (self.cred_second_path +
|
||||
resp_body['credentials']['credential']['id'])
|
||||
delete_path = str(delete_path_temp)
|
||||
delete_response = self.test_app.delete(delete_path)
|
||||
self.assertEqual(200, delete_response.status_int)
|
||||
@ -1046,15 +1138,18 @@ class MultiPortExtensionTest(unittest.TestCase):
|
||||
self.contenttype = 'application/json'
|
||||
self.multiport_path = '/extensions/csco/tenants/tt/multiport'
|
||||
self.multiport_path2 = '/extensions/csco/tenants/tt/multiport/'
|
||||
self.test_multi_port = {'multiport':
|
||||
{'net_id_list': '1',
|
||||
self.test_multi_port = {
|
||||
'multiport': {
|
||||
'net_id_list': '1',
|
||||
'status': 'test-qos1',
|
||||
'ports_desc': 'Port Descr'}}
|
||||
'ports_desc': 'Port Descr',
|
||||
},
|
||||
}
|
||||
self.tenant_id = "test_tenant"
|
||||
self.network_name = "test_network"
|
||||
options = {}
|
||||
options['plugin_provider'] = 'quantum.plugins.cisco.l2network_plugin'\
|
||||
'.L2Network'
|
||||
options['plugin_provider'] = (
|
||||
'quantum.plugins.cisco.l2network_plugin.L2Network')
|
||||
self.api = server.APIRouterV10(options)
|
||||
self._l2network_plugin = l2network_plugin.L2Network()
|
||||
|
||||
@ -1108,10 +1203,15 @@ class MultiPortExtensionTest(unittest.TestCase):
|
||||
|
||||
net_id = self._create_network('net1')
|
||||
net_id2 = self._create_network('net2')
|
||||
test_multi_port = {'multiport':
|
||||
{'net_id_list': [net_id, net_id2],
|
||||
test_multi_port = {
|
||||
'multiport': {
|
||||
'net_id_list': [net_id, net_id2],
|
||||
'status': 'ACTIVE',
|
||||
'ports_desc': {'key': 'value'}}}
|
||||
'ports_desc': {
|
||||
'key': 'value',
|
||||
},
|
||||
},
|
||||
}
|
||||
req_body = json.dumps(test_multi_port)
|
||||
index_response = self.test_app.post(self.multiport_path, req_body,
|
||||
content_type=self.contenttype)
|
||||
|
@ -19,11 +19,11 @@
|
||||
test_database.py is an independent test suite
|
||||
that tests the database api method calls
|
||||
"""
|
||||
|
||||
import logging as LOG
|
||||
import unittest
|
||||
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
|
||||
import quantum.plugins.cisco.db.api as db
|
||||
import quantum.plugins.cisco.db.l2network_db as l2network_db
|
||||
import quantum.plugins.cisco.db.nexus_db as nexus_db
|
||||
@ -72,13 +72,14 @@ class UcsDB(object):
|
||||
LOG.error("Failed to get port binding: %s" % str(exc))
|
||||
return port_binding
|
||||
|
||||
def create_port_binding(self, port_id, blade_intf_dn, portprofile_name, \
|
||||
def create_port_binding(self, port_id, blade_intf_dn, portprofile_name,
|
||||
vlan_name, vlan_id, qos):
|
||||
"""create port binding"""
|
||||
port_bind_dict = {}
|
||||
try:
|
||||
res = ucs_db.add_portbinding(port_id, blade_intf_dn, \
|
||||
portprofile_name, vlan_name, vlan_id, qos)
|
||||
res = ucs_db.add_portbinding(port_id, blade_intf_dn,
|
||||
portprofile_name, vlan_name,
|
||||
vlan_id, qos)
|
||||
LOG.debug("Created port binding: %s" % res.port_id)
|
||||
port_bind_dict["port-id"] = res.port_id
|
||||
port_bind_dict["blade-intf-dn"] = str(res.blade_intf_dn)
|
||||
@ -101,12 +102,13 @@ class UcsDB(object):
|
||||
except Exception, exc:
|
||||
raise Exception("Failed to delete port profile: %s" % str(exc))
|
||||
|
||||
def update_port_binding(self, port_id, blade_intf_dn, \
|
||||
def update_port_binding(self, port_id, blade_intf_dn,
|
||||
portprofile_name, vlan_name, vlan_id, qos):
|
||||
"""update port binding"""
|
||||
try:
|
||||
res = ucs_db.update_portbinding(port_id, blade_intf_dn, \
|
||||
portprofile_name, vlan_name, vlan_id, qos)
|
||||
res = ucs_db.update_portbinding(port_id, blade_intf_dn,
|
||||
portprofile_name, vlan_name,
|
||||
vlan_id, qos)
|
||||
LOG.debug("Updating port binding: %s" % res.port_id)
|
||||
port_bind_dict = {}
|
||||
port_bind_dict["port-id"] = res.port_id
|
||||
@ -223,7 +225,7 @@ class ServicesDB(object):
|
||||
"""create service binding"""
|
||||
bind_dict = {}
|
||||
try:
|
||||
res = services_db.add_services_binding(service_id, mngnet_id, \
|
||||
res = services_db.add_services_binding(service_id, mngnet_id,
|
||||
nbnet_id, sbnet_id)
|
||||
LOG.debug("Created service binding : %s" % res.service_id)
|
||||
bind_dict["service_id"] = str(res.service_id)
|
||||
@ -268,8 +270,8 @@ class L2networkDB(object):
|
||||
vlan = []
|
||||
try:
|
||||
for vlan_bind in l2network_db.get_vlan_binding(network_id):
|
||||
LOG.debug("Getting vlan binding for vlan: %s"
|
||||
% vlan_bind.vlan_id)
|
||||
LOG.debug("Getting vlan binding for vlan: %s" %
|
||||
vlan_bind.vlan_id)
|
||||
vlan_dict = {}
|
||||
vlan_dict["vlan-id"] = str(vlan_bind.vlan_id)
|
||||
vlan_dict["vlan-name"] = vlan_bind.vlan_name
|
||||
@ -453,8 +455,8 @@ class L2networkDB(object):
|
||||
port_id, default):
|
||||
"""Update portprofile binding"""
|
||||
try:
|
||||
res = l2network_db.update_pp_binding(tenant_id, pp_id,
|
||||
newtenant_id, port_id, default)
|
||||
res = l2network_db.update_pp_binding(
|
||||
tenant_id, pp_id, newtenant_id, port_id, default)
|
||||
LOG.debug("Updating port profile binding: %s" % res.portprofile_id)
|
||||
ppbinding_dict = {}
|
||||
ppbinding_dict["portprofile-id"] = str(res.portprofile_id)
|
||||
@ -653,8 +655,8 @@ class UcsDBTest(unittest.TestCase):
|
||||
"""create port binding"""
|
||||
net1 = self.quantum.create_network("t1", "netid1")
|
||||
port1 = self.quantum.create_port(net1["net-id"])
|
||||
port_bind1 = self.dbtest.create_port_binding(port1["port-id"],
|
||||
"vnic1", "pp1", "vlan1", 10, "qos1")
|
||||
port_bind1 = self.dbtest.create_port_binding(
|
||||
port1["port-id"], "vnic1", "pp1", "vlan1", 10, "qos1")
|
||||
self.assertTrue(port_bind1["port-id"] == port1["port-id"])
|
||||
self.teardown_portbinding()
|
||||
self.teardown_network_port()
|
||||
@ -664,10 +666,10 @@ class UcsDBTest(unittest.TestCase):
|
||||
net1 = self.quantum.create_network("t1", "netid1")
|
||||
port1 = self.quantum.create_port(net1["net-id"])
|
||||
port2 = self.quantum.create_port(net1["net-id"])
|
||||
port_bind1 = self.dbtest.create_port_binding(port1["port-id"],
|
||||
"vnic1", "pp1", "vlan1", 10, "qos1")
|
||||
port_bind2 = self.dbtest.create_port_binding(port2["port-id"],
|
||||
"vnic2", "pp2", "vlan2", 20, "qos2")
|
||||
port_bind1 = self.dbtest.create_port_binding(
|
||||
port1["port-id"], "vnic1", "pp1", "vlan1", 10, "qos1")
|
||||
port_bind2 = self.dbtest.create_port_binding(
|
||||
port2["port-id"], "vnic2", "pp2", "vlan2", 20, "qos2")
|
||||
port_bindings = self.dbtest.get_all_port_bindings()
|
||||
count = 0
|
||||
for pbind in port_bindings:
|
||||
@ -681,8 +683,8 @@ class UcsDBTest(unittest.TestCase):
|
||||
"""delete port binding"""
|
||||
net1 = self.quantum.create_network("t1", "netid1")
|
||||
port1 = self.quantum.create_port(net1["net-id"])
|
||||
port_bind1 = self.dbtest.create_port_binding(port1["port-id"],
|
||||
"vnic1", "pp1", "vlan1", 10, "qos1")
|
||||
port_bind1 = self.dbtest.create_port_binding(
|
||||
port1["port-id"], "vnic1", "pp1", "vlan1", 10, "qos1")
|
||||
self.dbtest.delete_port_binding(port1["port-id"])
|
||||
port_bindings = self.dbtest.get_all_port_bindings()
|
||||
count = 0
|
||||
@ -697,10 +699,10 @@ class UcsDBTest(unittest.TestCase):
|
||||
"""update port binding"""
|
||||
net1 = self.quantum.create_network("t1", "netid1")
|
||||
port1 = self.quantum.create_port(net1["net-id"])
|
||||
port_bind1 = self.dbtest.create_port_binding(port1["port-id"],
|
||||
"vnic1", "pp1", "vlan1", 10, "qos1")
|
||||
port_bind1 = self.dbtest.update_port_binding(port1["port-id"],
|
||||
"vnic1", "newpp1", "newvlan1", 11, "newqos1")
|
||||
port_bind1 = self.dbtest.create_port_binding(
|
||||
port1["port-id"], "vnic1", "pp1", "vlan1", 10, "qos1")
|
||||
port_bind1 = self.dbtest.update_port_binding(
|
||||
port1["port-id"], "vnic1", "newpp1", "newvlan1", 11, "newqos1")
|
||||
port_bindings = self.dbtest.get_all_port_bindings()
|
||||
count = 0
|
||||
for pbind in port_bindings:
|
||||
@ -776,7 +778,7 @@ class NexusDBTest(unittest.TestCase):
|
||||
def testd_update_nexusportbinding(self):
|
||||
"""update nexus port binding"""
|
||||
binding1 = self.dbtest.create_nexusportbinding("port1", 10)
|
||||
binding1 = self.dbtest.update_nexusport_binding(binding1["port-id"], \
|
||||
binding1 = self.dbtest.update_nexusport_binding(binding1["port-id"],
|
||||
20)
|
||||
bindings = self.dbtest.get_all_nexusportbindings()
|
||||
count = 0
|
||||
@ -809,15 +811,15 @@ class ServicesDBTest(unittest.TestCase):
|
||||
|
||||
def testa_create_servicebinding(self):
|
||||
"""create service binding"""
|
||||
service_id = self.dbtest.create_servicebinding("i-00001", \
|
||||
"mng_net", "northb_net", "northb_net")
|
||||
service_id = self.dbtest.create_servicebinding(
|
||||
"i-00001", "mng_net", "northb_net", "northb_net")
|
||||
self.assertTrue(service_id["service_id"] == "i-00001")
|
||||
self.tearDown_servicebinding()
|
||||
|
||||
def testb_get_servicesbindings(self):
|
||||
"""get all services binding"""
|
||||
service_id = self.dbtest.create_servicebinding("i-00001", \
|
||||
"mng_net", "northb_net", "northb_net")
|
||||
service_id = self.dbtest.create_servicebinding(
|
||||
"i-00001", "mng_net", "northb_net", "northb_net")
|
||||
bindings = self.dbtest.get_servicebindings("i-00001")
|
||||
count = 0
|
||||
if bindings:
|
||||
@ -827,10 +829,10 @@ class ServicesDBTest(unittest.TestCase):
|
||||
|
||||
def testb_getall_servicesbindings(self):
|
||||
"""get all services binding"""
|
||||
service_id = self.dbtest.create_servicebinding("i-00001", \
|
||||
"mng_net", "northb_net", "northb_net")
|
||||
service_id = self.dbtest.create_servicebinding("i-00002", \
|
||||
"mng_net", "northb_net", "northb_net")
|
||||
service_id = self.dbtest.create_servicebinding(
|
||||
"i-00001", "mng_net", "northb_net", "northb_net")
|
||||
service_id = self.dbtest.create_servicebinding(
|
||||
"i-00002", "mng_net", "northb_net", "northb_net")
|
||||
bindings = self.dbtest.get_all_servicesbindings()
|
||||
count = 0
|
||||
for bind in bindings:
|
||||
@ -841,8 +843,8 @@ class ServicesDBTest(unittest.TestCase):
|
||||
|
||||
def testc_delete_servicesbinding(self):
|
||||
"""delete services binding"""
|
||||
binding_serv = self.dbtest.create_servicebinding("i-00001", \
|
||||
"mng_net", "northb_net", "northb_net")
|
||||
binding_serv = self.dbtest.create_servicebinding(
|
||||
"i-00001", "mng_net", "northb_net", "northb_net")
|
||||
self.dbtest.delete_servicebinding("i-00001")
|
||||
bindings = self.dbtest.get_all_servicesbindings()
|
||||
count = 0
|
||||
@ -967,7 +969,7 @@ class L2networkDBTest(unittest.TestCase):
|
||||
"""test update portprofile"""
|
||||
pp1 = self.dbtest.create_portprofile("t1", "portprofile1", 10, "qos1")
|
||||
self.assertTrue(pp1["portprofile-name"] == "portprofile1")
|
||||
pp1 = self.dbtest.update_portprofile("t1", pp1["portprofile-id"], \
|
||||
pp1 = self.dbtest.update_portprofile("t1", pp1["portprofile-id"],
|
||||
"newportprofile1", 20, "qos2")
|
||||
pps = self.dbtest.get_all_portprofiles()
|
||||
count = 0
|
||||
@ -982,7 +984,7 @@ class L2networkDBTest(unittest.TestCase):
|
||||
net1 = self.quantum.create_network("t1", "netid1")
|
||||
port1 = self.quantum.create_port(net1["net-id"])
|
||||
pp1 = self.dbtest.create_portprofile("t1", "portprofile1", 10, "qos1")
|
||||
pp_binding1 = self.dbtest.create_pp_binding("t1", port1["port-id"], \
|
||||
pp_binding1 = self.dbtest.create_pp_binding("t1", port1["port-id"],
|
||||
pp1["portprofile-id"], "0")
|
||||
self.assertTrue(pp_binding1["tenant-id"] == "t1")
|
||||
self.teardown_portprofilebinding()
|
||||
@ -997,10 +999,10 @@ class L2networkDBTest(unittest.TestCase):
|
||||
port2 = self.quantum.create_port(net1["net-id"])
|
||||
pp1 = self.dbtest.create_portprofile("t1", "portprofile1", 10, "qos1")
|
||||
pp2 = self.dbtest.create_portprofile("t1", "portprofile2", 20, "qos2")
|
||||
pp_binding1 = self.dbtest.create_pp_binding("t1", port1["port-id"], \
|
||||
pp_binding1 = self.dbtest.create_pp_binding("t1", port1["port-id"],
|
||||
pp1["portprofile-id"], "0")
|
||||
self.assertTrue(pp_binding1["tenant-id"] == "t1")
|
||||
pp_binding2 = self.dbtest.create_pp_binding("t1", port2["port-id"], \
|
||||
pp_binding2 = self.dbtest.create_pp_binding("t1", port2["port-id"],
|
||||
pp2["portprofile-id"], "0")
|
||||
self.assertTrue(pp_binding2["tenant-id"] == "t1")
|
||||
pp_bindings = self.dbtest.get_all_pp_bindings()
|
||||
@ -1019,10 +1021,10 @@ class L2networkDBTest(unittest.TestCase):
|
||||
net1 = self.quantum.create_network("t1", "netid1")
|
||||
port1 = self.quantum.create_port(net1["net-id"])
|
||||
pp1 = self.dbtest.create_portprofile("t1", "portprofile1", 10, "qos1")
|
||||
pp_binding1 = self.dbtest.create_pp_binding("t1", port1["port-id"], \
|
||||
pp_binding1 = self.dbtest.create_pp_binding("t1", port1["port-id"],
|
||||
pp1["portprofile-id"], "0")
|
||||
self.assertTrue(pp_binding1["tenant-id"] == "t1")
|
||||
self.dbtest.delete_pp_binding("t1", port1["port-id"], \
|
||||
self.dbtest.delete_pp_binding("t1", port1["port-id"],
|
||||
pp_binding1["portprofile-id"])
|
||||
pp_bindings = self.dbtest.get_all_pp_bindings()
|
||||
count = 0
|
||||
@ -1040,11 +1042,11 @@ class L2networkDBTest(unittest.TestCase):
|
||||
net1 = self.quantum.create_network("t1", "netid1")
|
||||
port1 = self.quantum.create_port(net1["net-id"])
|
||||
pp1 = self.dbtest.create_portprofile("t1", "portprofile1", 10, "qos1")
|
||||
pp_binding1 = self.dbtest.create_pp_binding("t1", port1["port-id"], \
|
||||
pp_binding1 = self.dbtest.create_pp_binding("t1", port1["port-id"],
|
||||
pp1["portprofile-id"], "0")
|
||||
self.assertTrue(pp_binding1["tenant-id"] == "t1")
|
||||
pp_binding1 = self.dbtest.update_pp_binding("t1", \
|
||||
pp1["portprofile-id"], "newt1", port1["port-id"], "1")
|
||||
pp_binding1 = self.dbtest.update_pp_binding(
|
||||
"t1", pp1["portprofile-id"], "newt1", port1["port-id"], "1")
|
||||
pp_bindings = self.dbtest.get_all_pp_bindings()
|
||||
count = 0
|
||||
for pp_bind in pp_bindings:
|
||||
@ -1246,26 +1248,3 @@ class QuantumDBTest(unittest.TestCase):
|
||||
for port in ports:
|
||||
self.dbtest.delete_port(port["net-id"], port["port-id"])
|
||||
self.dbtest.delete_network(netid)
|
||||
|
||||
"""
|
||||
if __name__ == "__main__":
|
||||
usagestr = "Usage: %prog [OPTIONS] <command> [args]"
|
||||
parser = OptionParser(usage=usagestr)
|
||||
parser.add_option("-v", "--verbose", dest="verbose",
|
||||
action="store_true", default=False, help="turn on verbose logging")
|
||||
|
||||
options, args = parser.parse_args()
|
||||
|
||||
if options.verbose:
|
||||
LOG.basicConfig(level=LOG.DEBUG)
|
||||
else:
|
||||
LOG.basicConfig(level=LOG.WARN)
|
||||
|
||||
l2network_db.initialize()
|
||||
|
||||
# Run the tests
|
||||
suite = unittest.TestLoader().loadTestsFromTestCase(QuantumDBTest)
|
||||
unittest.TextTestRunner(verbosity=2).run(suite)
|
||||
suite = unittest.TestLoader().loadTestsFromTestCase(L2networkDBTest)
|
||||
unittest.TextTestRunner(verbosity=2).run(suite)
|
||||
"""
|
||||
|
@ -19,6 +19,7 @@
|
||||
|
||||
import logging
|
||||
import unittest
|
||||
|
||||
from quantum.common import exceptions as exc
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.common import cisco_exceptions as cexc
|
||||
@ -27,6 +28,7 @@ from quantum.plugins.cisco import l2network_plugin_configuration as conf
|
||||
from quantum.plugins.cisco.db import api as db
|
||||
from quantum.plugins.cisco.db import l2network_db as cdb
|
||||
|
||||
|
||||
LOG = logging.getLogger('quantum.tests.test_core_api_func')
|
||||
|
||||
|
||||
@ -70,8 +72,8 @@ class CoreAPITestFunc(unittest.TestCase):
|
||||
tenant_id, new_net_dict[const.NET_ID])
|
||||
self.assertRaises(exc.NetworkNotFound, db.network_get,
|
||||
new_net_dict[const.NET_ID])
|
||||
self.assertEqual(
|
||||
new_net_dict[const.NET_ID], delete_net_dict[const.NET_ID])
|
||||
self.assertEqual(new_net_dict[const.NET_ID],
|
||||
delete_net_dict[const.NET_ID])
|
||||
LOG.debug("test_delete_network - END")
|
||||
|
||||
def test_delete_networkDNE(self, net_tenant_id=None, net_id='0005'):
|
||||
@ -138,8 +140,8 @@ class CoreAPITestFunc(unittest.TestCase):
|
||||
tenant_id, new_net_dict[const.NET_ID])
|
||||
net = db.network_get(new_net_dict[const.NET_ID])
|
||||
self.assertEqual(net[const.UUID], new_net_dict[const.NET_ID])
|
||||
self.assertEqual(
|
||||
new_net_dict[const.NET_ID], result_net_dict[const.NET_ID])
|
||||
self.assertEqual(new_net_dict[const.NET_ID],
|
||||
result_net_dict[const.NET_ID])
|
||||
self.tearDownNetwork(tenant_id, new_net_dict[const.NET_ID])
|
||||
LOG.debug("test_show_network - END")
|
||||
|
||||
@ -347,9 +349,11 @@ class CoreAPITestFunc(unittest.TestCase):
|
||||
self.tearDownNetwork(tenant_id, new_net_dict[const.NET_ID])
|
||||
LOG.debug("test_delete_portDNE - END")
|
||||
|
||||
def test_delete_portInUse(
|
||||
self, tenant_id='test_tenant', instance_tenant_id='nova',
|
||||
nova_user_id='novaadmin', instance_id=10,
|
||||
def test_delete_portInUse(self,
|
||||
tenant_id='test_tenant',
|
||||
instance_tenant_id='nova',
|
||||
nova_user_id='novaadmin',
|
||||
instance_id=10,
|
||||
vif_id='fe701ddf-26a2-42ea-b9e6-7313d1c522cc'):
|
||||
"""
|
||||
Tests deletion of Ports when port is in Use.
|
||||
@ -477,9 +481,11 @@ class CoreAPITestFunc(unittest.TestCase):
|
||||
self.tearDownNetwork(tenant_id, new_net_dict[const.NET_ID])
|
||||
LOG.debug("test_show_portDNE - END")
|
||||
|
||||
def test_plug_interface(
|
||||
self, tenant_id='test_tenant', instance_tenant_id='nova',
|
||||
nova_user_id='novaadmin', instance_id=10,
|
||||
def test_plug_interface(self,
|
||||
tenant_id='test_tenant',
|
||||
instance_tenant_id='nova',
|
||||
nova_user_id='novaadmin',
|
||||
instance_id=10,
|
||||
vif_id='fe701ddf-26a2-42ea-b9e6-7313d1c522cc'):
|
||||
"""
|
||||
Tests attachment of interface to the port
|
||||
@ -514,9 +520,11 @@ class CoreAPITestFunc(unittest.TestCase):
|
||||
|
||||
LOG.debug("test_plug_interface - END")
|
||||
|
||||
def test_plug_interface_networkDNE(
|
||||
self, tenant_id='test_tenant', net_id='0005',
|
||||
port_id='p0005', remote_interface='new_interface'):
|
||||
def test_plug_interface_networkDNE(self,
|
||||
tenant_id='test_tenant',
|
||||
net_id='0005',
|
||||
port_id='p0005',
|
||||
remote_interface='new_interface'):
|
||||
"""
|
||||
Tests attachment of interface network does not exist
|
||||
"""
|
||||
@ -535,8 +543,8 @@ class CoreAPITestFunc(unittest.TestCase):
|
||||
"""
|
||||
|
||||
LOG.debug("test_plug_interface_portDNE - START")
|
||||
new_net_dict = self._l2network_plugin.create_network(
|
||||
tenant_id, self.network_name)
|
||||
new_net_dict = self._l2network_plugin.create_network(tenant_id,
|
||||
self.network_name)
|
||||
self.assertRaises(
|
||||
exc.PortNotFound, self._l2network_plugin.plug_interface, tenant_id,
|
||||
new_net_dict[const.NET_ID], port_id, remote_interface)
|
||||
@ -548,7 +556,6 @@ class CoreAPITestFunc(unittest.TestCase):
|
||||
nova_user_id='novaadmin', instance_id=10,
|
||||
vif_id='fe701ddf-26a2-42ea-b9e6-7313d1c522cc',
|
||||
remote_interface='new_interface'):
|
||||
|
||||
"""
|
||||
Tests attachment of new interface to the port when there is an
|
||||
existing attachment
|
||||
@ -585,7 +592,6 @@ class CoreAPITestFunc(unittest.TestCase):
|
||||
self, tenant_id='test_tenant', instance_tenant_id='nova',
|
||||
nova_user_id='novaadmin', instance_id=10,
|
||||
vif_id='fe701ddf-26a2-42ea-b9e6-7313d1c522cc'):
|
||||
|
||||
"""
|
||||
Tests detaachment of an interface to a port
|
||||
"""
|
||||
@ -866,8 +872,7 @@ class CoreAPITestFunc(unittest.TestCase):
|
||||
self.tearDownAssociatePortProfile(
|
||||
tenant_id, new_net_dict[const.NET_ID],
|
||||
port_dict[const.PORT_ID], port_profile_id)
|
||||
self.tearDownNetworkPort(
|
||||
tenant_id, new_net_dict[const.NET_ID],
|
||||
self.tearDownNetworkPort(tenant_id, new_net_dict[const.NET_ID],
|
||||
port_dict[const.PORT_ID])
|
||||
LOG.debug("test_associate_portprofile - END")
|
||||
|
||||
@ -1050,11 +1055,13 @@ class CoreAPITestFunc(unittest.TestCase):
|
||||
qos):
|
||||
profile_associations = self._make_portprofile_assc_list(
|
||||
tenant_id, profile_id)
|
||||
res = {const.PROFILE_ID: str(profile_id),
|
||||
res = {
|
||||
const.PROFILE_ID: str(profile_id),
|
||||
const.PROFILE_NAME: profile_name,
|
||||
const.PROFILE_ASSOCIATIONS: profile_associations,
|
||||
const.PROFILE_VLAN_ID: None,
|
||||
const.PROFILE_QOS: qos}
|
||||
const.PROFILE_QOS: qos,
|
||||
}
|
||||
return res
|
||||
|
||||
def _make_portprofile_assc_list(self, tenant_id, profile_id):
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -19,23 +18,22 @@
|
||||
# @author: Peter Strunk, Cisco Systems, Inc.
|
||||
# @author: Atul Gaikad, Cisco Systems, Inc.
|
||||
# @author: Tyler Smith, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import logging
|
||||
import unittest
|
||||
import logging as LOG
|
||||
|
||||
from quantum.common import exceptions as exc
|
||||
from quantum.common import utils
|
||||
from quantum.plugins.cisco import l2network_plugin_configuration as conf
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.common import cisco_credentials as creds
|
||||
from quantum.plugins.cisco.models import l2network_multi_blade
|
||||
from quantum.plugins.cisco.db import api as db
|
||||
from quantum.plugins.cisco.db import l2network_db as cdb
|
||||
from quantum.plugins.cisco import l2network_plugin_configuration as conf
|
||||
from quantum.plugins.cisco.models import l2network_multi_blade
|
||||
|
||||
LOG.basicConfig(level=LOG.WARN)
|
||||
LOG.getLogger(__name__)
|
||||
|
||||
logging.basicConfig(level=logging.WARN)
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
# Set some data to use in tests
|
||||
@ -72,10 +70,10 @@ class TestMultiBlade(unittest.TestCase):
|
||||
self.port_id = 0
|
||||
|
||||
# Create the multiblade object
|
||||
self._l2network_multiblade = l2network_multi_blade. \
|
||||
L2NetworkMultiBlade()
|
||||
self.plugin_key = "quantum.plugins.cisco.ucs.cisco_ucs_plugin" + \
|
||||
".UCSVICPlugin"
|
||||
self._l2network_multiblade = (
|
||||
l2network_multi_blade.L2NetworkMultiBlade())
|
||||
self.plugin_key = (
|
||||
"quantum.plugins.cisco.ucs.cisco_ucs_plugin.UCSVICPlugin")
|
||||
|
||||
# Get UCS inventory to make sure all UCSs are affected by tests
|
||||
for key in conf.PLUGINS[const.PLUGINS].keys():
|
||||
@ -83,8 +81,7 @@ class TestMultiBlade(unittest.TestCase):
|
||||
self._inventory[key] = utils.import_object(
|
||||
conf.PLUGINS[const.INVENTORY][key])
|
||||
|
||||
self.ucs_count = self._inventory['ucs_plugin'].\
|
||||
_inventory.__len__()
|
||||
self.ucs_count = self._inventory['ucs_plugin']._inventory.__len__()
|
||||
|
||||
def tearDown(self):
|
||||
"""Tear down our tests"""
|
||||
@ -113,11 +110,13 @@ class TestMultiBlade(unittest.TestCase):
|
||||
|
||||
# Create the network in the test DB, then with the model
|
||||
self.net_id = db.network_create(tenant_id, net_name)[const.UUID]
|
||||
networks = self._l2network_multiblade.create_network([tenant_id,
|
||||
networks = self._l2network_multiblade.create_network([
|
||||
tenant_id,
|
||||
net_name,
|
||||
self.net_id,
|
||||
vlan_name(self.net_id),
|
||||
vlan_id])
|
||||
vlan_id,
|
||||
])
|
||||
cdb.add_vlan_binding(vlan_id, vlan_name(self.net_id), self.net_id)
|
||||
|
||||
for network in networks:
|
||||
@ -174,9 +173,11 @@ class TestMultiBlade(unittest.TestCase):
|
||||
|
||||
net_details = db.network_update(self.net_id, tenant_id,
|
||||
name=new_net_name)
|
||||
networks = self._l2network_multiblade.update_network([tenant_id,
|
||||
networks = self._l2network_multiblade.update_network([
|
||||
tenant_id,
|
||||
self.net_id,
|
||||
{'name': new_net_name}])
|
||||
{'name': new_net_name},
|
||||
])
|
||||
|
||||
for network in networks:
|
||||
self.assertEqual(network[const.NET_ID], self.net_id)
|
||||
@ -285,8 +286,8 @@ class TestMultiBlade(unittest.TestCase):
|
||||
self.net_id,
|
||||
port_state, self.port_id])
|
||||
|
||||
interface = self._l2network_multiblade.plug_interface([tenant_id,
|
||||
self.net_id, self.port_id, interface_id])
|
||||
interface = self._l2network_multiblade.plug_interface(
|
||||
[tenant_id, self.net_id, self.port_id, interface_id])
|
||||
port = db.port_set_attachment(self.net_id, self.port_id, interface_id)
|
||||
|
||||
self.assertEqual(self.port_id, interface[0][const.PORTID])
|
||||
@ -352,7 +353,8 @@ class TestMultiBlade(unittest.TestCase):
|
||||
self.port_id, interface_id])
|
||||
db.port_set_attachment(self.net_id, self.port_id, interface_id)
|
||||
interface = self._l2network_multiblade.unplug_interface([tenant_id,
|
||||
self.net_id, self.port_id])
|
||||
self.net_id,
|
||||
self.port_id])
|
||||
|
||||
self.assertEqual(self.port_id, interface[0][const.PORTID])
|
||||
LOG.debug("test_unplug_interface - END")
|
||||
|
@ -13,17 +13,18 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Shweta Padubidri, Peter Strunk, Cisco Systems, Inc.
|
||||
#
|
||||
|
||||
import logging
|
||||
import unittest
|
||||
|
||||
from quantum.common import exceptions as exc
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.common import cisco_credentials as creds
|
||||
from quantum.plugins.cisco.db import l2network_db as cdb
|
||||
from quantum.plugins.cisco.db import api as db
|
||||
from quantum.plugins.cisco.common import cisco_credentials as cred
|
||||
from quantum.plugins.cisco.db import l2network_db as cdb
|
||||
from quantum.plugins.cisco.nexus import cisco_nexus_plugin
|
||||
|
||||
|
||||
LOG = logging.getLogger('quantum.tests.test_nexus')
|
||||
|
||||
|
||||
@ -42,7 +43,7 @@ class TestNexusPlugin(unittest.TestCase):
|
||||
self.port_id = "9"
|
||||
db.configure_db({'sql_connection': 'sqlite:///:memory:'})
|
||||
cdb.initialize()
|
||||
cred.Store.initialize()
|
||||
creds.Store.initialize()
|
||||
self._cisco_nexus_plugin = cisco_nexus_plugin.NexusPlugin()
|
||||
|
||||
def test_create_network(self, net_tenant_id=None, network_name=None,
|
||||
|
@ -22,52 +22,54 @@ import unittest
|
||||
|
||||
from quantum.plugins.cisco.ucs import cisco_ucs_network_driver
|
||||
|
||||
|
||||
LOG = logging.getLogger('quantum.tests.test_ucs_driver')
|
||||
|
||||
CREATE_VLAN_OUTPUT = "<configConfMos cookie=\"cookie_placeholder\" "\
|
||||
"inHierarchical=\"true\"> <inConfigs><pair key=\"fabric/lan/net-New Vlan\"> "\
|
||||
"<fabricVlan defaultNet=\"no\" dn=\"fabric/lan/net-New Vlan\" id=\"200\" "\
|
||||
"name=\"New Vlan\" status=\"created\"></fabricVlan> </pair> </inConfigs> "\
|
||||
"</configConfMos>"
|
||||
|
||||
CREATE_PROFILE_OUTPUT = "<configConfMos cookie=\"cookie_placeholder\" "\
|
||||
"inHierarchical=\"true\"> <inConfigs><pair key=\"fabric/lan/profiles/vnic-"\
|
||||
"New Profile\"> <vnicProfile descr=\"Profile created by Cisco OpenStack "\
|
||||
"Quantum Plugin\" dn=\"fabric/lan/profiles/vnic-New Profile\" maxPorts="\
|
||||
"\"64\" name=\"New Profile\" nwCtrlPolicyName=\"\" pinToGroupName=\"\" "\
|
||||
"qosPolicyName=\"\" status=\"created\"> <vnicEtherIf defaultNet=\"yes\" "\
|
||||
"name=\"New Vlan\" rn=\"if-New Vlan\" > </vnicEtherIf> </vnicProfile> "\
|
||||
"</pair> </inConfigs> </configConfMos>"
|
||||
CREATE_VLAN_OUTPUT = ("<configConfMos cookie=\"cookie_placeholder\" "
|
||||
"inHierarchical=\"true\"> <inConfigs><pair key=\"fabric/lan/net-New Vlan\"> "
|
||||
"<fabricVlan defaultNet=\"no\" dn=\"fabric/lan/net-New Vlan\" id=\"200\" "
|
||||
"name=\"New Vlan\" status=\"created\"></fabricVlan> </pair> </inConfigs> "
|
||||
"</configConfMos>")
|
||||
|
||||
CHANGE_VLAN_OUTPUT = "<configConfMos cookie=\"cookie_placeholder\" "\
|
||||
"inHierarchical=\"true\"> <inConfigs><pair key=\""\
|
||||
"fabric/lan/profiles/vnic-New Profile\"> <vnicProfile descr=\"Profile "\
|
||||
"created by Cisco OpenStack Quantum Plugin\" "\
|
||||
"dn=\"fabric/lan/profiles/vnic-New Profile\" maxPorts=\"64\" "\
|
||||
"name=\"New Profile\" nwCtrlPolicyName=\"\" pinToGroupName=\"\" "\
|
||||
"qosPolicyName=\"\" status=\"created,modified\"><vnicEtherIf "\
|
||||
"rn=\"if-Old Vlan\" status=\"deleted\"> </vnicEtherIf> "\
|
||||
"<vnicEtherIf defaultNet=\"yes\" name=\"New Vlan\" rn=\"if-New Vlan\" > "\
|
||||
"</vnicEtherIf> </vnicProfile> </pair></inConfigs> </configConfMos>"
|
||||
CREATE_PROFILE_OUTPUT = ("<configConfMos cookie=\"cookie_placeholder\" "
|
||||
"inHierarchical=\"true\"> <inConfigs><pair key=\"fabric/lan/profiles/vnic-"
|
||||
"New Profile\"> <vnicProfile descr=\"Profile created by Cisco OpenStack "
|
||||
"Quantum Plugin\" dn=\"fabric/lan/profiles/vnic-New Profile\" maxPorts="
|
||||
"\"64\" name=\"New Profile\" nwCtrlPolicyName=\"\" pinToGroupName=\"\" "
|
||||
"qosPolicyName=\"\" status=\"created\"> <vnicEtherIf defaultNet=\"yes\" "
|
||||
"name=\"New Vlan\" rn=\"if-New Vlan\" > </vnicEtherIf> </vnicProfile> "
|
||||
"</pair> </inConfigs> </configConfMos>")
|
||||
|
||||
DELETE_VLAN_OUTPUT = "<configConfMos cookie=\"cookie_placeholder\" "\
|
||||
"inHierarchical=\"true\"> <inConfigs><pair key=\"fabric/lan/net-New Vlan\"> "\
|
||||
"<fabricVlan dn=\"fabric/lan/net-New Vlan\" status=\"deleted\"> "\
|
||||
"</fabricVlan> </pair> </inConfigs></configConfMos>"
|
||||
CHANGE_VLAN_OUTPUT = ("<configConfMos cookie=\"cookie_placeholder\" "
|
||||
"inHierarchical=\"true\"> <inConfigs><pair key=\""
|
||||
"fabric/lan/profiles/vnic-New Profile\"> <vnicProfile descr=\"Profile "
|
||||
"created by Cisco OpenStack Quantum Plugin\" "
|
||||
"dn=\"fabric/lan/profiles/vnic-New Profile\" maxPorts=\"64\" "
|
||||
"name=\"New Profile\" nwCtrlPolicyName=\"\" pinToGroupName=\"\" "
|
||||
"qosPolicyName=\"\" status=\"created,modified\"><vnicEtherIf "
|
||||
"rn=\"if-Old Vlan\" status=\"deleted\"> </vnicEtherIf> "
|
||||
"<vnicEtherIf defaultNet=\"yes\" name=\"New Vlan\" rn=\"if-New Vlan\" > "
|
||||
"</vnicEtherIf> </vnicProfile> </pair></inConfigs> </configConfMos>")
|
||||
|
||||
DELETE_PROFILE_OUTPUT = "<configConfMos cookie=\"cookie_placeholder\" "\
|
||||
"inHierarchical=\"false\"> <inConfigs><pair key=\""\
|
||||
"fabric/lan/profiles/vnic-New Profile\"> <vnicProfile "\
|
||||
"dn=\"fabric/lan/profiles/vnic-New Profile\" status=\"deleted\"> "\
|
||||
"</vnicProfile></pair> </inConfigs> </configConfMos>"
|
||||
DELETE_VLAN_OUTPUT = ("<configConfMos cookie=\"cookie_placeholder\" "
|
||||
"inHierarchical=\"true\"> <inConfigs><pair key=\"fabric/lan/net-New Vlan\"> "
|
||||
"<fabricVlan dn=\"fabric/lan/net-New Vlan\" status=\"deleted\"> "
|
||||
"</fabricVlan> </pair> </inConfigs></configConfMos>")
|
||||
|
||||
ASSOCIATE_PROFILE_OUTPUT = "<configConfMos cookie=\"cookie_placeholder\" "\
|
||||
"inHierarchical=\"true\"> <inConfigs> <pair key="\
|
||||
"\"fabric/lan/profiles/vnic-New Profile/cl-New Profile Client\">"\
|
||||
" <vmVnicProfCl dcName=\".*\" descr=\"\" dn=\"fabric/lan/profiles/vnic-"\
|
||||
"New Profile/cl-New Profile Client\"name=\"New Profile Client\" "\
|
||||
"orgPath=\".*\" status=\"created\" swName=\"default$\"> </vmVnicProfCl>" \
|
||||
"</pair> </inConfigs> </configConfMos>"
|
||||
DELETE_PROFILE_OUTPUT = ("<configConfMos cookie=\"cookie_placeholder\" "
|
||||
"inHierarchical=\"false\"> <inConfigs><pair key=\""
|
||||
"fabric/lan/profiles/vnic-New Profile\"> <vnicProfile "
|
||||
"dn=\"fabric/lan/profiles/vnic-New Profile\" status=\"deleted\"> "
|
||||
"</vnicProfile></pair> </inConfigs> </configConfMos>")
|
||||
|
||||
ASSOCIATE_PROFILE_OUTPUT = ("<configConfMos cookie=\"cookie_placeholder\" "
|
||||
"inHierarchical=\"true\"> <inConfigs> <pair key="
|
||||
"\"fabric/lan/profiles/vnic-New Profile/cl-New Profile Client\">"
|
||||
" <vmVnicProfCl dcName=\".*\" descr=\"\" dn=\"fabric/lan/profiles/vnic-"
|
||||
"New Profile/cl-New Profile Client\"name=\"New Profile Client\" "
|
||||
"orgPath=\".*\" status=\"created\" swName=\"default$\"> </vmVnicProfCl>"
|
||||
"</pair> </inConfigs> </configConfMos>")
|
||||
|
||||
|
||||
class TestUCSDriver(unittest.TestCase):
|
||||
@ -130,8 +132,8 @@ class TestUCSDriver(unittest.TestCase):
|
||||
self.assertEqual(vlan_delete_details, expected_output)
|
||||
LOG.debug("test_create_profile_post - END")
|
||||
|
||||
def test_delete_profile_post_data(
|
||||
self, expected_output=DELETE_PROFILE_OUTPUT):
|
||||
def test_delete_profile_post_data(self,
|
||||
expected_output=DELETE_PROFILE_OUTPUT):
|
||||
"""
|
||||
Tests deletion of profile post Data
|
||||
"""
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -17,22 +16,22 @@
|
||||
#
|
||||
# @author: Shubhangi Satras, Cisco Systems, Inc.
|
||||
# @author: Tyler Smith, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import logging
|
||||
import unittest
|
||||
import logging as LOG
|
||||
|
||||
from quantum.common import exceptions as exc
|
||||
from quantum.plugins.cisco.l2network_plugin import L2Network
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.common import cisco_credentials as creds
|
||||
from quantum.plugins.cisco.db import api as db
|
||||
from quantum.plugins.cisco.db import l2network_db as cdb
|
||||
from quantum.plugins.cisco.l2network_plugin import L2Network
|
||||
from quantum.plugins.cisco.ucs.cisco_ucs_inventory import UCSInventory
|
||||
|
||||
LOG.basicConfig(level=LOG.WARN)
|
||||
LOG.getLogger(__name__)
|
||||
|
||||
logging.basicConfig(level=LOG.WARN)
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
# Set some data to use in tests
|
||||
tenant = 'shubh'
|
||||
@ -97,8 +96,8 @@ class TestUCSInventory(unittest.TestCase):
|
||||
|
||||
# Clean up created network and port
|
||||
try:
|
||||
self._l2network.unplug_interface(tenant,
|
||||
net[const.NET_ID], port[const.PORT_ID])
|
||||
self._l2network.unplug_interface(
|
||||
tenant, net[const.NET_ID], port[const.PORT_ID])
|
||||
except:
|
||||
pass
|
||||
self._l2network.delete_port(tenant,
|
||||
|
@ -15,23 +15,23 @@
|
||||
#
|
||||
# @author: Shubhangi Satras, Cisco Systems, Inc.
|
||||
# Shweta Padubidri, Cisco Systems, Inc.
|
||||
#
|
||||
|
||||
import logging
|
||||
import unittest
|
||||
import logging as LOG
|
||||
|
||||
from quantum.common import exceptions as exc
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.ucs import cisco_ucs_plugin
|
||||
from quantum.plugins.cisco.ucs import cisco_ucs_configuration as conf
|
||||
from quantum.plugins.cisco.common import cisco_credentials as cred
|
||||
|
||||
from quantum.plugins.cisco.common import cisco_exceptions as c_exc
|
||||
from quantum.plugins.cisco.db import api as db
|
||||
from quantum.plugins.cisco.db import l2network_db as cdb
|
||||
from quantum.plugins.cisco.common import cisco_exceptions as c_exc
|
||||
|
||||
from quantum.plugins.cisco.ucs import cisco_ucs_configuration as conf
|
||||
from quantum.plugins.cisco.ucs import cisco_ucs_inventory as ucsinv
|
||||
from quantum.plugins.cisco.ucs import cisco_ucs_plugin
|
||||
|
||||
LOG.basicConfig(level=LOG.WARN)
|
||||
LOG.getLogger("cisco_ucs_plugin")
|
||||
|
||||
logging.basicConfig(level=LOG.WARN)
|
||||
LOG = logging.getLogger("cisco_ucs_plugin")
|
||||
|
||||
|
||||
class UCSVICTestPlugin(unittest.TestCase):
|
||||
@ -53,13 +53,13 @@ class UCSVICTestPlugin(unittest.TestCase):
|
||||
self.device_ip = conf.UCSM_IP_ADDRESS
|
||||
self._ucs_inventory = ucsinv.UCSInventory()
|
||||
self._ucs_inventory._load_inventory()
|
||||
self.chassis_id_list = self._ucs_inventory._inventory[\
|
||||
self.device_ip].keys()
|
||||
self.chassis_id_list = (
|
||||
self._ucs_inventory._inventory[self.device_ip].keys())
|
||||
self.chassis_id = self.chassis_id_list[0]
|
||||
self.blade_id_list = self._ucs_inventory._inventory[\
|
||||
self.device_ip][self.chassis_id]
|
||||
self.blade_id = self._ucs_inventory._inventory[\
|
||||
self.device_ip][self.chassis_id][0]
|
||||
self.blade_id_list = (
|
||||
self._ucs_inventory._inventory[self.device_ip][self.chassis_id])
|
||||
self.blade_id = (
|
||||
self._ucs_inventory._inventory[self.device_ip][self.chassis_id][0])
|
||||
|
||||
def test_create_network(self):
|
||||
"""
|
||||
@ -164,21 +164,21 @@ class UCSVICTestPlugin(unittest.TestCase):
|
||||
self.tenant_id, self.net_id, const.PORT_UP,
|
||||
new_port1[const.UUID], device_ip=self.device_ip,
|
||||
ucs_inventory=self._ucs_inventory,
|
||||
least_rsvd_blade_dict=self._ucs_inventory.\
|
||||
_get_least_reserved_blade())
|
||||
least_rsvd_blade_dict=(
|
||||
self._ucs_inventory._get_least_reserved_blade()))
|
||||
new_port2 = db.port_create(new_network[const.UUID], const.PORT_UP)
|
||||
port_dict2 = self._cisco_ucs_plugin.create_port(
|
||||
self.tenant_id, self.net_id, const.PORT_UP,
|
||||
new_port2[const.UUID], device_ip=self.device_ip,
|
||||
ucs_inventory=self._ucs_inventory,
|
||||
least_rsvd_blade_dict=self._ucs_inventory.\
|
||||
_get_least_reserved_blade())
|
||||
least_rsvd_blade_dict=(
|
||||
self._ucs_inventory._get_least_reserved_blade()))
|
||||
ports_on_net = self._cisco_ucs_plugin.get_all_ports(
|
||||
self.tenant_id, new_net_dict[const.NET_ID],
|
||||
device_ip=self.device_ip,
|
||||
ucs_inventory=self._ucs_inventory,
|
||||
least_rsvd_blade_dict=self._ucs_inventory.\
|
||||
_get_least_reserved_blade())
|
||||
least_rsvd_blade_dict=(
|
||||
self._ucs_inventory._get_least_reserved_blade()))
|
||||
port_list = [port_dict1, port_dict2]
|
||||
self.assertTrue(str(ports_on_net[1]) == str(port_list[1]) or
|
||||
str(ports_on_net[1]) == str(port_list[0]))
|
||||
@ -192,10 +192,10 @@ class UCSVICTestPlugin(unittest.TestCase):
|
||||
port_dict1[const.PORTID], device_ip=self.device_ip,
|
||||
ucs_inventory=self._ucs_inventory,
|
||||
chassis_id=self.chassis_id, blade_id=self.blade_id,
|
||||
blade_intf_distinguished_name=blade_intf_details[\
|
||||
blade_intf_distinguished_name=blade_intf_details[
|
||||
const.BLADE_INTF_DN],
|
||||
least_rsvd_blade_dict=self._ucs_inventory.\
|
||||
_get_least_reserved_blade())
|
||||
least_rsvd_blade_dict=(
|
||||
self._ucs_inventory._get_least_reserved_blade()))
|
||||
self.tear_down_network_port(
|
||||
self.tenant_id, new_net_dict[const.NET_ID],
|
||||
port_dict2[const.PORTID])
|
||||
@ -218,11 +218,11 @@ class UCSVICTestPlugin(unittest.TestCase):
|
||||
self.tenant_id, self.net_id, const.PORT_UP,
|
||||
new_port[const.UUID], device_ip=self.device_ip,
|
||||
ucs_inventory=self._ucs_inventory,
|
||||
least_rsvd_blade_dict=self._ucs_inventory.\
|
||||
_get_least_reserved_blade())
|
||||
least_rsvd_blade_dict=(
|
||||
self._ucs_inventory._get_least_reserved_blade()))
|
||||
self.assertEqual(port_dict[const.PORTID], new_port[const.UUID])
|
||||
profile_name = self._cisco_ucs_plugin.\
|
||||
_get_profile_name(port_dict[const.PORTID])
|
||||
profile_name = (
|
||||
self._cisco_ucs_plugin._get_profile_name(port_dict[const.PORTID]))
|
||||
self.assertTrue(profile_name is not None)
|
||||
self.tear_down_network_port(
|
||||
self.tenant_id, new_net_dict[const.NET_ID],
|
||||
@ -248,8 +248,8 @@ class UCSVICTestPlugin(unittest.TestCase):
|
||||
self.tenant_id, self.net_id, const.PORT_UP,
|
||||
new_port[const.UUID], device_ip=self.device_ip,
|
||||
ucs_inventory=self._ucs_inventory,
|
||||
least_rsvd_blade_dict=self._ucs_inventory.\
|
||||
_get_least_reserved_blade())
|
||||
least_rsvd_blade_dict=(
|
||||
self._ucs_inventory._get_least_reserved_blade()))
|
||||
|
||||
blade_intf_details = self._ucs_inventory._get_rsvd_blade_intf_by_port(
|
||||
self.tenant_id, port_dict[const.PORTID])
|
||||
@ -258,10 +258,10 @@ class UCSVICTestPlugin(unittest.TestCase):
|
||||
port_dict[const.PORTID], device_ip=self.device_ip,
|
||||
ucs_inventory=self._ucs_inventory,
|
||||
chassis_id=self.chassis_id, blade_id=self.blade_id,
|
||||
blade_intf_distinguished_name=blade_intf_details[\
|
||||
blade_intf_distinguished_name=blade_intf_details[
|
||||
const.BLADE_INTF_DN],
|
||||
least_rsvd_blade_dict=self._ucs_inventory.\
|
||||
_get_least_reserved_blade())
|
||||
least_rsvd_blade_dict=(
|
||||
self._ucs_inventory._get_least_reserved_blade()))
|
||||
|
||||
self.assertEqual(port_bind[const.PORTID], new_port[const.UUID])
|
||||
self.tear_down_network(self.tenant_id, new_net_dict[const.NET_ID])
|
||||
@ -284,8 +284,8 @@ class UCSVICTestPlugin(unittest.TestCase):
|
||||
self.tenant_id, self.net_id, port_state,
|
||||
new_port[const.UUID], device_ip=self.device_ip,
|
||||
ucs_inventory=self._ucs_inventory,
|
||||
least_rsvd_blade_dict=self._ucs_inventory.\
|
||||
_get_least_reserved_blade())
|
||||
least_rsvd_blade_dict=(
|
||||
self._ucs_inventory._get_least_reserved_blade()))
|
||||
|
||||
port_detail = self._cisco_ucs_plugin.get_port_details(
|
||||
self.tenant_id, new_net_dict[const.NET_ID],
|
||||
@ -321,8 +321,8 @@ class UCSVICTestPlugin(unittest.TestCase):
|
||||
self.tenant_id, new_network[const.UUID],
|
||||
new_port[const.UUID], self.vlan_name,
|
||||
self.vlan_id)
|
||||
profile_name = self._cisco_ucs_plugin.\
|
||||
_get_profile_name(new_port[const.UUID])
|
||||
profile_name = (
|
||||
self._cisco_ucs_plugin._get_profile_name(new_port[const.UUID]))
|
||||
self.assertEqual(new_port_profile[const.PROFILE_NAME], profile_name)
|
||||
self.assertEqual(new_port_profile[const.PROFILE_VLAN_NAME],
|
||||
self.vlan_name)
|
||||
@ -344,8 +344,8 @@ class UCSVICTestPlugin(unittest.TestCase):
|
||||
self.tenant_id, new_network[const.UUID],
|
||||
new_port[const.UUID], self.vlan_name,
|
||||
self.vlan_id)
|
||||
profile_name = self._cisco_ucs_plugin.\
|
||||
_get_profile_name(new_port[const.UUID])
|
||||
profile_name = (
|
||||
self._cisco_ucs_plugin._get_profile_name(new_port[const.UUID]))
|
||||
|
||||
counter1 = self._cisco_ucs_plugin._port_profile_counter
|
||||
self._cisco_ucs_plugin._delete_port_profile(new_port[const.UUID],
|
||||
@ -373,8 +373,8 @@ class UCSVICTestPlugin(unittest.TestCase):
|
||||
const.PORT_UP, new_port[const.UUID],
|
||||
device_ip=self.device_ip,
|
||||
ucs_inventory=self._ucs_inventory,
|
||||
least_rsvd_blade_dict=self._ucs_inventory.\
|
||||
_get_least_reserved_blade())
|
||||
least_rsvd_blade_dict=(
|
||||
self._ucs_inventory._get_least_reserved_blade()))
|
||||
cdb.update_vlan_binding(new_network[const.UUID],
|
||||
str(new_vlanid), new_vlan_name)
|
||||
port_bind = self._cisco_ucs_plugin.plug_interface(
|
||||
@ -407,8 +407,8 @@ class UCSVICTestPlugin(unittest.TestCase):
|
||||
const.PORT_UP, new_port[const.UUID],
|
||||
device_ip=self.device_ip,
|
||||
ucs_inventory=self._ucs_inventory,
|
||||
least_rsvd_blade_dict=self._ucs_inventory.\
|
||||
_get_least_reserved_blade())
|
||||
least_rsvd_blade_dict=(
|
||||
self._ucs_inventory._get_least_reserved_blade()))
|
||||
cdb.update_vlan_binding(new_network[const.UUID],
|
||||
str(new_vlanid), new_vlan_name)
|
||||
self._cisco_ucs_plugin.plug_interface(
|
||||
@ -487,8 +487,8 @@ class UCSVICTestPlugin(unittest.TestCase):
|
||||
ucs_inventory=self._ucs_inventory,
|
||||
chassis_id=self.chassis_id, blade_id=self.blade_id,
|
||||
blade_intf_distinguished_name=None,
|
||||
least_rsvd_blade_dict=self._ucs_inventory.\
|
||||
_get_least_reserved_blade())
|
||||
least_rsvd_blade_dict=(
|
||||
self._ucs_inventory._get_least_reserved_blade()))
|
||||
|
||||
self.tear_down_network(self.tenant_id, new_net_dict[const.NET_ID])
|
||||
|
||||
@ -508,14 +508,13 @@ class UCSVICTestPlugin(unittest.TestCase):
|
||||
tenant_id, net_id, port_id, device_ip=self.device_ip,
|
||||
ucs_inventory=self._ucs_inventory,
|
||||
chassis_id=self.chassis_id, blade_id=self.blade_id,
|
||||
blade_intf_distinguished_name=blade_intf_details[\
|
||||
blade_intf_distinguished_name=blade_intf_details[
|
||||
const.BLADE_INTF_DN],
|
||||
least_rsvd_blade_dict=self._ucs_inventory.\
|
||||
_get_least_reserved_blade())
|
||||
least_rsvd_blade_dict=(
|
||||
self._ucs_inventory._get_least_reserved_blade()))
|
||||
self.tear_down_network(tenant_id, net_id)
|
||||
|
||||
def tear_down_network_port_interface(self, tenant_id, net_id, port_id):
|
||||
self._cisco_ucs_plugin.unplug_interface(
|
||||
tenant_id, net_id, port_id,
|
||||
self._cisco_ucs_plugin.unplug_interface(tenant_id, net_id, port_id,
|
||||
device_ip=self.device_ip)
|
||||
self.tear_down_network_port(tenant_id, net_id, port_id)
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,23 +15,23 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Peter Strunk, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import logging
|
||||
import unittest
|
||||
import logging as LOG
|
||||
|
||||
from quantum.common import exceptions as exc
|
||||
from quantum.plugins.cisco import l2network_plugin_configuration as conf
|
||||
from quantum.plugins.cisco.common import cisco_exceptions as c_exc
|
||||
from quantum.plugins.cisco.common import cisco_credentials as creds
|
||||
from quantum.plugins.cisco.db import api as db
|
||||
from quantum.plugins.cisco.db import l2network_db as cdb
|
||||
from quantum.plugins.cisco.segmentation.l2network_vlan_mgr \
|
||||
import L2NetworkVLANMgr
|
||||
from quantum.plugins.cisco import l2network_plugin_configuration as conf
|
||||
from quantum.plugins.cisco.segmentation.l2network_vlan_mgr import (
|
||||
L2NetworkVLANMgr,
|
||||
)
|
||||
|
||||
LOG.basicConfig(level=LOG.WARN)
|
||||
LOG.getLogger(__name__)
|
||||
|
||||
logging.basicConfig(level=logging.WARN)
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class Test_L2Network_Vlan_Mgr(unittest.TestCase):
|
||||
@ -50,8 +49,8 @@ class Test_L2Network_Vlan_Mgr(unittest.TestCase):
|
||||
self.vlan_id = 300
|
||||
self.net_id = 100
|
||||
self.vlan_mgr = L2NetworkVLANMgr()
|
||||
self.plugin_key = "quantum.plugins.cisco.ucs.cisco_ucs_plugin" +\
|
||||
".UCSVICPlugin"
|
||||
self.plugin_key = (
|
||||
"quantum.plugins.cisco.ucs.cisco_ucs_plugin.UCSVICPlugin")
|
||||
|
||||
def tearDown(self):
|
||||
db.clear_db()
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -17,4 +16,3 @@
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -17,7 +16,6 @@
|
||||
#
|
||||
# @author: Rohit Agarwalla, Cisco Systems Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import subprocess
|
||||
|
||||
@ -25,29 +23,29 @@ import subprocess
|
||||
def get_next_dynic(argv=[]):
|
||||
"""Get the next available dynamic nic on this host"""
|
||||
cmd = ["ifconfig", "-a"]
|
||||
f_cmd_output = subprocess.Popen(cmd, stdout=subprocess.PIPE).\
|
||||
communicate()[0]
|
||||
eths = [lines.split(' ')[0] for lines in f_cmd_output.splitlines() \
|
||||
f_cmd_output = (
|
||||
subprocess.Popen(cmd, stdout=subprocess.PIPE).communicate()[0])
|
||||
eths = [lines.split(' ')[0] for lines in f_cmd_output.splitlines()
|
||||
if "eth" in lines]
|
||||
#print eths
|
||||
for eth in eths:
|
||||
cmd = ["ethtool", "-i", eth]
|
||||
f_cmd_output = subprocess.Popen(cmd, stdout=subprocess.PIPE).\
|
||||
communicate()[0]
|
||||
bdf = [lines.split(' ')[1] for lines in f_cmd_output.splitlines() \
|
||||
f_cmd_output = (
|
||||
subprocess.Popen(cmd, stdout=subprocess.PIPE).communicate()[0])
|
||||
bdf = [lines.split(' ')[1] for lines in f_cmd_output.splitlines()
|
||||
if "bus-info" in lines]
|
||||
#print bdf
|
||||
cmd = ["lspci", "-n", "-s", bdf[0]]
|
||||
f_cmd_output = subprocess.Popen(cmd, stdout=subprocess.PIPE).\
|
||||
communicate()[0]
|
||||
deviceid = [(lines.split(':')[3]).split(' ')[0] \
|
||||
f_cmd_output = (subprocess.Popen(cmd, stdout=subprocess.PIPE).
|
||||
communicate()[0])
|
||||
deviceid = [(lines.split(':')[3]).split(' ')[0]
|
||||
for lines in f_cmd_output.splitlines()]
|
||||
#print deviceid
|
||||
if deviceid[0] == "0044":
|
||||
cmd = ["/sbin/ip", "link", "show", eth]
|
||||
f_cmd_output = subprocess.Popen(cmd, stdout=subprocess.PIPE).\
|
||||
communicate()[0]
|
||||
used = [lines for lines in f_cmd_output.splitlines() \
|
||||
f_cmd_output = (
|
||||
subprocess.Popen(cmd, stdout=subprocess.PIPE).communicate()[0])
|
||||
used = [lines for lines in f_cmd_output.splitlines()
|
||||
if "UP" in lines]
|
||||
if not used:
|
||||
break
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -17,12 +16,13 @@
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import os
|
||||
|
||||
from quantum.common.config import find_config_file
|
||||
from quantum.plugins.cisco.common import cisco_configparser as confp
|
||||
|
||||
|
||||
CP = confp.CiscoConfigParser(find_config_file({'plugin': 'cisco'}, [],
|
||||
'ucs.ini'))
|
||||
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,25 +15,6 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
from copy import deepcopy
|
||||
import logging
|
||||
|
||||
from quantum.common import exceptions as exc
|
||||
from quantum.plugins.cisco.l2device_inventory_base \
|
||||
import L2NetworkDeviceInventoryBase
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.common import cisco_credentials as cred
|
||||
from quantum.plugins.cisco.common import cisco_exceptions as cexc
|
||||
from quantum.plugins.cisco.common import cisco_utils as cutil
|
||||
from quantum.plugins.cisco.db import api as db
|
||||
from quantum.plugins.cisco.db import ucs_db as udb
|
||||
from quantum.plugins.cisco.ucs \
|
||||
import cisco_ucs_inventory_configuration as conf
|
||||
from quantum.plugins.cisco.ucs import cisco_ucs_network_driver
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
"""
|
||||
The _inventory data strcuture contains a nested disctioary:
|
||||
@ -80,6 +60,27 @@ const.INSTANCE_ID
|
||||
const.VIF_ID
|
||||
"""
|
||||
|
||||
from copy import deepcopy
|
||||
import logging
|
||||
|
||||
from quantum.common import exceptions as exc
|
||||
from quantum.plugins.cisco.l2device_inventory_base import (
|
||||
L2NetworkDeviceInventoryBase,
|
||||
)
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.common import cisco_credentials as cred
|
||||
from quantum.plugins.cisco.common import cisco_exceptions as cexc
|
||||
from quantum.plugins.cisco.common import cisco_utils as cutil
|
||||
from quantum.plugins.cisco.db import api as db
|
||||
from quantum.plugins.cisco.db import ucs_db as udb
|
||||
from quantum.plugins.cisco.ucs import (
|
||||
cisco_ucs_inventory_configuration as conf,
|
||||
)
|
||||
from quantum.plugins.cisco.ucs import cisco_ucs_network_driver
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class UCSInventory(L2NetworkDeviceInventoryBase):
|
||||
"""
|
||||
@ -110,10 +111,10 @@ class UCSInventory(L2NetworkDeviceInventoryBase):
|
||||
inventory[ucsm][chassis].pop(const.CHASSIS_ID)
|
||||
blade_list = []
|
||||
for blade in inventory[ucsm][chassis].keys():
|
||||
blade_id = \
|
||||
inventory[ucsm][chassis][blade][const.BLADE_ID]
|
||||
host_name = \
|
||||
inventory[ucsm][chassis][blade][const.HOST_NAME]
|
||||
blade_id = (
|
||||
inventory[ucsm][chassis][blade][const.BLADE_ID])
|
||||
host_name = (
|
||||
inventory[ucsm][chassis][blade][const.HOST_NAME])
|
||||
host_key = ucsm_ip + "-" + chassis_id + "-" + blade_id
|
||||
self._host_names[host_key] = host_name
|
||||
blade_list.append(blade_id)
|
||||
@ -178,18 +179,18 @@ class UCSInventory(L2NetworkDeviceInventoryBase):
|
||||
if not const.VIF_ID in blade_intf_data[blade_intf].keys():
|
||||
blade_intf_data[blade_intf][const.VIF_ID] = None
|
||||
|
||||
if (blade_intf_data[blade_intf][const.BLADE_INTF_LINK_STATE] == \
|
||||
const.BLADE_INTF_STATE_UNALLOCATED or \
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_LINK_STATE] == \
|
||||
const.BLADE_INTF_STATE_UNKNOWN) and \
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_OPER_STATE] == \
|
||||
const.BLADE_INTF_STATE_UNKNOWN:
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_RESERVATION] = \
|
||||
const.BLADE_INTF_UNRESERVED
|
||||
if (blade_intf_data[blade_intf][const.BLADE_INTF_LINK_STATE] ==
|
||||
const.BLADE_INTF_STATE_UNALLOCATED or
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_LINK_STATE] ==
|
||||
const.BLADE_INTF_STATE_UNKNOWN) and (
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_OPER_STATE] ==
|
||||
const.BLADE_INTF_STATE_UNKNOWN):
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_RESERVATION] = (
|
||||
const.BLADE_INTF_UNRESERVED)
|
||||
unreserved_counter += 1
|
||||
else:
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_RESERVATION] = \
|
||||
const.BLADE_INTF_RESERVED
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_RESERVATION] = (
|
||||
const.BLADE_INTF_RESERVED)
|
||||
|
||||
port_binding = udb.get_portbinding_dn(dist_name)
|
||||
if port_binding:
|
||||
@ -198,21 +199,17 @@ class UCSInventory(L2NetworkDeviceInventoryBase):
|
||||
# need to change it, and also load the state from the DB for
|
||||
# other associations
|
||||
intf_data = blade_intf_data[blade_intf]
|
||||
if intf_data[const.BLADE_INTF_RESERVATION] == \
|
||||
const.BLADE_INTF_UNRESERVED:
|
||||
if (intf_data[const.BLADE_INTF_RESERVATION] ==
|
||||
const.BLADE_INTF_UNRESERVED):
|
||||
unreserved_counter -= 1
|
||||
intf_data[const.BLADE_INTF_RESERVATION] = \
|
||||
const.BLADE_INTF_RESERVED
|
||||
intf_data[const.TENANTID] = \
|
||||
port_binding[const.TENANTID]
|
||||
intf_data[const.PORTID] = \
|
||||
port_binding[const.PORTID]
|
||||
intf_data[const.PROFILE_ID] = \
|
||||
port_binding[const.PORTPROFILENAME]
|
||||
intf_data[const.INSTANCE_ID] = \
|
||||
port_binding[const.INSTANCE_ID]
|
||||
intf_data[const.VIF_ID] = \
|
||||
port_binding[const.VIF_ID]
|
||||
intf_data[const.BLADE_INTF_RESERVATION] = (
|
||||
const.BLADE_INTF_RESERVED)
|
||||
intf_data[const.TENANTID] = port_binding[const.TENANTID]
|
||||
intf_data[const.PORTID] = port_binding[const.PORTID]
|
||||
intf_data[const.PROFILE_ID] = (
|
||||
port_binding[const.PORTPROFILENAME])
|
||||
intf_data[const.INSTANCE_ID] = port_binding[const.INSTANCE_ID]
|
||||
intf_data[const.VIF_ID] = port_binding[const.VIF_ID]
|
||||
host_name = self._get_host_name(ucsm_ip, chassis_id, blade_id)
|
||||
blade_data = {const.BLADE_INTF_DATA: blade_intf_data,
|
||||
const.BLADE_UNRESERVED_INTF_COUNT: unreserved_counter,
|
||||
@ -228,18 +225,18 @@ class UCSInventory(L2NetworkDeviceInventoryBase):
|
||||
unreserved_counter = 0
|
||||
|
||||
for blade_intf in blade_intf_data.keys():
|
||||
if (blade_intf_data[blade_intf][const.BLADE_INTF_LINK_STATE] == \
|
||||
const.BLADE_INTF_STATE_UNALLOCATED or \
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_LINK_STATE] == \
|
||||
const.BLADE_INTF_STATE_UNKNOWN) and \
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_OPER_STATE] == \
|
||||
const.BLADE_INTF_STATE_UNKNOWN:
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_RESERVATION] = \
|
||||
const.BLADE_INTF_UNRESERVED
|
||||
if (blade_intf_data[blade_intf][const.BLADE_INTF_LINK_STATE] ==
|
||||
const.BLADE_INTF_STATE_UNALLOCATED or
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_LINK_STATE] ==
|
||||
const.BLADE_INTF_STATE_UNKNOWN) and (
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_OPER_STATE] ==
|
||||
const.BLADE_INTF_STATE_UNKNOWN):
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_RESERVATION] = (
|
||||
const.BLADE_INTF_UNRESERVED)
|
||||
unreserved_counter += 1
|
||||
else:
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_RESERVATION] = \
|
||||
const.BLADE_INTF_RESERVED
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_RESERVATION] = (
|
||||
const.BLADE_INTF_RESERVED)
|
||||
|
||||
blade_data = {const.BLADE_INTF_DATA: blade_intf_data,
|
||||
const.BLADE_UNRESERVED_INTF_COUNT: unreserved_counter}
|
||||
@ -307,14 +304,13 @@ class UCSInventory(L2NetworkDeviceInventoryBase):
|
||||
blade_intf_data = blade_data[const.BLADE_INTF_DATA]
|
||||
for blade_intf in blade_intf_data.keys():
|
||||
intf_data = blade_intf_data[blade_intf]
|
||||
if intf_data[const.BLADE_INTF_RESERVATION] == \
|
||||
const.BLADE_INTF_RESERVED and \
|
||||
intf_data[const.TENANTID] == tenant_id and \
|
||||
intf_data[const.INSTANCE_ID] == instance_id:
|
||||
if (intf_data[const.BLADE_INTF_RESERVATION] ==
|
||||
const.BLADE_INTF_RESERVED and
|
||||
intf_data[const.TENANTID] == tenant_id and
|
||||
intf_data[const.INSTANCE_ID] == instance_id):
|
||||
found_blade_intf_data = blade_intf_data
|
||||
LOG.debug("Found blade %s associated with this" \
|
||||
" instance: %s" % \
|
||||
(blade_id,
|
||||
LOG.debug(("Found blade %s associated with this"
|
||||
" instance: %s") % (blade_id,
|
||||
instance_id))
|
||||
break
|
||||
|
||||
@ -322,25 +318,26 @@ class UCSInventory(L2NetworkDeviceInventoryBase):
|
||||
blade_intf_data = found_blade_intf_data
|
||||
for blade_intf in blade_intf_data.keys():
|
||||
intf_data = blade_intf_data[blade_intf]
|
||||
if intf_data[const.BLADE_INTF_RESERVATION] == \
|
||||
const.BLADE_INTF_RESERVED and \
|
||||
intf_data[const.TENANTID] == tenant_id and \
|
||||
(not intf_data[const.VIF_ID]):
|
||||
if (intf_data[const.BLADE_INTF_RESERVATION] ==
|
||||
const.BLADE_INTF_RESERVED and
|
||||
intf_data[const.TENANTID] == tenant_id and
|
||||
(not intf_data[const.VIF_ID])):
|
||||
intf_data[const.VIF_ID] = vif_id
|
||||
intf_data[const.INSTANCE_ID] = instance_id
|
||||
port_binding = udb.get_portbinding_dn(blade_intf)
|
||||
port_id = port_binding[const.PORTID]
|
||||
udb.update_portbinding(port_id, instance_id=instance_id,
|
||||
vif_id=vif_id)
|
||||
db.port_set_attachment_by_id(port_id, vif_id +
|
||||
const.UNPLUGGED)
|
||||
db.port_set_attachment_by_id(port_id,
|
||||
vif_id + const.UNPLUGGED)
|
||||
device_name = intf_data[const.BLADE_INTF_RHEL_DEVICE_NAME]
|
||||
profile_name = port_binding[const.PORTPROFILENAME]
|
||||
dynamicnic_details = \
|
||||
{const.DEVICENAME: device_name,
|
||||
const.UCSPROFILE: profile_name}
|
||||
LOG.debug("Found reserved dynamic nic: %s" \
|
||||
"associated with port %s" %
|
||||
dynamicnic_details = {
|
||||
const.DEVICENAME: device_name,
|
||||
const.UCSPROFILE: profile_name,
|
||||
}
|
||||
LOG.debug(("Found reserved dynamic nic: %s"
|
||||
"associated with port %s") %
|
||||
(intf_data, port_id))
|
||||
LOG.debug("Returning dynamic nic details: %s" %
|
||||
dynamicnic_details)
|
||||
@ -363,13 +360,13 @@ class UCSInventory(L2NetworkDeviceInventoryBase):
|
||||
blade_intf_data = blade_data[const.BLADE_INTF_DATA]
|
||||
for blade_intf in blade_intf_data.keys():
|
||||
intf_data = blade_intf_data[blade_intf]
|
||||
if intf_data[const.BLADE_INTF_RESERVATION] == \
|
||||
const.BLADE_INTF_RESERVED and \
|
||||
intf_data[const.TENANTID] == tenant_id and \
|
||||
blade_intf_data[blade_intf][const.INSTANCE_ID] == \
|
||||
instance_id and \
|
||||
intf_data[const.VIF_ID][:const.UUID_LENGTH] == \
|
||||
vif_id:
|
||||
if (intf_data[const.BLADE_INTF_RESERVATION] ==
|
||||
const.BLADE_INTF_RESERVED and
|
||||
intf_data[const.TENANTID] == tenant_id and
|
||||
blade_intf_data[blade_intf][const.INSTANCE_ID]
|
||||
== instance_id and
|
||||
intf_data[const.VIF_ID][:const.UUID_LENGTH] ==
|
||||
vif_id):
|
||||
intf_data[const.VIF_ID] = None
|
||||
intf_data[const.INSTANCE_ID] = None
|
||||
port_binding = udb.get_portbinding_dn(blade_intf)
|
||||
@ -377,15 +374,16 @@ class UCSInventory(L2NetworkDeviceInventoryBase):
|
||||
udb.update_portbinding(port_id, instance_id=None,
|
||||
vif_id=None)
|
||||
db.port_unset_attachment_by_id(port_id)
|
||||
LOG.debug("Disassociated VIF-ID: %s " \
|
||||
"from port: %s" \
|
||||
"in UCS inventory state for blade: %s" %
|
||||
LOG.debug(
|
||||
("Disassociated VIF-ID: %s "
|
||||
"from port: %s"
|
||||
"in UCS inventory state for blade: %s") %
|
||||
(vif_id, port_id, intf_data))
|
||||
device_params = {const.DEVICE_IP: [ucsm_ip],
|
||||
const.PORTID: port_id}
|
||||
return device_params
|
||||
LOG.warn("Disassociating VIF-ID in UCS inventory failed. " \
|
||||
"Could not find a reserved dynamic nic for tenant: %s" %
|
||||
LOG.warn(("Disassociating VIF-ID in UCS inventory failed. "
|
||||
"Could not find a reserved dynamic nic for tenant: %s") %
|
||||
tenant_id)
|
||||
return None
|
||||
|
||||
@ -401,14 +399,14 @@ class UCSInventory(L2NetworkDeviceInventoryBase):
|
||||
blade_data = ucsm[chassis_id][blade_id]
|
||||
blade_intf_data = blade_data[const.BLADE_INTF_DATA]
|
||||
for blade_intf in blade_intf_data.keys():
|
||||
if not blade_intf_data[blade_intf][const.PORTID] or \
|
||||
not blade_intf_data[blade_intf][const.TENANTID]:
|
||||
if (not blade_intf_data[blade_intf][const.PORTID] or
|
||||
not blade_intf_data[blade_intf][const.TENANTID]):
|
||||
continue
|
||||
intf_data = blade_intf_data[blade_intf]
|
||||
if intf_data[const.BLADE_INTF_RESERVATION] == \
|
||||
const.BLADE_INTF_RESERVED and \
|
||||
intf_data[const.TENANTID] == tenant_id and \
|
||||
intf_data[const.PORTID] == port_id:
|
||||
if (intf_data[const.BLADE_INTF_RESERVATION] ==
|
||||
const.BLADE_INTF_RESERVED and
|
||||
intf_data[const.TENANTID] == tenant_id and
|
||||
intf_data[const.PORTID] == port_id):
|
||||
interface_dn = intf_data[const.BLADE_INTF_DN]
|
||||
blade_intf_info = {const.UCSM_IP: ucsm_ip,
|
||||
const.CHASSIS_ID: chassis_id,
|
||||
@ -433,26 +431,27 @@ class UCSInventory(L2NetworkDeviceInventoryBase):
|
||||
for chassis_id in ucsm.keys():
|
||||
for blade_id in ucsm[chassis_id]:
|
||||
blade_data = ucsm[chassis_id][blade_id]
|
||||
if blade_data[const.BLADE_UNRESERVED_INTF_COUNT] > \
|
||||
unreserved_interface_count:
|
||||
unreserved_interface_count = \
|
||||
blade_data[const.BLADE_UNRESERVED_INTF_COUNT]
|
||||
if (blade_data[const.BLADE_UNRESERVED_INTF_COUNT] >
|
||||
unreserved_interface_count):
|
||||
unreserved_interface_count = (
|
||||
blade_data[const.BLADE_UNRESERVED_INTF_COUNT])
|
||||
least_reserved_blade_ucsm = ucsm_ip
|
||||
least_reserved_blade_chassis = chassis_id
|
||||
least_reserved_blade_id = blade_id
|
||||
least_reserved_blade_data = blade_data
|
||||
|
||||
if unreserved_interface_count < intf_count:
|
||||
LOG.warn("Not enough dynamic nics available on a single host." \
|
||||
" Requested: %s, Maximum available: %s" %
|
||||
LOG.warn(("Not enough dynamic nics available on a single host."
|
||||
" Requested: %s, Maximum available: %s") %
|
||||
(intf_count, unreserved_interface_count))
|
||||
return False
|
||||
|
||||
least_reserved_blade_dict = \
|
||||
{const.LEAST_RSVD_BLADE_UCSM: least_reserved_blade_ucsm,
|
||||
least_reserved_blade_dict = {
|
||||
const.LEAST_RSVD_BLADE_UCSM: least_reserved_blade_ucsm,
|
||||
const.LEAST_RSVD_BLADE_CHASSIS: least_reserved_blade_chassis,
|
||||
const.LEAST_RSVD_BLADE_ID: least_reserved_blade_id,
|
||||
const.LEAST_RSVD_BLADE_DATA: least_reserved_blade_data}
|
||||
const.LEAST_RSVD_BLADE_DATA: least_reserved_blade_data,
|
||||
}
|
||||
LOG.debug("Found dynamic nic %s available for reservation",
|
||||
least_reserved_blade_dict)
|
||||
return least_reserved_blade_dict
|
||||
@ -474,8 +473,6 @@ class UCSInventory(L2NetworkDeviceInventoryBase):
|
||||
blade_data = self._get_blade_state(chassis_id, blade_id, ucsm_ip,
|
||||
ucsm_username, ucsm_password)
|
||||
blade_intf_data = blade_data[const.BLADE_INTF_DATA]
|
||||
#import sys
|
||||
#sys.exit(ucsm_ip)
|
||||
chassis_data = self._inventory_state[ucsm_ip][chassis_id]
|
||||
old_blade_intf_data = chassis_data[blade_id][const.BLADE_INTF_DATA]
|
||||
|
||||
@ -485,34 +482,32 @@ class UCSInventory(L2NetworkDeviceInventoryBase):
|
||||
"""
|
||||
for blade_intf in blade_intf_data.keys():
|
||||
old_intf_data = old_blade_intf_data[blade_intf]
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_RESERVATION] = \
|
||||
old_intf_data[const.BLADE_INTF_RESERVATION]
|
||||
blade_intf_data[blade_intf][const.TENANTID] = \
|
||||
old_intf_data[const.TENANTID]
|
||||
blade_intf_data[blade_intf][const.PORTID] = \
|
||||
old_intf_data[const.PORTID]
|
||||
blade_intf_data[blade_intf][const.PROFILE_ID] = \
|
||||
old_intf_data[const.PROFILE_ID]
|
||||
blade_intf_data[blade_intf][const.INSTANCE_ID] = \
|
||||
old_intf_data[const.INSTANCE_ID]
|
||||
blade_intf_data[blade_intf][const.VIF_ID] = \
|
||||
old_intf_data[const.VIF_ID]
|
||||
blade_intf_data[blade_intf][const.BLADE_INTF_RESERVATION] = (
|
||||
old_intf_data[const.BLADE_INTF_RESERVATION])
|
||||
blade_intf_data[blade_intf][const.TENANTID] = (
|
||||
old_intf_data[const.TENANTID])
|
||||
blade_intf_data[blade_intf][const.PORTID] = (
|
||||
old_intf_data[const.PORTID])
|
||||
blade_intf_data[blade_intf][const.PROFILE_ID] = (
|
||||
old_intf_data[const.PROFILE_ID])
|
||||
blade_intf_data[blade_intf][const.INSTANCE_ID] = (
|
||||
old_intf_data[const.INSTANCE_ID])
|
||||
blade_intf_data[blade_intf][const.VIF_ID] = (
|
||||
old_intf_data[const.VIF_ID])
|
||||
|
||||
blade_data[const.BLADE_UNRESERVED_INTF_COUNT] = \
|
||||
chassis_data[blade_id][const.BLADE_UNRESERVED_INTF_COUNT]
|
||||
blade_data[const.BLADE_UNRESERVED_INTF_COUNT] = (
|
||||
chassis_data[blade_id][const.BLADE_UNRESERVED_INTF_COUNT])
|
||||
"""
|
||||
Now we will reserve an interface if its available
|
||||
"""
|
||||
for blade_intf in blade_intf_data.keys():
|
||||
intf_data = blade_intf_data[blade_intf]
|
||||
if intf_data[const.BLADE_INTF_RESERVATION] == \
|
||||
const.BLADE_INTF_UNRESERVED:
|
||||
intf_data[const.BLADE_INTF_RESERVATION] = \
|
||||
const.BLADE_INTF_RESERVED
|
||||
if (intf_data[const.BLADE_INTF_RESERVATION] ==
|
||||
const.BLADE_INTF_UNRESERVED):
|
||||
intf_data[const.BLADE_INTF_RESERVATION] = (
|
||||
const.BLADE_INTF_RESERVED)
|
||||
intf_data[const.TENANTID] = tenant_id
|
||||
intf_data[const.PORTID] = port_id
|
||||
#intf_data[const.PROFILE_ID] = \
|
||||
# portprofile_name
|
||||
intf_data[const.INSTANCE_ID] = None
|
||||
dev_eth_name = intf_data[const.BLADE_INTF_RHEL_DEVICE_NAME]
|
||||
"""
|
||||
@ -520,11 +515,12 @@ class UCSInventory(L2NetworkDeviceInventoryBase):
|
||||
"""
|
||||
chassis_data[blade_id][const.BLADE_INTF_DATA] = blade_intf_data
|
||||
chassis_data[blade_id][const.BLADE_UNRESERVED_INTF_COUNT] -= 1
|
||||
host_name = self._get_host_name(ucsm_ip, chassis_id,
|
||||
blade_id)
|
||||
reserved_nic_dict = {const.RESERVED_NIC_HOSTNAME: host_name,
|
||||
host_name = self._get_host_name(ucsm_ip, chassis_id, blade_id)
|
||||
reserved_nic_dict = {
|
||||
const.RESERVED_NIC_HOSTNAME: host_name,
|
||||
const.RESERVED_NIC_NAME: dev_eth_name,
|
||||
const.BLADE_INTF_DN: blade_intf}
|
||||
const.BLADE_INTF_DN: blade_intf,
|
||||
}
|
||||
port_binding = udb.add_portbinding(port_id, blade_intf, None,
|
||||
None, None, None)
|
||||
udb.update_portbinding(port_id,
|
||||
@ -598,10 +594,11 @@ class UCSInventory(L2NetworkDeviceInventoryBase):
|
||||
if not least_reserved_blade_dict:
|
||||
raise cexc.NoMoreNics()
|
||||
ucsm_ip = least_reserved_blade_dict[const.LEAST_RSVD_BLADE_UCSM]
|
||||
device_params = {const.DEVICE_IP: [ucsm_ip],
|
||||
device_params = {
|
||||
const.DEVICE_IP: [ucsm_ip],
|
||||
const.UCS_INVENTORY: self,
|
||||
const.LEAST_RSVD_BLADE_DICT:\
|
||||
least_reserved_blade_dict}
|
||||
const.LEAST_RSVD_BLADE_DICT: least_reserved_blade_dict,
|
||||
}
|
||||
return device_params
|
||||
|
||||
def delete_port(self, args):
|
||||
@ -618,12 +615,13 @@ class UCSInventory(L2NetworkDeviceInventoryBase):
|
||||
LOG.warn("UCSInventory: Port not found: net_id: %s, port_id: %s" %
|
||||
(net_id, port_id))
|
||||
return {const.DEVICE_IP: []}
|
||||
device_params = \
|
||||
{const.DEVICE_IP: [rsvd_info[const.UCSM_IP]],
|
||||
device_params = {
|
||||
const.DEVICE_IP: [rsvd_info[const.UCSM_IP]],
|
||||
const.UCS_INVENTORY: self,
|
||||
const.CHASSIS_ID: rsvd_info[const.CHASSIS_ID],
|
||||
const.BLADE_ID: rsvd_info[const.BLADE_ID],
|
||||
const.BLADE_INTF_DN: rsvd_info[const.BLADE_INTF_DN]}
|
||||
const.BLADE_INTF_DN: rsvd_info[const.BLADE_INTF_DN],
|
||||
}
|
||||
return device_params
|
||||
|
||||
def update_port(self, args):
|
||||
@ -707,8 +705,10 @@ class UCSInventory(L2NetworkDeviceInventoryBase):
|
||||
if not least_reserved_blade_dict:
|
||||
raise cexc.NoMoreNics()
|
||||
ucsm_ip = least_reserved_blade_dict[const.LEAST_RSVD_BLADE_UCSM]
|
||||
device_params = {const.DEVICE_IP: [ucsm_ip],
|
||||
device_params = {
|
||||
const.DEVICE_IP: [ucsm_ip],
|
||||
const.UCS_INVENTORY: self,
|
||||
const.LEAST_RSVD_BLADE_DICT:\
|
||||
least_reserved_blade_dict}
|
||||
const.LEAST_RSVD_BLADE_DICT:
|
||||
least_reserved_blade_dict,
|
||||
}
|
||||
return device_params
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -17,12 +16,13 @@
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import os
|
||||
|
||||
from quantum.common.config import find_config_file
|
||||
from quantum.plugins.cisco.common import cisco_configparser as confp
|
||||
|
||||
|
||||
CONF_FILE = find_config_file({'plugin': 'cisco'}, None, "ucs_inventory.ini")
|
||||
CP = confp.CiscoConfigParser(CONF_FILE)
|
||||
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -17,7 +16,6 @@
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
"""
|
||||
Implements a UCSM XML API Client
|
||||
@ -27,12 +25,14 @@ import httplib
|
||||
import logging
|
||||
from xml.etree import ElementTree as et
|
||||
|
||||
from quantum.plugins.cisco.common import cisco_exceptions as cexc
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.common import cisco_exceptions as cexc
|
||||
from quantum.plugins.cisco.ucs import cisco_getvif as gvif
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
COOKIE_VALUE = "cookie_placeholder"
|
||||
PROFILE_NAME = "profilename_placeholder"
|
||||
PROFILE_CLIENT = "profileclient_placeholder"
|
||||
@ -144,35 +144,25 @@ class CiscoUCSMDriver():
|
||||
def _post_data(self, ucsm_ip, ucsm_username, ucsm_password, data):
|
||||
"""Send command to UCSM in http request"""
|
||||
conn = httplib.HTTPSConnection(ucsm_ip)
|
||||
login_data = "<aaaLogin inName=\"" + ucsm_username + \
|
||||
"\" inPassword=\"" + ucsm_password + "\" />"
|
||||
login_data = ("<aaaLogin inName=\"" + ucsm_username +
|
||||
"\" inPassword=\"" + ucsm_password + "\" />")
|
||||
conn.request(METHOD, URL, login_data, HEADERS)
|
||||
response = conn.getresponse()
|
||||
response_data = response.read()
|
||||
#LOG.debug(response.status)
|
||||
#LOG.debug(response.reason)
|
||||
#LOG.debug(response_data)
|
||||
# TODO (Sumit): If login is not successful, throw exception
|
||||
xml_tree = et.XML(response_data)
|
||||
cookie = xml_tree.attrib["outCookie"]
|
||||
|
||||
data = data.replace(COOKIE_VALUE, cookie)
|
||||
#LOG.debug("POST: %s" % data)
|
||||
conn.request(METHOD, URL, data, HEADERS)
|
||||
response = conn.getresponse()
|
||||
response_data = response.read()
|
||||
#LOG.debug(response.status)
|
||||
#LOG.debug(response.reason)
|
||||
#LOG.debug("UCSM Response: %s" % response_data)
|
||||
post_data_response = response_data
|
||||
|
||||
logout_data = "<aaaLogout inCookie=\"" + cookie + "\" />"
|
||||
conn.request(METHOD, URL, logout_data, HEADERS)
|
||||
response = conn.getresponse()
|
||||
response_data = response.read()
|
||||
#LOG.debug(response.status)
|
||||
#LOG.debug(response.reason)
|
||||
#LOG.debug(response_data)
|
||||
return post_data_response
|
||||
|
||||
def _create_vlan_post_data(self, vlan_name, vlan_id):
|
||||
@ -187,8 +177,7 @@ class CiscoUCSMDriver():
|
||||
data = data.replace(VLAN_NAME, vlan_name)
|
||||
return data
|
||||
|
||||
def _create_pclient_post_data(self, profile_name,
|
||||
profile_client_name):
|
||||
def _create_pclient_post_data(self, profile_name, profile_client_name):
|
||||
"""Create command"""
|
||||
data = ASSOCIATE_PROFILE.replace(PROFILE_NAME, profile_name)
|
||||
data = data.replace(PROFILE_CLIENT, profile_client_name)
|
||||
@ -229,20 +218,23 @@ class CiscoUCSMDriver():
|
||||
data = self._get_blade_interfaces_post_data(chassis_number,
|
||||
blade_number)
|
||||
response = self._post_data(ucsm_ip, ucsm_username, ucsm_password, data)
|
||||
elements = \
|
||||
elements = (
|
||||
et.XML(response).find("outConfigs").findall("adaptorHostEthIf")
|
||||
)
|
||||
blade_interfaces = {}
|
||||
for element in elements:
|
||||
dist_name = element.get("dn", default=None)
|
||||
if dist_name:
|
||||
order = element.get("order", default=None)
|
||||
blade_interface = {const.BLADE_INTF_DN: dist_name,
|
||||
blade_interface = {
|
||||
const.BLADE_INTF_DN: dist_name,
|
||||
const.BLADE_INTF_ORDER: order,
|
||||
const.BLADE_INTF_LINK_STATE: None,
|
||||
const.BLADE_INTF_OPER_STATE: None,
|
||||
const.BLADE_INTF_INST_TYPE: None,
|
||||
const.BLADE_INTF_RHEL_DEVICE_NAME:
|
||||
self._get_rhel_device_name(order)}
|
||||
self._get_rhel_device_name(order),
|
||||
}
|
||||
blade_interfaces[dist_name] = blade_interface
|
||||
|
||||
return blade_interfaces
|
||||
@ -250,11 +242,11 @@ class CiscoUCSMDriver():
|
||||
def _get_blade_interface_state(self, blade_intf, ucsm_ip,
|
||||
ucsm_username, ucsm_password):
|
||||
"""Create command"""
|
||||
data = \
|
||||
data = (
|
||||
self._get_blade_intf_st_post_data(blade_intf[const.BLADE_INTF_DN])
|
||||
)
|
||||
response = self._post_data(ucsm_ip, ucsm_username, ucsm_password, data)
|
||||
elements = \
|
||||
et.XML(response).find("outConfigs").findall("dcxVIf")
|
||||
elements = et.XML(response).find("outConfigs").findall("dcxVIf")
|
||||
for element in elements:
|
||||
blade_intf[const.BLADE_INTF_LINK_STATE] = element.get("linkState",
|
||||
default=None)
|
||||
@ -279,8 +271,7 @@ class CiscoUCSMDriver():
|
||||
"""Create request for UCSM"""
|
||||
data = self._create_profile_post_data(profile_name, vlan_name)
|
||||
self._post_data(ucsm_ip, ucsm_username, ucsm_password, data)
|
||||
data = self._create_pclient_post_data(profile_name,
|
||||
profile_name[-16:])
|
||||
data = self._create_pclient_post_data(profile_name, profile_name[-16:])
|
||||
self._post_data(ucsm_ip, ucsm_username, ucsm_password, data)
|
||||
|
||||
def change_vlan_in_profile(self, profile_name, old_vlan_name,
|
||||
@ -292,9 +283,8 @@ class CiscoUCSMDriver():
|
||||
new_vlan_name)
|
||||
self._post_data(ucsm_ip, ucsm_username, ucsm_password, data)
|
||||
|
||||
def get_blade_data(self, chassis_number, blade_number,
|
||||
ucsm_ip, ucsm_username,
|
||||
ucsm_password):
|
||||
def get_blade_data(self, chassis_number, blade_number, ucsm_ip,
|
||||
ucsm_username, ucsm_password):
|
||||
"""
|
||||
Returns only the dynamic interfaces on the blade
|
||||
"""
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2011 Cisco Systems, Inc. All rights reserved.
|
||||
@ -17,15 +16,14 @@
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import logging
|
||||
|
||||
from quantum.common import exceptions as exc
|
||||
from quantum.common import utils
|
||||
from quantum.plugins.cisco.common import cisco_exceptions as cexc
|
||||
from quantum.plugins.cisco.common import cisco_constants as const
|
||||
from quantum.plugins.cisco.common import cisco_credentials as cred
|
||||
from quantum.plugins.cisco.common import cisco_exceptions as cexc
|
||||
from quantum.plugins.cisco.common import cisco_utils as cutil
|
||||
from quantum.plugins.cisco.db import api as db
|
||||
from quantum.plugins.cisco.db import l2network_db as cdb
|
||||
@ -33,6 +31,7 @@ from quantum.plugins.cisco.db import ucs_db as udb
|
||||
from quantum.plugins.cisco.l2device_plugin_base import L2DevicePluginBase
|
||||
from quantum.plugins.cisco.ucs import cisco_ucs_configuration as conf
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
@ -166,8 +165,8 @@ class UCSVICPlugin(L2DevicePluginBase):
|
||||
conf.DEFAULT_VLAN_NAME,
|
||||
conf.DEFAULT_VLAN_ID)
|
||||
profile_name = new_port_profile[const.PROFILE_NAME]
|
||||
rsvd_nic_dict = ucs_inventory.\
|
||||
reserve_blade_interface(self._ucsm_ip, chassis_id,
|
||||
rsvd_nic_dict = ucs_inventory.reserve_blade_interface(
|
||||
self._ucsm_ip, chassis_id,
|
||||
blade_id, blade_data_dict,
|
||||
tenant_id, port_id,
|
||||
profile_name)
|
||||
@ -269,17 +268,18 @@ class UCSVICPlugin(L2DevicePluginBase):
|
||||
blade_data_dict = least_rsvd_blade_dict[const.LEAST_RSVD_BLADE_DATA]
|
||||
port_binding_list = []
|
||||
for port_id, net_id in zip(port_id_list, net_id_list):
|
||||
new_port_profile = \
|
||||
self._create_port_profile(tenant_id, net_id, port_id,
|
||||
new_port_profile = self._create_port_profile(
|
||||
tenant_id, net_id, port_id,
|
||||
conf.DEFAULT_VLAN_NAME,
|
||||
conf.DEFAULT_VLAN_ID)
|
||||
profile_name = new_port_profile[const.PROFILE_NAME]
|
||||
rsvd_nic_dict = ucs_inventory.\
|
||||
reserve_blade_interface(self._ucsm_ip, chassis_id,
|
||||
rsvd_nic_dict = ucs_inventory.reserve_blade_interface(
|
||||
self._ucsm_ip, chassis_id,
|
||||
blade_id, blade_data_dict,
|
||||
tenant_id, port_id,
|
||||
profile_name)
|
||||
port_binding = udb.update_portbinding(port_id,
|
||||
port_binding = udb.update_portbinding(
|
||||
port_id,
|
||||
portprofile_name=profile_name,
|
||||
vlan_name=conf.DEFAULT_VLAN_NAME,
|
||||
vlan_id=conf.DEFAULT_VLAN_ID,
|
||||
@ -298,8 +298,7 @@ class UCSVICPlugin(L2DevicePluginBase):
|
||||
|
||||
def _get_profile_name(self, port_id):
|
||||
"""Returns the port profile name based on the port UUID"""
|
||||
profile_name = conf.PROFILE_NAME_PREFIX \
|
||||
+ cutil.get16ByteUUID(port_id)
|
||||
profile_name = conf.PROFILE_NAME_PREFIX + cutil.get16ByteUUID(port_id)
|
||||
return profile_name
|
||||
|
||||
def _get_vlan_name_for_network(self, tenant_id, network_id):
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2012, Cisco Systems, Inc.
|
||||
@ -15,17 +14,16 @@
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
"""
|
||||
|
||||
import logging
|
||||
|
||||
from quantum.api.api_common import OperationalStatus
|
||||
from quantum.common import exceptions as exc
|
||||
from quantum.db import api as db
|
||||
from quantum.plugins.linuxbridge import plugin_configuration as conf
|
||||
from quantum.plugins.linuxbridge.common import constants as const
|
||||
from quantum.plugins.linuxbridge.common import utils as cutil
|
||||
from quantum.plugins.linuxbridge.db import l2network_db as cdb
|
||||
from quantum.plugins.linuxbridge import plugin_configuration as conf
|
||||
from quantum.quantum_plugin_base import QuantumPluginBase
|
||||
|
||||
|
||||
@ -111,10 +109,12 @@ class LinuxBridgePlugin(QuantumPluginBase):
|
||||
new_net_id = new_network[const.UUID]
|
||||
vlan_id = self._get_vlan_for_tenant(tenant_id)
|
||||
cdb.add_vlan_binding(vlan_id, new_net_id)
|
||||
new_net_dict = {const.NET_ID: new_net_id,
|
||||
new_net_dict = {
|
||||
const.NET_ID: new_net_id,
|
||||
const.NET_NAME: net_name,
|
||||
const.NET_PORTS: [],
|
||||
const.NET_OP_STATUS: new_network[const.OPSTATUS]}
|
||||
const.NET_OP_STATUS: new_network[const.OPSTATUS],
|
||||
}
|
||||
return new_net_dict
|
||||
|
||||
def delete_network(self, tenant_id, net_id):
|
||||
|
@ -21,21 +21,23 @@
|
||||
# Based on the structure of the OpenVSwitch agent in the
|
||||
# Quantum OpenVSwitch Plugin.
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
|
||||
from optparse import OptionParser
|
||||
from subprocess import *
|
||||
|
||||
import ConfigParser
|
||||
import logging as LOG
|
||||
import MySQLdb
|
||||
import logging
|
||||
from optparse import OptionParser
|
||||
import os
|
||||
import shlex
|
||||
import signal
|
||||
import sqlite3
|
||||
import subprocess
|
||||
import sys
|
||||
import time
|
||||
|
||||
import MySQLdb
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
BRIDGE_NAME_PREFIX = "brq"
|
||||
GATEWAY_INTERFACE_PREFIX = "gw-"
|
||||
@ -62,7 +64,7 @@ class LinuxBridge:
|
||||
def run_cmd(self, args):
|
||||
cmd = shlex.split(self.root_helper) + args
|
||||
LOG.debug("Running command: " + " ".join(cmd))
|
||||
p = Popen(cmd, stdout=PIPE)
|
||||
p = subprocess.Popen(cmd, stdout=subprocess.PIPE)
|
||||
retval = p.communicate()[0]
|
||||
if p.returncode == -(signal.SIGALRM):
|
||||
LOG.debug("Timeout running command: " + " ".join(cmd))
|
||||
@ -109,9 +111,8 @@ class LinuxBridge:
|
||||
|
||||
def get_interfaces_on_bridge(self, bridge_name):
|
||||
if self.device_exists(bridge_name):
|
||||
bridge_interface_path = \
|
||||
BRIDGE_INTERFACES_FS.replace(BRIDGE_NAME_PLACEHOLDER,
|
||||
bridge_name)
|
||||
bridge_interface_path = BRIDGE_INTERFACES_FS.replace(
|
||||
BRIDGE_NAME_PLACEHOLDER, bridge_name)
|
||||
return os.listdir(bridge_interface_path)
|
||||
|
||||
def get_all_tap_devices(self):
|
||||
@ -149,9 +150,8 @@ class LinuxBridge:
|
||||
if not device_name:
|
||||
return False
|
||||
else:
|
||||
bridge_port_path = \
|
||||
BRIDGE_PORT_FS_FOR_DEVICE.replace(DEVICE_NAME_PLACEHOLDER,
|
||||
device_name)
|
||||
bridge_port_path = BRIDGE_PORT_FS_FOR_DEVICE.replace(
|
||||
DEVICE_NAME_PLACEHOLDER, device_name)
|
||||
return os.path.exists(bridge_port_path)
|
||||
|
||||
def ensure_vlan_bridge(self, network_id, vlan_id):
|
||||
@ -210,8 +210,7 @@ class LinuxBridge:
|
||||
tap_device_name)
|
||||
return False
|
||||
|
||||
current_bridge_name = \
|
||||
self.get_bridge_for_tap_device(tap_device_name)
|
||||
current_bridge_name = self.get_bridge_for_tap_device(tap_device_name)
|
||||
bridge_name = self.get_bridge_name(network_id)
|
||||
if bridge_name == current_bridge_name:
|
||||
return False
|
||||
@ -237,12 +236,10 @@ class LinuxBridge:
|
||||
"""
|
||||
return False
|
||||
if interface_id.startswith(GATEWAY_INTERFACE_PREFIX):
|
||||
return self.add_tap_interface(network_id, vlan_id,
|
||||
interface_id)
|
||||
return self.add_tap_interface(network_id, vlan_id, interface_id)
|
||||
else:
|
||||
tap_device_name = self.get_tap_device_name(interface_id)
|
||||
return self.add_tap_interface(network_id, vlan_id,
|
||||
tap_device_name)
|
||||
return self.add_tap_interface(network_id, vlan_id, tap_device_name)
|
||||
|
||||
def delete_vlan_bridge(self, bridge_name):
|
||||
if self.device_exists(bridge_name):
|
||||
@ -266,15 +263,15 @@ class LinuxBridge:
|
||||
if self.device_exists(bridge_name):
|
||||
if not self.is_device_on_bridge(interface_name):
|
||||
return True
|
||||
LOG.debug("Removing device %s from bridge %s" % \
|
||||
LOG.debug("Removing device %s from bridge %s" %
|
||||
(interface_name, bridge_name))
|
||||
if self.run_cmd(['brctl', 'delif', bridge_name, interface_name]):
|
||||
return False
|
||||
LOG.debug("Done removing device %s from bridge %s" % \
|
||||
LOG.debug("Done removing device %s from bridge %s" %
|
||||
(interface_name, bridge_name))
|
||||
return True
|
||||
else:
|
||||
LOG.debug("Cannot remove device %s, bridge %s does not exist" % \
|
||||
LOG.debug("Cannot remove device %s, bridge %s does not exist" %
|
||||
(interface_name, bridge_name))
|
||||
return False
|
||||
|
||||
@ -327,16 +324,16 @@ class LinuxBridgeQuantumAgent:
|
||||
LOG.debug("plugged tap device names %s" % plugged_tap_device_names)
|
||||
for tap_device in self.linux_br.get_all_tap_devices():
|
||||
if tap_device not in plugged_tap_device_names:
|
||||
current_bridge_name = \
|
||||
self.linux_br.get_bridge_for_tap_device(tap_device)
|
||||
current_bridge_name = (
|
||||
self.linux_br.get_bridge_for_tap_device(tap_device))
|
||||
if current_bridge_name:
|
||||
self.linux_br.remove_interface(current_bridge_name,
|
||||
tap_device)
|
||||
|
||||
for gw_device in self.linux_br.get_all_gateway_devices():
|
||||
if gw_device not in plugged_gateway_device_names:
|
||||
current_bridge_name = \
|
||||
self.linux_br.get_bridge_for_tap_device(gw_device)
|
||||
current_bridge_name = (
|
||||
self.linux_br.get_bridge_for_tap_device(gw_device))
|
||||
if current_bridge_name:
|
||||
self.linux_br.remove_interface(current_bridge_name,
|
||||
gw_device)
|
||||
@ -378,15 +375,13 @@ class LinuxBridgeQuantumAgent:
|
||||
for pb in port_bindings:
|
||||
ports_string = "%s %s" % (ports_string, pb)
|
||||
if pb['interface_id']:
|
||||
vlan_id = \
|
||||
str(vlan_bindings[pb['network_id']]['vlan_id'])
|
||||
vlan_id = str(vlan_bindings[pb['network_id']]['vlan_id'])
|
||||
if self.process_port_binding(pb['uuid'],
|
||||
pb['network_id'],
|
||||
pb['interface_id'],
|
||||
vlan_id):
|
||||
cursor = MySQLdb.cursors.DictCursor(conn)
|
||||
sql = PORT_OPSTATUS_UPDATESQL % (pb['uuid'],
|
||||
OP_STATUS_UP)
|
||||
sql = PORT_OPSTATUS_UPDATESQL % (pb['uuid'], OP_STATUS_UP)
|
||||
cursor.execute(sql)
|
||||
cursor.close()
|
||||
plugged_interfaces.append(pb['interface_id'])
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2012 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,5 +15,3 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2012 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,8 +15,6 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
from configobj import ConfigObj
|
||||
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2012 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,8 +15,7 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
|
||||
PORT_STATE = 'port-state'
|
||||
PORT_UP = "ACTIVE"
|
||||
|
@ -20,24 +20,25 @@
|
||||
"""
|
||||
Exceptions used by the LinuxBridge plugin
|
||||
"""
|
||||
|
||||
from quantum.common import exceptions
|
||||
|
||||
|
||||
class NetworksLimit(exceptions.QuantumException):
|
||||
"""Total number of network objects limit has been hit"""
|
||||
message = _("Unable to create new network. Number of networks" \
|
||||
message = _("Unable to create new network. Number of networks"
|
||||
"for the system has exceeded the limit")
|
||||
|
||||
|
||||
class NetworkVlanBindingAlreadyExists(exceptions.QuantumException):
|
||||
"""Binding cannot be created, since it already exists"""
|
||||
message = _("NetworkVlanBinding for %(vlan_id)s and network " \
|
||||
message = _("NetworkVlanBinding for %(vlan_id)s and network "
|
||||
"%(network_id)s already exists")
|
||||
|
||||
|
||||
class NetworkVlanBindingNotFound(exceptions.QuantumException):
|
||||
"""Binding could not be found"""
|
||||
message = _("NetworkVlanBinding for network " \
|
||||
message = _("NetworkVlanBinding for network "
|
||||
"%(network_id)s does not exist")
|
||||
|
||||
|
||||
@ -53,20 +54,5 @@ class VlanIDNotAvailable(exceptions.QuantumException):
|
||||
|
||||
class UnableToChangeVlanRange(exceptions.QuantumException):
|
||||
"""No VLAN ID available"""
|
||||
message = _("Current VLAN ID range %(range_start)s to %(range_end)s " \
|
||||
message = _("Current VLAN ID range %(range_start)s to %(range_end)s "
|
||||
"cannot be changed. Please check plugin conf file.")
|
||||
|
||||
|
||||
try:
|
||||
_("test")
|
||||
except NameError:
|
||||
|
||||
def _(a_string):
|
||||
"""
|
||||
Default implementation of the gettext string
|
||||
translation function: no translation
|
||||
"""
|
||||
return a_string
|
||||
except TypeError:
|
||||
# during doctesting, _ might mean something else
|
||||
pass
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2012 Cisco Systems, Inc. All rights reserved.
|
||||
@ -16,21 +15,23 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
#
|
||||
"""
|
||||
|
||||
import logging
|
||||
|
||||
from quantum.api.api_common import OperationalStatus
|
||||
from quantum.plugins.linuxbridge.common import constants as const
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
def make_net_dict(net_id, net_name, ports, op_status):
|
||||
"""Helper funciton"""
|
||||
res = {const.NET_ID: net_id, const.NET_NAME: net_name, const.NET_OP_STATUS:
|
||||
op_status}
|
||||
res = {
|
||||
const.NET_ID: net_id,
|
||||
const.NET_NAME: net_name,
|
||||
const.NET_OP_STATUS: op_status,
|
||||
}
|
||||
if ports:
|
||||
res[const.NET_PORTS] = ports
|
||||
return res
|
||||
@ -43,8 +44,10 @@ def make_port_dict(port):
|
||||
else:
|
||||
op_status = OperationalStatus.DOWN
|
||||
|
||||
return {const.PORT_ID: str(port[const.UUID]),
|
||||
return {
|
||||
const.PORT_ID: str(port[const.UUID]),
|
||||
const.PORT_STATE: port[const.PORTSTATE],
|
||||
const.PORT_OP_STATUS: op_status,
|
||||
const.NET_ID: port[const.NETWORKID],
|
||||
const.ATTACHMENT: port[const.INTERFACEID]}
|
||||
const.ATTACHMENT: port[const.INTERFACEID],
|
||||
}
|
||||
|
@ -15,17 +15,16 @@
|
||||
# under the License.
|
||||
# @author: Rohit Agarwalla, Cisco Systems, Inc.
|
||||
|
||||
import logging
|
||||
|
||||
from sqlalchemy import func
|
||||
from sqlalchemy.orm import exc
|
||||
|
||||
from quantum.common import exceptions as q_exc
|
||||
from quantum.plugins.linuxbridge import plugin_configuration as conf
|
||||
import quantum.db.api as db
|
||||
from quantum.plugins.linuxbridge.common import exceptions as c_exc
|
||||
from quantum.plugins.linuxbridge.db import l2network_models
|
||||
|
||||
import logging
|
||||
|
||||
import quantum.db.api as db
|
||||
from quantum.plugins.linuxbridge import plugin_configuration as conf
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
@ -63,12 +62,12 @@ def create_vlanids():
|
||||
has to be supported.
|
||||
Per Dan's suggestion we just throw a server exception for now.
|
||||
"""
|
||||
current_start = \
|
||||
current_start = (
|
||||
int(session.query(func.min(l2network_models.VlanID.vlan_id)).
|
||||
one()[0])
|
||||
current_end = \
|
||||
one()[0]))
|
||||
current_end = (
|
||||
int(session.query(func.max(l2network_models.VlanID.vlan_id)).
|
||||
one()[0])
|
||||
one()[0]))
|
||||
if current_start != start or current_end != end:
|
||||
LOG.debug("Old VLAN range %s-%s" % (current_start, current_end))
|
||||
LOG.debug("New VLAN range %s-%s" % (start, end))
|
||||
@ -89,8 +88,8 @@ def get_all_vlanids():
|
||||
LOG.debug("get_all_vlanids() called")
|
||||
session = db.get_session()
|
||||
try:
|
||||
vlanids = session.query(l2network_models.VlanID).\
|
||||
all()
|
||||
vlanids = (session.query(l2network_models.VlanID).
|
||||
all())
|
||||
return vlanids
|
||||
except exc.NoResultFound:
|
||||
return []
|
||||
@ -101,9 +100,9 @@ def is_vlanid_used(vlan_id):
|
||||
LOG.debug("is_vlanid_used() called")
|
||||
session = db.get_session()
|
||||
try:
|
||||
vlanid = session.query(l2network_models.VlanID).\
|
||||
filter_by(vlan_id=vlan_id).\
|
||||
one()
|
||||
vlanid = (session.query(l2network_models.VlanID).
|
||||
filter_by(vlan_id=vlan_id).
|
||||
one())
|
||||
return vlanid["vlan_used"]
|
||||
except exc.NoResultFound:
|
||||
raise c_exc.VlanIDNotFound(vlan_id=vlan_id)
|
||||
@ -114,9 +113,9 @@ def release_vlanid(vlan_id):
|
||||
LOG.debug("release_vlanid() called")
|
||||
session = db.get_session()
|
||||
try:
|
||||
vlanid = session.query(l2network_models.VlanID).\
|
||||
filter_by(vlan_id=vlan_id).\
|
||||
one()
|
||||
vlanid = (session.query(l2network_models.VlanID).
|
||||
filter_by(vlan_id=vlan_id).
|
||||
one())
|
||||
vlanid["vlan_used"] = False
|
||||
session.merge(vlanid)
|
||||
session.flush()
|
||||
@ -131,9 +130,9 @@ def delete_vlanid(vlan_id):
|
||||
LOG.debug("delete_vlanid() called")
|
||||
session = db.get_session()
|
||||
try:
|
||||
vlanid = session.query(l2network_models.VlanID).\
|
||||
filter_by(vlan_id=vlan_id).\
|
||||
one()
|
||||
vlanid = (session.query(l2network_models.VlanID).
|
||||
filter_by(vlan_id=vlan_id).
|
||||
one())
|
||||
session.delete(vlanid)
|
||||
session.flush()
|
||||
return vlanid
|
||||
@ -146,20 +145,20 @@ def reserve_vlanid():
|
||||
LOG.debug("reserve_vlanid() called")
|
||||
session = db.get_session()
|
||||
try:
|
||||
rvlan = session.query(l2network_models.VlanID).\
|
||||
first()
|
||||
rvlan = (session.query(l2network_models.VlanID).
|
||||
first())
|
||||
if not rvlan:
|
||||
create_vlanids()
|
||||
|
||||
rvlan = session.query(l2network_models.VlanID).\
|
||||
filter_by(vlan_used=False).\
|
||||
first()
|
||||
rvlan = (session.query(l2network_models.VlanID).
|
||||
filter_by(vlan_used=False).
|
||||
first())
|
||||
if not rvlan:
|
||||
raise c_exc.VlanIDNotAvailable()
|
||||
|
||||
rvlanid = session.query(l2network_models.VlanID).\
|
||||
filter_by(vlan_id=rvlan["vlan_id"]).\
|
||||
one()
|
||||
rvlanid = (session.query(l2network_models.VlanID).
|
||||
filter_by(vlan_id=rvlan["vlan_id"]).
|
||||
one())
|
||||
rvlanid["vlan_used"] = True
|
||||
session.merge(rvlanid)
|
||||
session.flush()
|
||||
@ -173,9 +172,9 @@ def get_all_vlanids_used():
|
||||
LOG.debug("get_all_vlanids() called")
|
||||
session = db.get_session()
|
||||
try:
|
||||
vlanids = session.query(l2network_models.VlanID).\
|
||||
filter_by(vlan_used=True).\
|
||||
all()
|
||||
vlanids = (session.query(l2network_models.VlanID).
|
||||
filter_by(vlan_used=True).
|
||||
all())
|
||||
return vlanids
|
||||
except exc.NoResultFound:
|
||||
return []
|
||||
@ -186,8 +185,8 @@ def get_all_vlan_bindings():
|
||||
LOG.debug("get_all_vlan_bindings() called")
|
||||
session = db.get_session()
|
||||
try:
|
||||
bindings = session.query(l2network_models.VlanBinding).\
|
||||
all()
|
||||
bindings = (session.query(l2network_models.VlanBinding).
|
||||
all())
|
||||
return bindings
|
||||
except exc.NoResultFound:
|
||||
return []
|
||||
@ -198,9 +197,9 @@ def get_vlan_binding(netid):
|
||||
LOG.debug("get_vlan_binding() called")
|
||||
session = db.get_session()
|
||||
try:
|
||||
binding = session.query(l2network_models.VlanBinding).\
|
||||
filter_by(network_id=netid).\
|
||||
one()
|
||||
binding = (session.query(l2network_models.VlanBinding).
|
||||
filter_by(network_id=netid).
|
||||
one())
|
||||
return binding
|
||||
except exc.NoResultFound:
|
||||
raise c_exc.NetworkVlanBindingNotFound(network_id=netid)
|
||||
@ -211,9 +210,9 @@ def add_vlan_binding(vlanid, netid):
|
||||
LOG.debug("add_vlan_binding() called")
|
||||
session = db.get_session()
|
||||
try:
|
||||
binding = session.query(l2network_models.VlanBinding).\
|
||||
filter_by(vlan_id=vlanid).\
|
||||
one()
|
||||
binding = (session.query(l2network_models.VlanBinding).
|
||||
filter_by(vlan_id=vlanid).
|
||||
one())
|
||||
raise c_exc.NetworkVlanBindingAlreadyExists(vlan_id=vlanid,
|
||||
network_id=netid)
|
||||
except exc.NoResultFound:
|
||||
@ -228,9 +227,9 @@ def remove_vlan_binding(netid):
|
||||
LOG.debug("remove_vlan_binding() called")
|
||||
session = db.get_session()
|
||||
try:
|
||||
binding = session.query(l2network_models.VlanBinding).\
|
||||
filter_by(network_id=netid).\
|
||||
one()
|
||||
binding = (session.query(l2network_models.VlanBinding).
|
||||
filter_by(network_id=netid).
|
||||
one())
|
||||
session.delete(binding)
|
||||
session.flush()
|
||||
return binding
|
||||
@ -243,9 +242,9 @@ def update_vlan_binding(netid, newvlanid=None):
|
||||
LOG.debug("update_vlan_binding() called")
|
||||
session = db.get_session()
|
||||
try:
|
||||
binding = session.query(l2network_models.VlanBinding).\
|
||||
filter_by(network_id=netid).\
|
||||
one()
|
||||
binding = (session.query(l2network_models.VlanBinding).
|
||||
filter_by(network_id=netid).
|
||||
one())
|
||||
if newvlanid:
|
||||
binding["vlan_id"] = newvlanid
|
||||
session.merge(binding)
|
||||
|
@ -20,9 +20,9 @@ import uuid
|
||||
from sqlalchemy import Column, Integer, String, Boolean
|
||||
from sqlalchemy.orm import relation, object_mapper
|
||||
|
||||
from quantum.db import models
|
||||
from quantum.db.models import BASE
|
||||
from quantum.db.models import QuantumBase
|
||||
from quantum.db import models
|
||||
|
||||
|
||||
class VlanID(BASE, QuantumBase):
|
||||
@ -37,8 +37,7 @@ class VlanID(BASE, QuantumBase):
|
||||
self.vlan_used = False
|
||||
|
||||
def __repr__(self):
|
||||
return "<VlanID(%d,%s)>" % \
|
||||
(self.vlan_id, self.vlan_used)
|
||||
return "<VlanID(%d,%s)>" % (self.vlan_id, self.vlan_used)
|
||||
|
||||
|
||||
class VlanBinding(BASE, QuantumBase):
|
||||
@ -53,5 +52,4 @@ class VlanBinding(BASE, QuantumBase):
|
||||
self.network_id = network_id
|
||||
|
||||
def __repr__(self):
|
||||
return "<VlanBinding(%d,%s,%s)>" % \
|
||||
(self.vlan_id, self.network_id)
|
||||
return "<VlanBinding(%d,%s,%s)>" % (self.vlan_id, self.network_id)
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2012 Cisco Systems, Inc. All rights reserved.
|
||||
@ -17,7 +16,6 @@
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
# @author: Rohit Agarwalla, Cisco Systems, Inc.
|
||||
"""
|
||||
|
||||
import os
|
||||
|
||||
|
@ -25,11 +25,10 @@ To run all tests::
|
||||
PLUGIN_DIR=quantum/plugins/linuxbridge ./run_tests.sh
|
||||
"""
|
||||
|
||||
import gettext
|
||||
import logging
|
||||
import os
|
||||
import unittest
|
||||
import sys
|
||||
import unittest
|
||||
|
||||
from nose import config
|
||||
from nose import core
|
||||
|
@ -15,26 +15,26 @@
|
||||
# under the License.
|
||||
#
|
||||
# @author: Shweta Padubidri, Cisco Systems, Inc.
|
||||
#
|
||||
|
||||
import ConfigParser
|
||||
import logging as LOG
|
||||
import unittest
|
||||
import sys
|
||||
import logging
|
||||
import os
|
||||
import shlex
|
||||
import signal
|
||||
from subprocess import *
|
||||
import subprocess
|
||||
import sys
|
||||
import unittest
|
||||
|
||||
import quantum.plugins.linuxbridge.agent.linuxbridge_quantum_agent\
|
||||
as linux_agent
|
||||
from quantum.plugins.linuxbridge.common import constants as lconst
|
||||
from quantum.plugins.linuxbridge import LinuxBridgePlugin
|
||||
from quantum.plugins.linuxbridge.db import l2network_db as cdb
|
||||
import quantum.db.api as db
|
||||
from quantum.plugins.linuxbridge import LinuxBridgePlugin
|
||||
from quantum.plugins.linuxbridge.agent import (
|
||||
linuxbridge_quantum_agent as linux_agent,
|
||||
)
|
||||
from quantum.plugins.linuxbridge.common import constants as lconst
|
||||
from quantum.plugins.linuxbridge.db import l2network_db as cdb
|
||||
|
||||
|
||||
LOG.getLogger(__name__)
|
||||
LOG = logger.getLogger(__name__)
|
||||
|
||||
|
||||
class LinuxBridgeAgentTest(unittest.TestCase):
|
||||
@ -45,8 +45,8 @@ class LinuxBridgeAgentTest(unittest.TestCase):
|
||||
mac_address='fe:16:3e:51:60:dd'):
|
||||
|
||||
LOG.debug("test_tap_gateway_interface - START")
|
||||
new_network =\
|
||||
self._linuxbridge_plugin.create_network(tenant_id, network_name)
|
||||
new_network = (
|
||||
self._linuxbridge_plugin.create_network(tenant_id, network_name))
|
||||
new_port = self._linuxbridge_plugin.create_port(
|
||||
tenant_id, new_network[lconst.NET_ID], lconst.PORT_UP)
|
||||
self._linuxbridge_plugin.plug_interface(
|
||||
@ -63,8 +63,8 @@ class LinuxBridgeAgentTest(unittest.TestCase):
|
||||
self._linuxbridge_quantum_agent.process_port_binding(
|
||||
new_port[lconst.PORT_ID], new_network[lconst.NET_ID],
|
||||
device_name, str(vlan_id))
|
||||
list_interface = self._linuxbridge_quantum_agent.linux_br.\
|
||||
get_interfaces_on_bridge(bridge_name)
|
||||
list_interface = (self._linuxbridge_quantum_agent.linux_br.
|
||||
get_interfaces_on_bridge(bridge_name))
|
||||
|
||||
self.assertTrue(device_name in list_interface)
|
||||
for interface in list_interface:
|
||||
@ -83,8 +83,8 @@ class LinuxBridgeAgentTest(unittest.TestCase):
|
||||
mac_address='fe:16:3e:51:60:dd'):
|
||||
|
||||
LOG.debug("test_add_tap_interface - START")
|
||||
new_network =\
|
||||
self._linuxbridge_plugin.create_network(tenant_id, network_name)
|
||||
new_network = (
|
||||
self._linuxbridge_plugin.create_network(tenant_id, network_name))
|
||||
new_port = self._linuxbridge_plugin.create_port(
|
||||
tenant_id, new_network[lconst.NET_ID], lconst.PORT_UP)
|
||||
self._linuxbridge_plugin.plug_interface(
|
||||
@ -101,8 +101,8 @@ class LinuxBridgeAgentTest(unittest.TestCase):
|
||||
self._linuxbridge_quantum_agent.process_port_binding(
|
||||
new_port[lconst.PORT_ID], new_network[lconst.NET_ID],
|
||||
interface_id, str(vlan_id))
|
||||
list_interface = self._linuxbridge_quantum_agent.linux_br.\
|
||||
get_interfaces_on_bridge(bridge_name)
|
||||
list_interface = (self._linuxbridge_quantum_agent.linux_br.
|
||||
get_interfaces_on_bridge(bridge_name))
|
||||
|
||||
self.assertTrue(device_name in list_interface)
|
||||
for interface in list_interface:
|
||||
@ -121,8 +121,8 @@ class LinuxBridgeAgentTest(unittest.TestCase):
|
||||
mac_address='fe:16:3e:51:60:dd'):
|
||||
|
||||
LOG.debug("test_remove_interface - START")
|
||||
new_network =\
|
||||
self._linuxbridge_plugin.create_network(tenant_id, network_name)
|
||||
new_network = (
|
||||
self._linuxbridge_plugin.create_network(tenant_id, network_name))
|
||||
new_port = self._linuxbridge_plugin.create_port(
|
||||
tenant_id, new_network[lconst.NET_ID], lconst.PORT_UP)
|
||||
self._linuxbridge_plugin.plug_interface(
|
||||
@ -139,13 +139,13 @@ class LinuxBridgeAgentTest(unittest.TestCase):
|
||||
self._linuxbridge_quantum_agent.process_port_binding(
|
||||
new_port[lconst.PORT_ID], new_network[lconst.NET_ID],
|
||||
interface_id, str(vlan_id))
|
||||
list_interface = self._linuxbridge_quantum_agent.linux_br.\
|
||||
get_interfaces_on_bridge(bridge_name)
|
||||
list_interface = (self._linuxbridge_quantum_agent.linux_br.
|
||||
get_interfaces_on_bridge(bridge_name))
|
||||
|
||||
self._linuxbridge_quantum_agent.linux_br.remove_interface(bridge_name,
|
||||
device_name)
|
||||
list_interface = self._linuxbridge_quantum_agent.linux_br.\
|
||||
get_interfaces_on_bridge(bridge_name)
|
||||
list_interface = (self._linuxbridge_quantum_agent.linux_br.
|
||||
get_interfaces_on_bridge(bridge_name))
|
||||
self.assertFalse(device_name in list_interface)
|
||||
for interface in list_interface:
|
||||
self._linuxbridge_quantum_agent.linux_br.remove_interface(
|
||||
@ -159,12 +159,13 @@ class LinuxBridgeAgentTest(unittest.TestCase):
|
||||
LOG.debug("test_remove_interface -END")
|
||||
|
||||
def test_ensure_vlan_bridge(
|
||||
self, tenant_id="test_tenant", network_name="test_network",
|
||||
self, tenant_id="test_tenant",
|
||||
network_name="test_network",
|
||||
interface_id='fe701ddf-26a2-42ea-b9e6-7313d1c522cc'):
|
||||
|
||||
LOG.debug("test_ensure_vlan_bridge - START")
|
||||
new_network =\
|
||||
self._linuxbridge_plugin.create_network(tenant_id, network_name)
|
||||
new_network = (
|
||||
self._linuxbridge_plugin.create_network(tenant_id, network_name))
|
||||
new_port = self._linuxbridge_plugin.create_port(
|
||||
tenant_id, new_network[lconst.NET_ID], lconst.PORT_UP)
|
||||
self._linuxbridge_plugin.plug_interface(
|
||||
@ -177,11 +178,11 @@ class LinuxBridgeAgentTest(unittest.TestCase):
|
||||
|
||||
self._linuxbridge_quantum_agent.linux_br.ensure_vlan_bridge(
|
||||
new_network[lconst.NET_ID], str(vlan_id))
|
||||
list_quantum_bridges = self._linuxbridge_quantum_agent.linux_br.\
|
||||
get_all_quantum_bridges()
|
||||
list_quantum_bridges = (self._linuxbridge_quantum_agent.linux_br.
|
||||
get_all_quantum_bridges())
|
||||
self.assertTrue(bridge_name in list_quantum_bridges)
|
||||
list_interface = self._linuxbridge_quantum_agent.linux_br.\
|
||||
get_interfaces_on_bridge(bridge_name)
|
||||
list_interface = (self._linuxbridge_quantum_agent.linux_br.
|
||||
get_interfaces_on_bridge(bridge_name))
|
||||
self.assertTrue(vlan_subinterface in list_interface)
|
||||
|
||||
for interface in list_interface:
|
||||
@ -199,8 +200,8 @@ class LinuxBridgeAgentTest(unittest.TestCase):
|
||||
interface_id='fe701ddf-26a2-42ea-b9e6-7313d1c522cc'):
|
||||
|
||||
LOG.debug("test_delete_vlan_bridge - START")
|
||||
new_network =\
|
||||
self._linuxbridge_plugin.create_network(tenant_id, network_name)
|
||||
new_network = (
|
||||
self._linuxbridge_plugin.create_network(tenant_id, network_name))
|
||||
new_port = self._linuxbridge_plugin.create_port(
|
||||
tenant_id, new_network[lconst.NET_ID], lconst.PORT_UP)
|
||||
self._linuxbridge_plugin.plug_interface(
|
||||
@ -228,8 +229,8 @@ class LinuxBridgeAgentTest(unittest.TestCase):
|
||||
interface_id='fe701ddf-26a2-42ea-b9e6-7313d1c522cc'):
|
||||
|
||||
LOG.debug("test_delete_vlan_bridge - START")
|
||||
new_network =\
|
||||
self._linuxbridge_plugin.create_network(tenant_id, network_name)
|
||||
new_network = (
|
||||
self._linuxbridge_plugin.create_network(tenant_id, network_name))
|
||||
new_port = self._linuxbridge_plugin.create_port(
|
||||
tenant_id, new_network[lconst.NET_ID], lconst.PORT_UP)
|
||||
self._linuxbridge_plugin.plug_interface(
|
||||
@ -237,8 +238,8 @@ class LinuxBridgeAgentTest(unittest.TestCase):
|
||||
new_port[lconst.PORT_ID], interface_id)
|
||||
bridge_name = self.br_name_prefix + new_network[lconst.NET_ID][0:11]
|
||||
vlan_bindings = {}
|
||||
vlan_bindings[new_network[lconst.NET_ID]] =\
|
||||
cdb.get_vlan_binding(new_network[lconst.NET_ID])
|
||||
vlan_bindings[new_network[lconst.NET_ID]] = (
|
||||
cdb.get_vlan_binding(new_network[lconst.NET_ID]))
|
||||
vlan_id = vlan_bindings[new_network[lconst.NET_ID]][lconst.VLANID]
|
||||
vlan_subinterface = self.physical_interface + '.' + str(vlan_id)
|
||||
|
||||
@ -259,8 +260,8 @@ class LinuxBridgeAgentTest(unittest.TestCase):
|
||||
mac_address='fe:16:3e:51:60:dd'):
|
||||
|
||||
LOG.debug("test_process_unplugged_tap_interface - START")
|
||||
new_network =\
|
||||
self._linuxbridge_plugin.create_network(tenant_id, network_name)
|
||||
new_network = (
|
||||
self._linuxbridge_plugin.create_network(tenant_id, network_name))
|
||||
new_port = self._linuxbridge_plugin.create_port(
|
||||
tenant_id, new_network[lconst.NET_ID], lconst.PORT_UP)
|
||||
self._linuxbridge_plugin.plug_interface(
|
||||
@ -285,8 +286,8 @@ class LinuxBridgeAgentTest(unittest.TestCase):
|
||||
plugged_interface = []
|
||||
self._linuxbridge_quantum_agent.process_unplugged_interfaces(
|
||||
plugged_interface)
|
||||
list_interface = self._linuxbridge_quantum_agent.linux_br.\
|
||||
get_interfaces_on_bridge(bridge_name)
|
||||
list_interface = (self._linuxbridge_quantum_agent.linux_br.
|
||||
get_interfaces_on_bridge(bridge_name))
|
||||
self.assertFalse(device_name in list_interface)
|
||||
for interface in list_interface:
|
||||
self._linuxbridge_quantum_agent.linux_br.remove_interface(
|
||||
@ -305,8 +306,8 @@ class LinuxBridgeAgentTest(unittest.TestCase):
|
||||
mac_address='fe:16:3e:51:60:dd'):
|
||||
|
||||
LOG.debug("test_process_unplugged_gw_interface - START")
|
||||
new_network =\
|
||||
self._linuxbridge_plugin.create_network(tenant_id, network_name)
|
||||
new_network = (
|
||||
self._linuxbridge_plugin.create_network(tenant_id, network_name))
|
||||
new_port = self._linuxbridge_plugin.create_port(
|
||||
tenant_id, new_network[lconst.NET_ID], lconst.PORT_UP)
|
||||
self._linuxbridge_plugin.plug_interface(
|
||||
@ -323,16 +324,16 @@ class LinuxBridgeAgentTest(unittest.TestCase):
|
||||
self._linuxbridge_quantum_agent.process_port_binding(
|
||||
new_port[lconst.PORT_ID], new_network[lconst.NET_ID],
|
||||
interface_id, str(vlan_id))
|
||||
list_interface = self._linuxbridge_quantum_agent.linux_br.\
|
||||
get_interfaces_on_bridge(bridge_name)
|
||||
list_interface = (self._linuxbridge_quantum_agent.linux_br.
|
||||
get_interfaces_on_bridge(bridge_name))
|
||||
self._linuxbridge_plugin.unplug_interface(tenant_id,
|
||||
new_network[lconst.NET_ID],
|
||||
new_port[lconst.PORT_ID])
|
||||
plugged_interface = []
|
||||
self._linuxbridge_quantum_agent.process_unplugged_interfaces(
|
||||
plugged_interface)
|
||||
list_interface = self._linuxbridge_quantum_agent.linux_br.\
|
||||
get_interfaces_on_bridge(bridge_name)
|
||||
list_interface = (self._linuxbridge_quantum_agent.linux_br.
|
||||
get_interfaces_on_bridge(bridge_name))
|
||||
self.assertFalse(device_name in list_interface)
|
||||
for interface in list_interface:
|
||||
self._linuxbridge_quantum_agent.linux_br.remove_interface(
|
||||
@ -410,7 +411,7 @@ class LinuxBridgeAgentTest(unittest.TestCase):
|
||||
def run_cmd(self, args):
|
||||
cmd = shlex.split(self.root_helper) + args
|
||||
LOG.debug("Running command: " + " ".join(cmd))
|
||||
p = Popen(cmd, stdout=PIPE)
|
||||
p = subprocess.Popen(cmd, stdout=subprocess.PIPE)
|
||||
retval = p.communicate()[0]
|
||||
if p.returncode == -(signal.SIGALRM):
|
||||
LOG.debug("Timeout running command: " + " ".join(args))
|
||||
|
@ -1,4 +1,3 @@
|
||||
"""
|
||||
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
||||
#
|
||||
# Copyright 2012, Cisco Systems, Inc.
|
||||
@ -15,22 +14,21 @@
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
# @author: Rohit Agarwalla, Cisco Systems, Inc.
|
||||
"""
|
||||
|
||||
"""
|
||||
test_database.py is an independent test suite
|
||||
that tests the database api method calls
|
||||
"""
|
||||
import logging as LOG
|
||||
|
||||
import logging
|
||||
import unittest
|
||||
|
||||
from common import constants as const
|
||||
|
||||
import quantum.db.api as db
|
||||
import db.l2network_db as l2network_db
|
||||
from quantum.plugins.linuxbridge.common import constants as const
|
||||
import quantum.plugins.linuxbridge.db.l2network_db as l2network_db
|
||||
|
||||
|
||||
LOG.getLogger(__name__)
|
||||
LOG = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class L2networkDB(object):
|
||||
@ -56,8 +54,8 @@ class L2networkDB(object):
|
||||
vlan = []
|
||||
try:
|
||||
for vlan_bind in l2network_db.get_vlan_binding(network_id):
|
||||
LOG.debug("Getting vlan binding for vlan: %s"
|
||||
% vlan_bind.vlan_id)
|
||||
LOG.debug("Getting vlan binding for vlan: %s" %
|
||||
vlan_bind.vlan_id)
|
||||
vlan_dict = {}
|
||||
vlan_dict["vlan-id"] = str(vlan_bind.vlan_id)
|
||||
vlan_dict["net-id"] = str(vlan_bind.network_id)
|
||||
|
@ -1,4 +1,3 @@
|
||||
'''
|
||||
# Copyright 2012 Nicira Networks, Inc.
|
||||
#
|
||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||
@ -12,14 +11,18 @@
|
||||
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
|
||||
@author: Somik Behera, Nicira Networks, Inc.
|
||||
'''
|
||||
#
|
||||
#@author: Somik Behera, Nicira Networks, Inc.
|
||||
|
||||
import httplib # basic HTTP library for HTTPS connections
|
||||
import logging
|
||||
from api_client.client_eventlet import NvpApiClientEventlet
|
||||
from api_client.request_eventlet import NvpGenericRequestEventlet
|
||||
|
||||
|
||||
from quantum.plugins.nicira.nicira_nvp_plugin.api_client.client_eventlet \
|
||||
import NvpApiClientEventlet
|
||||
from quantum.plugins.nicira.nicira_nvp_plugin.api_client.request_eventlet \
|
||||
import NvpGenericRequestEventlet
|
||||
|
||||
|
||||
LOG = logging.getLogger("NVPApiHelper")
|
||||
LOG.setLevel(logging.INFO)
|
||||
@ -124,8 +127,9 @@ class NVPApiHelper(NvpApiClientEventlet):
|
||||
# Continue processing for non-error condition.
|
||||
if (status != httplib.OK and status != httplib.CREATED
|
||||
and status != httplib.NO_CONTENT):
|
||||
LOG.error("%s to %s, unexpected response code: %d (content = '%s')"
|
||||
% (method, url, response.status, response.body))
|
||||
LOG.error(
|
||||
"%s to %s, unexpected response code: %d (content = '%s')" %
|
||||
(method, url, response.status, response.body))
|
||||
return None
|
||||
|
||||
return response.body
|
||||
@ -145,14 +149,16 @@ class NVPApiHelper(NvpApiClientEventlet):
|
||||
def zero(self):
|
||||
raise NvpApiException()
|
||||
|
||||
error_codes = {404: fourZeroFour,
|
||||
error_codes = {
|
||||
404: fourZeroFour,
|
||||
409: fourZeroNine,
|
||||
503: fiveZeroThree,
|
||||
403: fourZeroThree,
|
||||
301: zero,
|
||||
307: zero,
|
||||
400: zero,
|
||||
500: zero}
|
||||
500: zero,
|
||||
}
|
||||
|
||||
|
||||
class NvpApiException(Exception):
|
||||
@ -191,13 +197,13 @@ class Conflict(NvpApiException):
|
||||
|
||||
|
||||
class ServiceUnavailable(NvpApiException):
|
||||
message = "Request could not completed because the associated " \
|
||||
"resource could not be reached."
|
||||
message = ("Request could not completed because the associated "
|
||||
"resource could not be reached.")
|
||||
|
||||
|
||||
class Forbidden(NvpApiException):
|
||||
message = "The request is forbidden from accessing the " \
|
||||
"referenced resource."
|
||||
message = ("The request is forbidden from accessing the "
|
||||
"referenced resource.")
|
||||
|
||||
|
||||
class RequestTimeout(NvpApiException):
|
||||
|
@ -17,19 +17,29 @@
|
||||
|
||||
import ConfigParser
|
||||
import logging
|
||||
import nvplib
|
||||
import NvpApiClient
|
||||
import os
|
||||
import sys
|
||||
|
||||
from api_client.client_eventlet import DEFAULT_CONCURRENT_CONNECTIONS
|
||||
from api_client.client_eventlet import DEFAULT_FAILOVER_TIME
|
||||
from api_client.request_eventlet import DEFAULT_REQUEST_TIMEOUT
|
||||
from api_client.request_eventlet import DEFAULT_HTTP_TIMEOUT
|
||||
from api_client.request_eventlet import DEFAULT_RETRIES
|
||||
from api_client.request_eventlet import DEFAULT_REDIRECTS
|
||||
import NvpApiClient
|
||||
import nvplib
|
||||
|
||||
from quantum.common import exceptions as exception
|
||||
from quantum.plugins.nicira.nicira_nvp_plugin.api_client.client_eventlet \
|
||||
import (
|
||||
DEFAULT_CONCURRENT_CONNECTIONS,
|
||||
DEFAULT_FAILOVER_TIME,
|
||||
)
|
||||
from quantum.plugins.nicira.nicira_nvp_plugin.api_client.request_eventlet \
|
||||
import (
|
||||
DEFAULT_REQUEST_TIMEOUT,
|
||||
DEFAULT_HTTP_TIMEOUT,
|
||||
DEFAULT_RETRIES,
|
||||
DEFAULT_REDIRECTS,
|
||||
)
|
||||
|
||||
|
||||
LOG = logging.getLogger("QuantumPlugin")
|
||||
|
||||
|
||||
CONFIG_FILE = "nvp.ini"
|
||||
CONFIG_FILE_PATHS = []
|
||||
@ -38,7 +48,6 @@ if os.environ.get('QUANTUM_HOME', None):
|
||||
CONFIG_FILE_PATHS.append("/etc/quantum/plugins/nicira")
|
||||
CONFIG_KEYS = ["DEFAULT_TZ_UUID", "NVP_CONTROLLER_IP", "PORT", "USER",
|
||||
"PASSWORD"]
|
||||
LOG = logging.getLogger("QuantumPlugin")
|
||||
|
||||
|
||||
def initConfig(cfile=None):
|
||||
@ -50,8 +59,7 @@ def initConfig(cfile=None):
|
||||
cfile = find_config(os.path.abspath(os.path.dirname(__file__)))
|
||||
|
||||
if cfile == None:
|
||||
raise Exception("Configuration file \"%s\" doesn't exist" %
|
||||
(cfile))
|
||||
raise Exception("Configuration file \"%s\" doesn't exist" % (cfile))
|
||||
LOG.info("Using configuration file: %s" % cfile)
|
||||
config.read(cfile)
|
||||
LOG.debug("Config: %s" % config)
|
||||
@ -71,7 +79,7 @@ def find_config(basepath):
|
||||
|
||||
|
||||
def parse_config(config):
|
||||
'''Backwards compatible parsing.
|
||||
"""Backwards compatible parsing.
|
||||
|
||||
:param config: ConfigParser object initilized with nvp.ini.
|
||||
:returns: A tuple consisting of a control cluster object and a
|
||||
@ -81,7 +89,7 @@ def parse_config(config):
|
||||
At some point, error handling needs to be significantly
|
||||
enhanced to provide user friendly error messages, clean program
|
||||
exists, rather than exceptions propagated to the user.
|
||||
'''
|
||||
"""
|
||||
# Extract plugin config parameters.
|
||||
try:
|
||||
failover_time = config.get('NVP', 'failover_time')
|
||||
@ -95,7 +103,7 @@ def parse_config(config):
|
||||
|
||||
plugin_config = {
|
||||
'failover_time': failover_time,
|
||||
'concurrent_connections': concurrent_connections
|
||||
'concurrent_connections': concurrent_connections,
|
||||
}
|
||||
LOG.info('parse_config(): plugin_config == "%s"' % plugin_config)
|
||||
|
||||
@ -103,8 +111,7 @@ def parse_config(config):
|
||||
|
||||
# Extract connection information.
|
||||
try:
|
||||
defined_connections = config.get(
|
||||
'NVP', 'NVP_CONTROLLER_CONNECTIONS')
|
||||
defined_connections = config.get('NVP', 'NVP_CONTROLLER_CONNECTIONS')
|
||||
|
||||
for conn_key in defined_connections.split():
|
||||
args = [config.get('NVP', 'DEFAULT_TZ_UUID')]
|
||||
@ -131,7 +138,7 @@ def parse_config(config):
|
||||
|
||||
|
||||
class NVPCluster(object):
|
||||
'''Encapsulates controller connection and api_client.
|
||||
"""Encapsulates controller connection and api_client.
|
||||
|
||||
Initialized within parse_config().
|
||||
Accessed within the NvpPlugin class.
|
||||
@ -142,7 +149,7 @@ class NVPCluster(object):
|
||||
|
||||
There may be some redundancy here, but that has been done to provide
|
||||
future flexibility.
|
||||
'''
|
||||
"""
|
||||
def __init__(self, name):
|
||||
self._name = name
|
||||
self.controllers = []
|
||||
@ -162,7 +169,7 @@ class NVPCluster(object):
|
||||
request_timeout=DEFAULT_REQUEST_TIMEOUT,
|
||||
http_timeout=DEFAULT_HTTP_TIMEOUT,
|
||||
retries=DEFAULT_RETRIES, redirects=DEFAULT_REDIRECTS):
|
||||
'''Add a new set of controller parameters.
|
||||
"""Add a new set of controller parameters.
|
||||
|
||||
:param ip: IP address of controller.
|
||||
:param port: port controller is listening on.
|
||||
@ -174,14 +181,12 @@ class NVPCluster(object):
|
||||
:param redirects: maximum number of server redirect responses to
|
||||
follow.
|
||||
:param default_tz_uuid: default transport zone uuid.
|
||||
'''
|
||||
"""
|
||||
|
||||
keys = [
|
||||
'ip', 'port', 'user', 'password', 'default_tz_uuid']
|
||||
keys = ['ip', 'port', 'user', 'password', 'default_tz_uuid']
|
||||
controller_dict = dict([(k, locals()[k]) for k in keys])
|
||||
|
||||
int_keys = [
|
||||
'request_timeout', 'http_timeout', 'retries', 'redirects']
|
||||
int_keys = ['request_timeout', 'http_timeout', 'retries', 'redirects']
|
||||
for k in int_keys:
|
||||
controller_dict[k] = int(locals()[k])
|
||||
|
||||
@ -236,10 +241,10 @@ class NVPCluster(object):
|
||||
|
||||
|
||||
class NvpPlugin(object):
|
||||
'''
|
||||
"""
|
||||
NvpPlugin is a Quantum plugin that provides L2 Virtual Network
|
||||
functionality using NVP.
|
||||
'''
|
||||
"""
|
||||
supported_extension_aliases = ["portstats"]
|
||||
|
||||
def __init__(self, configfile=None, loglevel=None, cli=False):
|
||||
@ -251,8 +256,7 @@ class NvpPlugin(object):
|
||||
config = initConfig(configfile)
|
||||
self.controller, self.plugin_config = parse_config(config)
|
||||
c = self.controller
|
||||
api_providers = [
|
||||
(x['ip'], x['port'], True) for x in c.controllers]
|
||||
api_providers = [(x['ip'], x['port'], True) for x in c.controllers]
|
||||
|
||||
c.api_client = NvpApiClient.NVPApiHelper(
|
||||
api_providers, c.user, c.password,
|
||||
@ -268,7 +272,7 @@ class NvpPlugin(object):
|
||||
self.api_client = self.controller.api_client
|
||||
|
||||
def get_all_networks(self, tenant_id, **kwargs):
|
||||
'''
|
||||
"""
|
||||
Returns a dictionary containing all <network_uuid, network_name> for
|
||||
the specified tenant.
|
||||
|
||||
@ -286,15 +290,14 @@ class NvpPlugin(object):
|
||||
}
|
||||
]
|
||||
:raises: None
|
||||
'''
|
||||
networks = nvplib.get_all_networks(self.controller, tenant_id,
|
||||
[])
|
||||
LOG.debug("get_all_networks() completed for tenant %s: %s" % (
|
||||
tenant_id, networks))
|
||||
"""
|
||||
networks = nvplib.get_all_networks(self.controller, tenant_id, [])
|
||||
LOG.debug("get_all_networks() completed for tenant %s: %s" %
|
||||
(tenant_id, networks))
|
||||
return networks
|
||||
|
||||
def create_network(self, tenant_id, net_name, **kwargs):
|
||||
'''
|
||||
"""
|
||||
Creates a new Virtual Network, and assigns it a symbolic name.
|
||||
:returns: a sequence of mappings with the following signature:
|
||||
{'net-id': uuid that uniquely identifies the
|
||||
@ -303,7 +306,7 @@ class NvpPlugin(object):
|
||||
with network referenced by net-id
|
||||
}
|
||||
:raises:
|
||||
'''
|
||||
"""
|
||||
kwargs["controller"] = self.controller
|
||||
return nvplib.create_network(tenant_id, net_name, **kwargs)
|
||||
|
||||
@ -315,7 +318,7 @@ class NvpPlugin(object):
|
||||
controller=controller)
|
||||
|
||||
def delete_network(self, tenant_id, netw_id):
|
||||
'''
|
||||
"""
|
||||
Deletes the network with the specified network identifier
|
||||
belonging to the specified tenant.
|
||||
|
||||
@ -325,7 +328,7 @@ class NvpPlugin(object):
|
||||
}
|
||||
:raises: exception.NetworkInUse
|
||||
:raises: exception.NetworkNotFound
|
||||
'''
|
||||
"""
|
||||
if not nvplib.check_tenant(self.controller, netw_id, tenant_id):
|
||||
raise exception.NetworkNotFound(net_id=netw_id)
|
||||
nvplib.delete_network(self.controller, netw_id)
|
||||
@ -334,7 +337,7 @@ class NvpPlugin(object):
|
||||
return {'net-id': netw_id}
|
||||
|
||||
def get_network_details(self, tenant_id, netw_id):
|
||||
'''
|
||||
"""
|
||||
Retrieves a list of all the remote vifs that
|
||||
are attached to the network.
|
||||
|
||||
@ -348,7 +351,7 @@ class NvpPlugin(object):
|
||||
}
|
||||
:raises: exception.NetworkNotFound
|
||||
:raises: exception.QuantumException
|
||||
'''
|
||||
"""
|
||||
if not nvplib.check_tenant(self.controller, netw_id, tenant_id):
|
||||
raise exception.NetworkNotFound(net_id=netw_id)
|
||||
result = None
|
||||
@ -366,16 +369,18 @@ class NvpPlugin(object):
|
||||
if not result:
|
||||
result = nvplib.get_network(self.controller, switch)
|
||||
|
||||
d = {"net-id": netw_id,
|
||||
d = {
|
||||
"net-id": netw_id,
|
||||
"net-ifaces": remote_vifs,
|
||||
"net-name": result["display_name"],
|
||||
"net-op-status": "UP"}
|
||||
LOG.debug("get_network_details() completed for tenant %s: %s" % (
|
||||
tenant_id, d))
|
||||
"net-op-status": "UP",
|
||||
}
|
||||
LOG.debug("get_network_details() completed for tenant %s: %s" %
|
||||
(tenant_id, d))
|
||||
return d
|
||||
|
||||
def update_network(self, tenant_id, netw_id, **kwargs):
|
||||
'''
|
||||
"""
|
||||
Updates the properties of a particular Virtual Network.
|
||||
|
||||
:returns: a sequence of mappings representing the new network
|
||||
@ -386,16 +391,19 @@ class NvpPlugin(object):
|
||||
associated with network referenced by net-id
|
||||
}
|
||||
:raises: exception.NetworkNotFound
|
||||
'''
|
||||
"""
|
||||
if not nvplib.check_tenant(self.controller, netw_id, tenant_id):
|
||||
raise exception.NetworkNotFound(net_id=netw_id)
|
||||
result = nvplib.update_network(self.controller, netw_id, **kwargs)
|
||||
LOG.debug("update_network() completed for tenant: %s" % tenant_id)
|
||||
return {'net-id': netw_id, 'net-name': result["display_name"],
|
||||
'net-op-status': "UP"}
|
||||
return {
|
||||
'net-id': netw_id,
|
||||
'net-name': result["display_name"],
|
||||
'net-op-status': "UP",
|
||||
}
|
||||
|
||||
def get_all_ports(self, tenant_id, netw_id, **kwargs):
|
||||
'''
|
||||
"""
|
||||
Retrieves all port identifiers belonging to the
|
||||
specified Virtual Network.
|
||||
|
||||
@ -409,7 +417,7 @@ class NvpPlugin(object):
|
||||
}
|
||||
]
|
||||
:raises: exception.NetworkNotFound
|
||||
'''
|
||||
"""
|
||||
ids = []
|
||||
filters = kwargs.get("filter_opts") or {}
|
||||
if not nvplib.check_tenant(self.controller, netw_id, tenant_id):
|
||||
@ -430,9 +438,8 @@ class NvpPlugin(object):
|
||||
LOG.debug(ids)
|
||||
return ids
|
||||
|
||||
def create_port(self, tenant_id, netw_id, port_init_state=None,
|
||||
**params):
|
||||
'''
|
||||
def create_port(self, tenant_id, netw_id, port_init_state=None, **params):
|
||||
"""
|
||||
Creates a port on the specified Virtual Network.
|
||||
|
||||
:returns: a mapping sequence with the following signature:
|
||||
@ -441,7 +448,7 @@ class NvpPlugin(object):
|
||||
}
|
||||
:raises: exception.NetworkNotFound
|
||||
:raises: exception.StateInvalid
|
||||
'''
|
||||
"""
|
||||
if not nvplib.check_tenant(self.controller, netw_id, tenant_id):
|
||||
raise exception.NetworkNotFound(net_id=netw_id)
|
||||
params["controller"] = self.controller
|
||||
@ -449,13 +456,15 @@ class NvpPlugin(object):
|
||||
raise exception.NetworkNotFound(net_id=netw_id)
|
||||
result = nvplib.create_port(tenant_id, netw_id, port_init_state,
|
||||
**params)
|
||||
d = {"port-id": result["uuid"],
|
||||
"port-op-status": result["port-op-status"]}
|
||||
d = {
|
||||
"port-id": result["uuid"],
|
||||
"port-op-status": result["port-op-status"],
|
||||
}
|
||||
LOG.debug("create_port() completed for tenant %s: %s" % (tenant_id, d))
|
||||
return d
|
||||
|
||||
def update_port(self, tenant_id, netw_id, portw_id, **params):
|
||||
'''
|
||||
"""
|
||||
Updates the properties of a specific port on the
|
||||
specified Virtual Network.
|
||||
|
||||
@ -466,21 +475,23 @@ class NvpPlugin(object):
|
||||
}
|
||||
:raises: exception.StateInvalid
|
||||
:raises: exception.PortNotFound
|
||||
'''
|
||||
"""
|
||||
if not nvplib.check_tenant(self.controller, netw_id, tenant_id):
|
||||
raise exception.NetworkNotFound(net_id=netw_id)
|
||||
LOG.debug("Update port request: %s" % (params))
|
||||
params["controller"] = self.controller
|
||||
result = nvplib.update_port(netw_id, portw_id, **params)
|
||||
LOG.debug("update_port() completed for tenant: %s" % tenant_id)
|
||||
port = {'port-id': portw_id,
|
||||
port = {
|
||||
'port-id': portw_id,
|
||||
'port-state': result["admin_status_enabled"],
|
||||
'port-op-status': result["port-op-status"]}
|
||||
'port-op-status': result["port-op-status"],
|
||||
}
|
||||
LOG.debug("returning updated port %s: " % port)
|
||||
return port
|
||||
|
||||
def delete_port(self, tenant_id, netw_id, portw_id):
|
||||
'''
|
||||
"""
|
||||
Deletes a port on a specified Virtual Network,
|
||||
if the port contains a remote interface attachment,
|
||||
the remote interface is first un-plugged and then the port
|
||||
@ -493,7 +504,7 @@ class NvpPlugin(object):
|
||||
:raises: exception.PortInUse
|
||||
:raises: exception.PortNotFound
|
||||
:raises: exception.NetworkNotFound
|
||||
'''
|
||||
"""
|
||||
if not nvplib.check_tenant(self.controller, netw_id, tenant_id):
|
||||
raise exception.NetworkNotFound(net_id=netw_id)
|
||||
nvplib.delete_port(self.controller, netw_id, portw_id)
|
||||
@ -501,7 +512,7 @@ class NvpPlugin(object):
|
||||
return {"port-id": portw_id}
|
||||
|
||||
def get_port_details(self, tenant_id, netw_id, portw_id):
|
||||
'''
|
||||
"""
|
||||
This method allows the user to retrieve a remote interface
|
||||
that is attached to this particular port.
|
||||
|
||||
@ -515,7 +526,7 @@ class NvpPlugin(object):
|
||||
}
|
||||
:raises: exception.PortNotFound
|
||||
:raises: exception.NetworkNotFound
|
||||
'''
|
||||
"""
|
||||
if not nvplib.check_tenant(self.controller, netw_id, tenant_id):
|
||||
raise exception.NetworkNotFound(net_id=netw_id)
|
||||
port = nvplib.get_port(self.controller, netw_id, portw_id,
|
||||
@ -530,15 +541,17 @@ class NvpPlugin(object):
|
||||
if attach_type == "VifAttachment":
|
||||
vif_uuid = relation["LogicalPortAttachment"]["vif_uuid"]
|
||||
|
||||
d = {"port-id": portw_id, "attachment": vif_uuid,
|
||||
d = {
|
||||
"port-id": portw_id, "attachment": vif_uuid,
|
||||
"net-id": netw_id, "port-state": state,
|
||||
"port-op-status": op_status}
|
||||
"port-op-status": op_status,
|
||||
}
|
||||
LOG.debug("Port details for tenant %s: %s" % (tenant_id, d))
|
||||
return d
|
||||
|
||||
def plug_interface(self, tenant_id, netw_id, portw_id,
|
||||
remote_interface_id):
|
||||
'''
|
||||
"""
|
||||
Attaches a remote interface to the specified port on the
|
||||
specified Virtual Network.
|
||||
|
||||
@ -547,23 +560,23 @@ class NvpPlugin(object):
|
||||
:raises: exception.PortNotFound
|
||||
:raises: exception.AlreadyAttached
|
||||
(? should the network automatically unplug/replug)
|
||||
'''
|
||||
"""
|
||||
if not nvplib.check_tenant(self.controller, netw_id, tenant_id):
|
||||
raise exception.NetworkNotFound(net_id=netw_id)
|
||||
result = nvplib.plug_interface(self.controller, netw_id, portw_id,
|
||||
"VifAttachment", attachment=remote_interface_id)
|
||||
LOG.debug("plug_interface() completed for %s: %s" % (
|
||||
tenant_id, result))
|
||||
LOG.debug("plug_interface() completed for %s: %s" %
|
||||
(tenant_id, result))
|
||||
|
||||
def unplug_interface(self, tenant_id, netw_id, portw_id):
|
||||
'''
|
||||
"""
|
||||
Detaches a remote interface from the specified port on the
|
||||
specified Virtual Network.
|
||||
|
||||
:returns: None
|
||||
:raises: exception.NetworkNotFound
|
||||
:raises: exception.PortNotFound
|
||||
'''
|
||||
"""
|
||||
if not nvplib.check_tenant(self.controller, netw_id, tenant_id):
|
||||
raise exception.NetworkNotFound(net_id=netw_id)
|
||||
result = nvplib.unplug_interface(self.controller, netw_id, portw_id)
|
||||
|
@ -12,18 +12,22 @@
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
|
||||
|
||||
import client
|
||||
import eventlet
|
||||
import httplib
|
||||
import logging
|
||||
import request_eventlet
|
||||
import time
|
||||
from common import _conn_str
|
||||
|
||||
import eventlet
|
||||
|
||||
from quantum.plugins.nicira.nicira_nvp_plugin.api_client.common import (
|
||||
_conn_str,
|
||||
)
|
||||
import quantum.plugins.nicira.nicira_nvp_plugin.api_client.client as client
|
||||
import quantum.plugins.nicira.nicira_nvp_plugin.api_client.request_eventlet
|
||||
|
||||
|
||||
logging.basicConfig(level=logging.INFO)
|
||||
lg = logging.getLogger('nvp_api_client')
|
||||
LOG = logging.getLogger('nvp_api_client')
|
||||
|
||||
|
||||
# Default parameters.
|
||||
DEFAULT_FAILOVER_TIME = 5
|
||||
@ -32,7 +36,7 @@ DEFAULT_CONNECT_TIMEOUT = 5
|
||||
|
||||
|
||||
class NvpApiClientEventlet(object):
|
||||
'''Eventlet-based implementation of NvpApiClient ABC.'''
|
||||
"""Eventlet-based implementation of NvpApiClient ABC."""
|
||||
|
||||
CONN_IDLE_TIMEOUT = 60 * 15
|
||||
|
||||
@ -41,7 +45,7 @@ class NvpApiClientEventlet(object):
|
||||
use_https=True,
|
||||
connect_timeout=DEFAULT_CONNECT_TIMEOUT,
|
||||
failover_time=DEFAULT_FAILOVER_TIME):
|
||||
'''Constructor
|
||||
"""Constructor
|
||||
|
||||
Args:
|
||||
api_providers: a list of tuples of the form: (host, port, is_ssl).
|
||||
@ -50,7 +54,7 @@ class NvpApiClientEventlet(object):
|
||||
concurrent_connections: total number of concurrent connections.
|
||||
use_https: whether or not to use https for requests.
|
||||
connect_timeout: connection timeout in seconds.
|
||||
'''
|
||||
"""
|
||||
self._api_providers = set([tuple(p) for p in api_providers])
|
||||
self._user = user
|
||||
self._password = password
|
||||
@ -107,13 +111,13 @@ class NvpApiClientEventlet(object):
|
||||
return self._cookie
|
||||
|
||||
def acquire_connection(self):
|
||||
'''Check out an available HTTPConnection instance.
|
||||
"""Check out an available HTTPConnection instance.
|
||||
|
||||
Blocks until a connection is available.
|
||||
|
||||
Returns: An available HTTPConnection instance or None if no
|
||||
api_providers are configured.
|
||||
'''
|
||||
"""
|
||||
if not self._api_providers:
|
||||
return None
|
||||
|
||||
@ -121,47 +125,47 @@ class NvpApiClientEventlet(object):
|
||||
# there has been a change in the controller used as the api_provider.
|
||||
now = time.time()
|
||||
if now < getattr(self, '_issue_conn_barrier', now):
|
||||
lg.info("acquire_connection() waiting for timer to expire.")
|
||||
LOG.info("acquire_connection() waiting for timer to expire.")
|
||||
time.sleep(self._issue_conn_barrier - now)
|
||||
|
||||
if self._active_conn_pool.empty():
|
||||
lg.debug("Waiting to acquire an API client connection")
|
||||
LOG.debug("Waiting to acquire an API client connection")
|
||||
|
||||
# get() call is blocking.
|
||||
conn = self._active_conn_pool.get()
|
||||
now = time.time()
|
||||
if getattr(conn, 'last_used', now) < now - self.CONN_IDLE_TIMEOUT:
|
||||
lg.info("Connection %s idle for %0.2f seconds; reconnecting."
|
||||
% (_conn_str(conn), now - conn.last_used))
|
||||
LOG.info("Connection %s idle for %0.2f seconds; reconnecting." %
|
||||
(_conn_str(conn), now - conn.last_used))
|
||||
conn = self._create_connection(*self._conn_params(conn))
|
||||
|
||||
# Stash conn pool so conn knows where to go when it releases.
|
||||
conn.conn_pool = self._active_conn_pool
|
||||
|
||||
conn.last_used = now
|
||||
lg.debug("API client connection %s acquired" % _conn_str(conn))
|
||||
LOG.debug("API client connection %s acquired" % _conn_str(conn))
|
||||
return conn
|
||||
|
||||
def release_connection(self, http_conn, bad_state=False):
|
||||
'''Mark HTTPConnection instance as available for check-out.
|
||||
"""Mark HTTPConnection instance as available for check-out.
|
||||
|
||||
Args:
|
||||
http_conn: An HTTPConnection instance obtained from this
|
||||
instance.
|
||||
bad_state: True if http_conn is known to be in a bad state
|
||||
(e.g. connection fault.)
|
||||
'''
|
||||
"""
|
||||
if self._conn_params(http_conn) not in self._api_providers:
|
||||
lg.debug("Released connection '%s' is no longer an API provider "
|
||||
"for the cluster" % _conn_str(http_conn))
|
||||
LOG.debug(("Released connection '%s' is no longer an API provider "
|
||||
"for the cluster") % _conn_str(http_conn))
|
||||
return
|
||||
|
||||
# Retrieve "home" connection pool.
|
||||
conn_pool = http_conn.conn_pool
|
||||
if bad_state:
|
||||
# reconnect
|
||||
lg.info("API connection fault, reconnecting to %s"
|
||||
% _conn_str(http_conn))
|
||||
LOG.info("API connection fault, reconnecting to %s" %
|
||||
_conn_str(http_conn))
|
||||
http_conn = self._create_connection(*self._conn_params(http_conn))
|
||||
http_conn.conn_pool = conn_pool
|
||||
conn_pool.put(http_conn)
|
||||
@ -169,14 +173,14 @@ class NvpApiClientEventlet(object):
|
||||
if self._active_conn_pool == http_conn.conn_pool:
|
||||
# Get next connection from the connection pool and make it
|
||||
# active.
|
||||
lg.info("API connection fault changing active_conn_pool.")
|
||||
LOG.info("API connection fault changing active_conn_pool.")
|
||||
self._conn_pool.put(self._active_conn_pool)
|
||||
self._active_conn_pool = self._conn_pool.get()
|
||||
self._issue_conn_barrier = time.time() + self._failover_time
|
||||
else:
|
||||
conn_pool.put(http_conn)
|
||||
|
||||
lg.debug("API client connection %s released" % _conn_str(http_conn))
|
||||
LOG.debug("API client connection %s released" % _conn_str(http_conn))
|
||||
|
||||
@property
|
||||
def need_login(self):
|
||||
@ -192,13 +196,15 @@ class NvpApiClientEventlet(object):
|
||||
self.login()
|
||||
self._doing_login_sem.release()
|
||||
else:
|
||||
lg.debug("Waiting for auth to complete")
|
||||
LOG.debug("Waiting for auth to complete")
|
||||
self._doing_login_sem.acquire()
|
||||
self._doing_login_sem.release()
|
||||
return self._cookie
|
||||
|
||||
def login(self):
|
||||
'''Issue login request and update authentication cookie.'''
|
||||
"""Issue login request and update authentication cookie."""
|
||||
request_eventlet = (quantum.plugins.nicira.nicira_nvp_plugin.
|
||||
api_client.request_eventlet)
|
||||
g = request_eventlet.NvpLoginRequestEventlet(
|
||||
self, self._user, self._password)
|
||||
g.start()
|
||||
@ -206,13 +212,13 @@ class NvpApiClientEventlet(object):
|
||||
|
||||
if ret:
|
||||
if isinstance(ret, Exception):
|
||||
lg.error('NvpApiClient: login error "%s"' % ret)
|
||||
LOG.error('NvpApiClient: login error "%s"' % ret)
|
||||
raise ret
|
||||
|
||||
self._cookie = None
|
||||
cookie = ret.getheader("Set-Cookie")
|
||||
if cookie:
|
||||
lg.debug("Saving new authentication cookie '%s'" % cookie)
|
||||
LOG.debug("Saving new authentication cookie '%s'" % cookie)
|
||||
self._cookie = cookie
|
||||
self._need_login = False
|
||||
|
||||
|
@ -12,8 +12,8 @@
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
|
||||
|
||||
import httplib
|
||||
|
||||
import mock
|
||||
|
||||
|
||||
|
@ -12,7 +12,6 @@
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
|
||||
|
||||
from abc import ABCMeta
|
||||
from abc import abstractmethod
|
||||
from abc import abstractproperty
|
||||
|
@ -12,22 +12,27 @@
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
|
||||
|
||||
import client_eventlet
|
||||
import eventlet
|
||||
import httplib
|
||||
import json
|
||||
import logging
|
||||
import time
|
||||
import urllib
|
||||
import urlparse
|
||||
import logging
|
||||
import request
|
||||
import time
|
||||
import json
|
||||
from common import _conn_str
|
||||
|
||||
import eventlet
|
||||
from eventlet import timeout
|
||||
|
||||
from quantum.plugins.nicira.nicira_nvp_plugin.api_client.common import (
|
||||
_conn_str,
|
||||
)
|
||||
import quantum.plugins.nicira.nicira_nvp_plugin.api_client.request as request
|
||||
import quantum.plugins.nicira.nicira_nvp_plugin.api_client.client_eventlet
|
||||
|
||||
|
||||
logging.basicConfig(level=logging.INFO)
|
||||
lg = logging.getLogger("nvp_api_request")
|
||||
LOG = logging.getLogger("nvp_api_request")
|
||||
|
||||
|
||||
USER_AGENT = "NVP gevent client/1.0"
|
||||
|
||||
# Default parameters.
|
||||
@ -57,7 +62,7 @@ class NvpApiRequestEventlet:
|
||||
httplib.NOT_FOUND,
|
||||
httplib.CONFLICT,
|
||||
httplib.INTERNAL_SERVER_ERROR,
|
||||
httplib.SERVICE_UNAVAILABLE
|
||||
httplib.SERVICE_UNAVAILABLE,
|
||||
]
|
||||
|
||||
API_REQUEST_POOL = eventlet.GreenPool(API_REQUEST_POOL_SIZE)
|
||||
@ -102,7 +107,7 @@ class NvpApiRequestEventlet:
|
||||
def join(self):
|
||||
if self._green_thread is not None:
|
||||
return self._green_thread.wait()
|
||||
lg.error('Joining on invalid green thread')
|
||||
LOG.error('Joining on invalid green thread')
|
||||
return Exception('Joining an invalid green thread')
|
||||
|
||||
def start(self):
|
||||
@ -124,7 +129,7 @@ class NvpApiRequestEventlet:
|
||||
with timeout.Timeout(self._request_timeout, False):
|
||||
return self._handle_request()
|
||||
|
||||
lg.info('Request timeout handling request.')
|
||||
LOG.info('Request timeout handling request.')
|
||||
self._request_error = Exception('Request timeout')
|
||||
return None
|
||||
else:
|
||||
@ -141,7 +146,7 @@ class NvpApiRequestEventlet:
|
||||
return error
|
||||
|
||||
url = self._url
|
||||
lg.info("Issuing request '%s'" % self._request_str(conn, url))
|
||||
LOG.info("Issuing request '%s'" % self._request_str(conn, url))
|
||||
issued_time = time.time()
|
||||
is_conn_error = False
|
||||
try:
|
||||
@ -159,27 +164,28 @@ class NvpApiRequestEventlet:
|
||||
try:
|
||||
conn.request(self._method, url, self._body, self._headers)
|
||||
except Exception, e:
|
||||
lg.info('_issue_request: conn.request() exception: %s' % e)
|
||||
LOG.info('_issue_request: conn.request() exception: %s' %
|
||||
e)
|
||||
raise e
|
||||
|
||||
response = conn.getresponse()
|
||||
response.body = response.read()
|
||||
response.headers = response.getheaders()
|
||||
lg.info("Request '%s' complete: %s (%0.2f seconds)"
|
||||
LOG.info("Request '%s' complete: %s (%0.2f seconds)"
|
||||
% (self._request_str(conn, url), response.status,
|
||||
time.time() - issued_time))
|
||||
if response.status not in [httplib.MOVED_PERMANENTLY,
|
||||
httplib.TEMPORARY_REDIRECT]:
|
||||
break
|
||||
elif redirects >= self._redirects:
|
||||
lg.warn("Maximum redirects exceeded, aborting request")
|
||||
LOG.warn("Maximum redirects exceeded, aborting request")
|
||||
break
|
||||
redirects += 1
|
||||
conn, url = self._redirect_params(conn, response.headers)
|
||||
if url is None:
|
||||
response.status = httplib.INTERNAL_SERVER_ERROR
|
||||
break
|
||||
lg.info("Redirecting request to: %s" % \
|
||||
LOG.info("Redirecting request to: %s" %
|
||||
self._request_str(conn, url))
|
||||
|
||||
# If we receive any of these responses, then our server did not
|
||||
@ -188,8 +194,8 @@ class NvpApiRequestEventlet:
|
||||
# is_conn_error == True which puts the conn on the back of the
|
||||
# client's priority queue.
|
||||
if response.status >= 500:
|
||||
lg.warn("API Request '%s %s' received: %s"
|
||||
% (self._method, self._url, response.status))
|
||||
LOG.warn("API Request '%s %s' received: %s" %
|
||||
(self._method, self._url, response.status))
|
||||
raise Exception('Server error return: %s' %
|
||||
response.status)
|
||||
return response
|
||||
@ -198,7 +204,7 @@ class NvpApiRequestEventlet:
|
||||
msg = "Invalid server response"
|
||||
else:
|
||||
msg = unicode(e)
|
||||
lg.warn("Request '%s' failed: %s (%0.2f seconds)"
|
||||
LOG.warn("Request '%s' failed: %s (%0.2f seconds)"
|
||||
% (self._request_str(conn, url), msg,
|
||||
time.time() - issued_time))
|
||||
self._request_error = e
|
||||
@ -214,7 +220,7 @@ class NvpApiRequestEventlet:
|
||||
url = value
|
||||
break
|
||||
if not url:
|
||||
lg.warn("Received redirect status without location header field")
|
||||
LOG.warn("Received redirect status without location header field")
|
||||
return (conn, None)
|
||||
# Accept location with the following format:
|
||||
# 1. /path, redirect to same node
|
||||
@ -230,15 +236,18 @@ class NvpApiRequestEventlet:
|
||||
url = result.path
|
||||
return (conn, url) # case 1
|
||||
else:
|
||||
lg.warn("Received invalid redirect location: %s" % url)
|
||||
LOG.warn("Received invalid redirect location: %s" % url)
|
||||
return (conn, None) # case 3
|
||||
elif result.scheme not in ["http", "https"] or not result.hostname:
|
||||
lg.warn("Received malformed redirect location: %s" % url)
|
||||
LOG.warn("Received malformed redirect location: %s" % url)
|
||||
return (conn, None) # case 3
|
||||
# case 2, redirect location includes a scheme
|
||||
# so setup a new connection and authenticate
|
||||
use_https = result.scheme == "https"
|
||||
api_providers = [(result.hostname, result.port, use_https)]
|
||||
client_eventlet = (
|
||||
quantum.plugins.nicira.nicira_nvp_plugin.api_client.client_eventlet
|
||||
)
|
||||
api_client = client_eventlet.NvpApiClientEventlet(
|
||||
api_providers, self._api_client.user, self._api_client.password,
|
||||
use_https=use_https)
|
||||
@ -268,7 +277,7 @@ class NvpApiRequestEventlet:
|
||||
|
||||
req = self.spawn(self._issue_request).wait()
|
||||
# automatically raises any exceptions returned.
|
||||
lg.debug('req: %s' % type(req))
|
||||
LOG.debug('req: %s' % type(req))
|
||||
|
||||
if isinstance(req, httplib.HTTPResponse):
|
||||
if (req.status == httplib.UNAUTHORIZED
|
||||
@ -278,15 +287,15 @@ class NvpApiRequestEventlet:
|
||||
continue
|
||||
# else fall through to return the error code
|
||||
|
||||
lg.debug("API Request '%s %s' complete: %s"
|
||||
% (self._method, self._url, req.status))
|
||||
LOG.debug("API Request '%s %s' complete: %s" %
|
||||
(self._method, self._url, req.status))
|
||||
self._request_error = None
|
||||
response = req
|
||||
else:
|
||||
lg.info('_handle_request: caught an error - %s' % req)
|
||||
LOG.info('_handle_request: caught an error - %s' % req)
|
||||
self._request_error = req
|
||||
|
||||
lg.debug('_handle_request: response - %s' % response)
|
||||
LOG.debug('_handle_request: response - %s' % response)
|
||||
return response
|
||||
|
||||
|
||||
@ -332,7 +341,7 @@ class NvpGetApiProvidersRequestEventlet(NvpApiRequestEventlet):
|
||||
ret.append(_provider_from_listen_addr(addr))
|
||||
return ret
|
||||
except Exception, e:
|
||||
lg.warn("Failed to parse API provider: %s" % e)
|
||||
LOG.warn("Failed to parse API provider: %s" % e)
|
||||
# intentionally fall through
|
||||
return None
|
||||
|
||||
|
@ -12,17 +12,16 @@
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
|
||||
from optparse import OptionParser
|
||||
|
||||
import gettext
|
||||
import logging
|
||||
from optparse import OptionParser
|
||||
import os
|
||||
import sys
|
||||
|
||||
gettext.install('nvp-plugin-cli', unicode=1)
|
||||
from quantum.plugins.nicira.nicira_nvp_plugin import nvplib
|
||||
from quantum.plugins.nicira.nicira_nvp_plugin.QuantumPlugin import (
|
||||
NvpPlugin as QuantumManager,
|
||||
)
|
||||
|
||||
from QuantumPlugin import NvpPlugin as QuantumManager
|
||||
import nvplib
|
||||
|
||||
logging.basicConfig(level=logging.INFO)
|
||||
LOG = logging.getLogger('nvp-plugin-cli')
|
||||
|
@ -14,10 +14,12 @@
|
||||
#
|
||||
# @author: Brad Hall, Nicira Networks, Inc.
|
||||
|
||||
from quantum.common import exceptions as exception
|
||||
import json
|
||||
import logging
|
||||
import NvpApiClient
|
||||
|
||||
from quantum.common import exceptions as exception
|
||||
from quantum.plugins.nicira.nicira_nvp_plugin import NvpApiClient
|
||||
|
||||
|
||||
LOG = logging.getLogger("nvplib")
|
||||
LOG.setLevel(logging.INFO)
|
||||
@ -36,7 +38,8 @@ def check_default_transport_zone(c):
|
||||
msg = []
|
||||
# This will throw an exception on failure and that's ok since it will
|
||||
# just propogate to the cli.
|
||||
resp = do_single_request("GET",
|
||||
resp = do_single_request(
|
||||
"GET",
|
||||
"/ws.v1/transport-zone?uuid=%s" % c.default_tz_uuid,
|
||||
controller=c)
|
||||
result = json.loads(resp)
|
||||
@ -78,8 +81,8 @@ def create_lswitch(controller, lswitch_obj):
|
||||
# Warn if no tenant is specified
|
||||
found = "os_tid" in [x["scope"] for x in lswitch_obj["tags"]]
|
||||
if not found:
|
||||
LOG.warn("No tenant-id tag specified in logical switch: %s" % (
|
||||
lswitch_obj))
|
||||
LOG.warn("No tenant-id tag specified in logical switch: %s" %
|
||||
lswitch_obj)
|
||||
uri = "/ws.v1/lswitch"
|
||||
try:
|
||||
resp_obj = do_single_request("POST", uri,
|
||||
@ -102,8 +105,8 @@ def update_network(controller, network, **kwargs):
|
||||
if "name" in kwargs:
|
||||
lswitch_obj["display_name"] = kwargs["name"]
|
||||
try:
|
||||
resp_obj = do_single_request("PUT", uri,
|
||||
json.dumps(lswitch_obj), controller=controller)
|
||||
resp_obj = do_single_request(
|
||||
"PUT", uri, json.dumps(lswitch_obj), controller=controller)
|
||||
except NvpApiClient.ResourceNotFound as e:
|
||||
LOG.error("Network not found, Error: %s" % str(e))
|
||||
raise exception.NetworkNotFound(net_id=network)
|
||||
@ -175,12 +178,15 @@ def create_network(tenant_id, net_name, **kwargs):
|
||||
transport_zone = kwargs.get("transport_zone",
|
||||
controller.default_tz_uuid)
|
||||
transport_type = kwargs.get("transport_type", "gre")
|
||||
lswitch_obj = {"display_name": net_name,
|
||||
lswitch_obj = {
|
||||
"display_name": net_name,
|
||||
"transport_zones": [
|
||||
{"zone_uuid": transport_zone,
|
||||
"transport_type": transport_type}
|
||||
{
|
||||
"zone_uuid": transport_zone,
|
||||
"transport_type": transport_type,
|
||||
},
|
||||
],
|
||||
"tags": [{"tag": tenant_id, "scope": "os_tid"}]
|
||||
"tags": [{"tag": tenant_id, "scope": "os_tid"}],
|
||||
}
|
||||
|
||||
net = create_lswitch(controller, lswitch_obj)
|
||||
@ -216,8 +222,8 @@ def get_port_stats(controller, network_id, port_id):
|
||||
|
||||
def check_port_state(state):
|
||||
if state not in ["ACTIVE", "DOWN"]:
|
||||
LOG.error("Invalid port state (ACTIVE and " \
|
||||
"DOWN are valid states): %s" % state)
|
||||
LOG.error("Invalid port state (ACTIVE and DOWN are valid states): %s" %
|
||||
state)
|
||||
raise exception.StateInvalid(port_state=state)
|
||||
|
||||
|
||||
@ -256,7 +262,8 @@ def delete_all_ports(controller, ls_uuid):
|
||||
controller=controller)
|
||||
res = json.loads(res)
|
||||
for r in res["results"]:
|
||||
do_single_request("DELETE",
|
||||
do_single_request(
|
||||
"DELETE",
|
||||
"/ws.v1/lswitch/%s/lport/%s" % (ls_uuid, r["uuid"]),
|
||||
controller=controller)
|
||||
|
||||
@ -308,8 +315,8 @@ def unplug_interface(controller, network, port):
|
||||
uri = "/ws.v1/lswitch/" + network + "/lport/" + port + "/attachment"
|
||||
lport_obj = {"type": "NoAttachment"}
|
||||
try:
|
||||
resp_obj = do_single_request("PUT",
|
||||
uri, json.dumps(lport_obj), controller=controller)
|
||||
resp_obj = do_single_request(
|
||||
"PUT", uri, json.dumps(lport_obj), controller=controller)
|
||||
except NvpApiClient.ResourceNotFound as e:
|
||||
LOG.error("Port or Network not found, Error: %s" % str(e))
|
||||
raise exception.PortNotFound(port_id=port, net_id=network)
|
||||
@ -332,8 +339,8 @@ def update_port(network, port_id, **params):
|
||||
|
||||
uri = "/ws.v1/lswitch/" + network + "/lport/" + port_id
|
||||
try:
|
||||
resp_obj = do_single_request("PUT", uri,
|
||||
json.dumps(lport_obj), controller=controller)
|
||||
resp_obj = do_single_request(
|
||||
"PUT", uri, json.dumps(lport_obj), controller=controller)
|
||||
except NvpApiClient.ResourceNotFound as e:
|
||||
LOG.error("Port or Network not found, Error: %s" % str(e))
|
||||
raise exception.PortNotFound(port_id=port_id, net_id=network)
|
||||
@ -361,8 +368,8 @@ def create_port(tenant, network, port_init_state, **params):
|
||||
|
||||
path = "/ws.v1/lswitch/" + ls_uuid + "/lport"
|
||||
try:
|
||||
resp_obj = do_single_request("POST", path,
|
||||
json.dumps(lport_obj), controller=controller)
|
||||
resp_obj = do_single_request(
|
||||
"POST", path, json.dumps(lport_obj), controller=controller)
|
||||
except NvpApiClient.ResourceNotFound as e:
|
||||
LOG.error("Network not found, Error: %s" % str(e))
|
||||
raise exception.NetworkNotFound(net_id=network)
|
||||
@ -387,7 +394,8 @@ def get_port_status(controller, lswitch_id, port_id):
|
||||
except NvpApiClient.NvpApiException as e:
|
||||
raise exception.QuantumException()
|
||||
try:
|
||||
r = do_single_request("GET",
|
||||
r = do_single_request(
|
||||
"GET",
|
||||
"/ws.v1/lswitch/%s/lport/%s/status" % (lswitch_id, port_id),
|
||||
controller=controller)
|
||||
r = json.loads(r)
|
||||
|
@ -17,8 +17,9 @@
|
||||
import logging
|
||||
import unittest
|
||||
|
||||
from nicira_nvp_plugin.QuantumPlugin import NvpPlugin
|
||||
from nicira_nvp_plugin import nvplib
|
||||
from quantum.plugins.nicira.nicira_nvp_plugin.QuantumPlugin import NvpPlugin
|
||||
from quantum.plugins.nicira.nicira_nvp_plugin import nvplib
|
||||
|
||||
|
||||
logging.basicConfig(level=logging.DEBUG)
|
||||
LOG = logging.getLogger("test_check")
|
||||
|
@ -12,12 +12,14 @@
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
|
||||
|
||||
import unittest
|
||||
import StringIO
|
||||
import ConfigParser
|
||||
from nicira_nvp_plugin.QuantumPlugin import parse_config
|
||||
from nicira_nvp_plugin.QuantumPlugin import NVPCluster
|
||||
import StringIO
|
||||
import unittest
|
||||
|
||||
from quantum.plugins.nicira.nicira_nvp_plugin.QuantumPlugin import (
|
||||
NVPCluster,
|
||||
parse_config,
|
||||
)
|
||||
|
||||
|
||||
class ConfigParserTest(unittest.TestCase):
|
||||
@ -46,7 +48,7 @@ class ConfigParserTest(unittest.TestCase):
|
||||
self.assertTrue(len(nvpc.controllers) == 3)
|
||||
|
||||
def test_old_config_parser_old_style(self):
|
||||
config = StringIO.StringIO('''
|
||||
config = StringIO.StringIO("""
|
||||
[DEFAULT]
|
||||
[NVP]
|
||||
DEFAULT_TZ_UUID = <default uuid>
|
||||
@ -54,7 +56,7 @@ NVP_CONTROLLER_IP = <controller ip>
|
||||
PORT = <port>
|
||||
USER = <user>
|
||||
PASSWORD = <pass>
|
||||
''')
|
||||
""")
|
||||
cp = ConfigParser.ConfigParser()
|
||||
cp.readfp(config)
|
||||
cluster1, plugin_config = parse_config(cp)
|
||||
@ -78,13 +80,13 @@ PASSWORD = <pass>
|
||||
cluster1.controllers[0]['redirects'] == 2)
|
||||
|
||||
def test_old_config_parser_new_style(self):
|
||||
config = StringIO.StringIO('''
|
||||
config = StringIO.StringIO("""
|
||||
[DEFAULT]
|
||||
[NVP]
|
||||
DEFAULT_TZ_UUID = <default uuid>
|
||||
NVP_CONTROLLER_CONNECTIONS = CONNECTION1
|
||||
CONNECTION1 = 10.0.0.1:4242:admin:admin:42:43:44:45
|
||||
''')
|
||||
""")
|
||||
cp = ConfigParser.ConfigParser()
|
||||
cp.readfp(config)
|
||||
cluster1, plugin_config = parse_config(cp)
|
||||
@ -108,7 +110,7 @@ CONNECTION1 = 10.0.0.1:4242:admin:admin:42:43:44:45
|
||||
cluster1.controllers[0]['redirects'] == 45)
|
||||
|
||||
def test_old_config_parser_both_styles(self):
|
||||
config = StringIO.StringIO('''
|
||||
config = StringIO.StringIO("""
|
||||
[DEFAULT]
|
||||
[NVP]
|
||||
NVP_CONTROLLER_IP = <controller ip>
|
||||
@ -118,7 +120,7 @@ PASSWORD = <pass>
|
||||
DEFAULT_TZ_UUID = <default uuid>
|
||||
NVP_CONTROLLER_CONNECTIONS = CONNECTION1
|
||||
CONNECTION1 = 10.0.0.1:4242:admin:admin:42:43:44:45
|
||||
''')
|
||||
""")
|
||||
cp = ConfigParser.ConfigParser()
|
||||
cp.readfp(config)
|
||||
cluster1, plugin_config = parse_config(cp)
|
||||
@ -142,7 +144,7 @@ CONNECTION1 = 10.0.0.1:4242:admin:admin:42:43:44:45
|
||||
cluster1.controllers[0]['redirects'] == 45)
|
||||
|
||||
def test_old_config_parser_both_styles(self):
|
||||
config = StringIO.StringIO('''
|
||||
config = StringIO.StringIO("""
|
||||
[DEFAULT]
|
||||
[NVP]
|
||||
NVP_CONTROLLER_IP = <controller ip>
|
||||
@ -152,7 +154,7 @@ PASSWORD = <pass>
|
||||
DEFAULT_TZ_UUID = <default uuid>
|
||||
NVP_CONTROLLER_CONNECTIONS = CONNECTION1
|
||||
CONNECTION1 = 10.0.0.1:4242:admin:admin:42:43:44:45
|
||||
''')
|
||||
""")
|
||||
cp = ConfigParser.ConfigParser()
|
||||
cp.readfp(config)
|
||||
cluster1, plugin_config = parse_config(cp)
|
||||
@ -176,7 +178,7 @@ CONNECTION1 = 10.0.0.1:4242:admin:admin:42:43:44:45
|
||||
cluster1.controllers[0]['redirects'] == 45)
|
||||
|
||||
def test_failover_time(self):
|
||||
config = StringIO.StringIO('''
|
||||
config = StringIO.StringIO("""
|
||||
[DEFAULT]
|
||||
[NVP]
|
||||
DEFAULT_TZ_UUID = <default uuid>
|
||||
@ -185,28 +187,28 @@ PORT = 443
|
||||
USER = admin
|
||||
PASSWORD = admin
|
||||
FAILOVER_TIME = 10
|
||||
''')
|
||||
""")
|
||||
cp = ConfigParser.ConfigParser()
|
||||
cp.readfp(config)
|
||||
cluster1, plugin_config = parse_config(cp)
|
||||
self.assertTrue(plugin_config['failover_time'] == '10')
|
||||
|
||||
def test_failover_time_new_style(self):
|
||||
config = StringIO.StringIO('''
|
||||
config = StringIO.StringIO("""
|
||||
[DEFAULT]
|
||||
[NVP]
|
||||
DEFAULT_TZ_UUID = <default uuid>
|
||||
NVP_CONTROLLER_CONNECTIONS = CONNECTION1
|
||||
CONNECTION1 = 10.0.0.1:4242:admin:admin:42:43:44:45
|
||||
FAILOVER_TIME = 10
|
||||
''')
|
||||
""")
|
||||
cp = ConfigParser.ConfigParser()
|
||||
cp.readfp(config)
|
||||
cluster1, plugin_config = parse_config(cp)
|
||||
self.assertTrue(plugin_config['failover_time'] == '10')
|
||||
|
||||
def test_concurrent_connections_time(self):
|
||||
config = StringIO.StringIO('''
|
||||
config = StringIO.StringIO("""
|
||||
[DEFAULT]
|
||||
[NVP]
|
||||
DEFAULT_TZ_UUID = <default uuid>
|
||||
@ -215,21 +217,21 @@ PORT = 443
|
||||
USER = admin
|
||||
PASSWORD = admin
|
||||
CONCURRENT_CONNECTIONS = 5
|
||||
''')
|
||||
""")
|
||||
cp = ConfigParser.ConfigParser()
|
||||
cp.readfp(config)
|
||||
cluster1, plugin_config = parse_config(cp)
|
||||
self.assertTrue(plugin_config['concurrent_connections'] == '5')
|
||||
|
||||
def test_concurrent_connections_time_new_style(self):
|
||||
config = StringIO.StringIO('''
|
||||
config = StringIO.StringIO("""
|
||||
[DEFAULT]
|
||||
[NVP]
|
||||
DEFAULT_TZ_UUID = <default uuid>
|
||||
NVP_CONTROLLER_CONNECTIONS = CONNECTION1
|
||||
CONNECTION1 = 10.0.0.1:4242:admin:admin:42:43:44:45
|
||||
CONCURRENT_CONNECTIONS = 5
|
||||
''')
|
||||
""")
|
||||
cp = ConfigParser.ConfigParser()
|
||||
cp.readfp(config)
|
||||
cluster1, plugin_config = parse_config(cp)
|
||||
|
@ -19,10 +19,14 @@ import json
|
||||
import logging
|
||||
import os
|
||||
import unittest
|
||||
|
||||
from quantum.common import exceptions as exception
|
||||
from nicira_nvp_plugin.QuantumPlugin import NvpPlugin
|
||||
from nicira_nvp_plugin import NvpApiClient
|
||||
from nicira_nvp_plugin import nvplib
|
||||
from quantum.plugins.nicira.nicira_nvp_plugin.QuantumPlugin import NvpPlugin
|
||||
from quantum.plugins.nicira.nicira_nvp_plugin import (
|
||||
NvpApiClient,
|
||||
nvplib,
|
||||
)
|
||||
|
||||
|
||||
logging.basicConfig(level=logging.DEBUG)
|
||||
LOG = logging.getLogger("test_network")
|
||||
|
@ -12,11 +12,10 @@
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
|
||||
|
||||
import httplib
|
||||
import unittest
|
||||
import unittest2 as unittest
|
||||
|
||||
import nicira_nvp_plugin.api_client.common as naco
|
||||
import quantum.plugins.nicira.nicira_nvp_plugin.api_client.common as naco
|
||||
|
||||
|
||||
class NvpApiCommonTest(unittest.TestCase):
|
||||
|
@ -15,10 +15,13 @@
|
||||
|
||||
import logging
|
||||
import unittest
|
||||
|
||||
from eventlet.green import urllib2
|
||||
|
||||
|
||||
logging.basicConfig(level=logging.DEBUG)
|
||||
lg = logging.getLogger("test_nvp_api_request")
|
||||
LOG = logging.getLogger("test_nvp_api_request")
|
||||
|
||||
|
||||
REQUEST_TIMEOUT = 1
|
||||
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user