Merge "Enable hacking H301 check"
This commit is contained in:
commit
667a694786
@ -26,7 +26,7 @@ from neutron.debug.debug_agent import NeutronDebugAgent
|
||||
from neutron.openstack.common import importutils
|
||||
from neutronclient.common import exceptions as exc
|
||||
from neutronclient.common import utils
|
||||
from neutronclient.shell import env, NeutronShell, NEUTRON_API_VERSION
|
||||
from neutronclient import shell
|
||||
|
||||
COMMAND_V2 = {
|
||||
'probe-create': utils.import_class(
|
||||
@ -46,7 +46,7 @@ COMMAND_V2 = {
|
||||
COMMANDS = {'2.0': COMMAND_V2}
|
||||
|
||||
|
||||
class NeutronDebugShell(NeutronShell):
|
||||
class NeutronDebugShell(shell.NeutronShell):
|
||||
def __init__(self, api_version):
|
||||
super(NeutronDebugShell, self).__init__(api_version)
|
||||
for k, v in COMMANDS[api_version].items():
|
||||
@ -56,7 +56,8 @@ class NeutronDebugShell(NeutronShell):
|
||||
parser = super(NeutronDebugShell, self).build_option_parser(
|
||||
description, version)
|
||||
default = (
|
||||
env('NEUTRON_TEST_CONFIG_FILE') or env('QUANTUM_TEST_CONFIG_FILE')
|
||||
shell.env('NEUTRON_TEST_CONFIG_FILE') or
|
||||
shell.env('QUANTUM_TEST_CONFIG_FILE')
|
||||
)
|
||||
parser.add_argument(
|
||||
'--config-file',
|
||||
@ -85,4 +86,5 @@ class NeutronDebugShell(NeutronShell):
|
||||
|
||||
|
||||
def main(argv=None):
|
||||
return NeutronDebugShell(NEUTRON_API_VERSION).run(argv or sys.argv[1:])
|
||||
return NeutronDebugShell(shell.NEUTRON_API_VERSION).run(
|
||||
argv or sys.argv[1:])
|
||||
|
@ -20,15 +20,14 @@ v2 Neutron Plug-in API specification.
|
||||
methods that needs to be implemented by a v2 Neutron Plug-in.
|
||||
"""
|
||||
|
||||
from abc import ABCMeta, abstractmethod
|
||||
|
||||
import abc
|
||||
import six
|
||||
|
||||
|
||||
@six.add_metaclass(ABCMeta)
|
||||
@six.add_metaclass(abc.ABCMeta)
|
||||
class NeutronPluginBaseV2(object):
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def create_subnet(self, context, subnet):
|
||||
"""Create a subnet.
|
||||
|
||||
@ -43,7 +42,7 @@ class NeutronPluginBaseV2(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def update_subnet(self, context, id, subnet):
|
||||
"""Update values of a subnet.
|
||||
|
||||
@ -57,7 +56,7 @@ class NeutronPluginBaseV2(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def get_subnet(self, context, id, fields=None):
|
||||
"""Retrieve a subnet.
|
||||
|
||||
@ -71,7 +70,7 @@ class NeutronPluginBaseV2(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def get_subnets(self, context, filters=None, fields=None,
|
||||
sorts=None, limit=None, marker=None, page_reverse=False):
|
||||
"""Retrieve a list of subnets.
|
||||
@ -119,7 +118,7 @@ class NeutronPluginBaseV2(object):
|
||||
"""
|
||||
raise NotImplementedError
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def delete_subnet(self, context, id):
|
||||
"""Delete a subnet.
|
||||
|
||||
@ -128,7 +127,7 @@ class NeutronPluginBaseV2(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def create_network(self, context, network):
|
||||
"""Create a network.
|
||||
|
||||
@ -144,7 +143,7 @@ class NeutronPluginBaseV2(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def update_network(self, context, id, network):
|
||||
"""Update values of a network.
|
||||
|
||||
@ -158,7 +157,7 @@ class NeutronPluginBaseV2(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def get_network(self, context, id, fields=None):
|
||||
"""Retrieve a network.
|
||||
|
||||
@ -172,7 +171,7 @@ class NeutronPluginBaseV2(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def get_networks(self, context, filters=None, fields=None,
|
||||
sorts=None, limit=None, marker=None, page_reverse=False):
|
||||
"""Retrieve a list of networks.
|
||||
@ -220,7 +219,7 @@ class NeutronPluginBaseV2(object):
|
||||
"""
|
||||
raise NotImplementedError
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def delete_network(self, context, id):
|
||||
"""Delete a network.
|
||||
|
||||
@ -229,7 +228,7 @@ class NeutronPluginBaseV2(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def create_port(self, context, port):
|
||||
"""Create a port.
|
||||
|
||||
@ -244,7 +243,7 @@ class NeutronPluginBaseV2(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def update_port(self, context, id, port):
|
||||
"""Update values of a port.
|
||||
|
||||
@ -257,7 +256,7 @@ class NeutronPluginBaseV2(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def get_port(self, context, id, fields=None):
|
||||
"""Retrieve a port.
|
||||
|
||||
@ -271,7 +270,7 @@ class NeutronPluginBaseV2(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def get_ports(self, context, filters=None, fields=None,
|
||||
sorts=None, limit=None, marker=None, page_reverse=False):
|
||||
"""Retrieve a list of ports.
|
||||
@ -316,7 +315,7 @@ class NeutronPluginBaseV2(object):
|
||||
"""
|
||||
raise NotImplementedError
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def delete_port(self, context, id):
|
||||
"""Delete a port.
|
||||
|
||||
|
@ -16,13 +16,12 @@
|
||||
#
|
||||
# @author: Sumit Naiksatam, Cisco Systems, Inc.
|
||||
|
||||
from abc import ABCMeta, abstractmethod
|
||||
import abc
|
||||
import inspect
|
||||
|
||||
import six
|
||||
|
||||
|
||||
@six.add_metaclass(ABCMeta)
|
||||
@six.add_metaclass(abc.ABCMeta)
|
||||
class L2DevicePluginBase(object):
|
||||
"""Base class for a device-specific plugin.
|
||||
|
||||
@ -31,7 +30,7 @@ class L2DevicePluginBase(object):
|
||||
the configuration on each device.
|
||||
"""
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def create_network(self, tenant_id, net_name, net_id, vlan_name, vlan_id,
|
||||
**kwargs):
|
||||
"""Create network.
|
||||
@ -41,7 +40,7 @@ class L2DevicePluginBase(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def delete_network(self, tenant_id, net_id, **kwargs):
|
||||
"""Delete network.
|
||||
|
||||
@ -50,7 +49,7 @@ class L2DevicePluginBase(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def update_network(self, tenant_id, net_id, name, **kwargs):
|
||||
"""Update network.
|
||||
|
||||
@ -59,7 +58,7 @@ class L2DevicePluginBase(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def create_port(self, tenant_id, net_id, port_state, port_id, **kwargs):
|
||||
"""Create port.
|
||||
|
||||
@ -68,7 +67,7 @@ class L2DevicePluginBase(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def delete_port(self, tenant_id, net_id, port_id, **kwargs):
|
||||
"""Delete port.
|
||||
|
||||
@ -77,7 +76,7 @@ class L2DevicePluginBase(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def update_port(self, tenant_id, net_id, port_id, **kwargs):
|
||||
"""Update port.
|
||||
|
||||
@ -86,7 +85,7 @@ class L2DevicePluginBase(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def plug_interface(self, tenant_id, net_id, port_id, remote_interface_id,
|
||||
**kwargs):
|
||||
"""Plug interface.
|
||||
@ -96,7 +95,7 @@ class L2DevicePluginBase(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def unplug_interface(self, tenant_id, net_id, port_id, **kwargs):
|
||||
"""Unplug interface.
|
||||
|
||||
|
@ -26,13 +26,12 @@ from neutron.db import external_net_db
|
||||
from neutron.db import extraroute_db
|
||||
from neutron.db import l3_db
|
||||
from neutron.db import models_v2
|
||||
from neutron.extensions.flavor import (FLAVOR_NETWORK, FLAVOR_ROUTER)
|
||||
from neutron.extensions import flavor as ext_flavor
|
||||
from neutron.openstack.common import importutils
|
||||
from neutron.openstack.common import log as logging
|
||||
from neutron.plugins.metaplugin.common import config # noqa
|
||||
from neutron.plugins.metaplugin import meta_db_v2
|
||||
from neutron.plugins.metaplugin.meta_models_v2 import (NetworkFlavor,
|
||||
RouterFlavor)
|
||||
from neutron.plugins.metaplugin import meta_models_v2
|
||||
|
||||
|
||||
LOG = logging.getLogger(__name__)
|
||||
@ -40,19 +39,21 @@ LOG = logging.getLogger(__name__)
|
||||
|
||||
# Hooks used to select records which belong a target plugin.
|
||||
def _meta_network_model_hook(context, original_model, query):
|
||||
return query.outerjoin(NetworkFlavor,
|
||||
NetworkFlavor.network_id == models_v2.Network.id)
|
||||
return query.outerjoin(meta_models_v2.NetworkFlavor,
|
||||
meta_models_v2.NetworkFlavor.network_id ==
|
||||
models_v2.Network.id)
|
||||
|
||||
|
||||
def _meta_port_model_hook(context, original_model, query):
|
||||
return query.join(NetworkFlavor,
|
||||
NetworkFlavor.network_id == models_v2.Port.network_id)
|
||||
return query.join(meta_models_v2.NetworkFlavor,
|
||||
meta_models_v2.NetworkFlavor.network_id ==
|
||||
models_v2.Port.network_id)
|
||||
|
||||
|
||||
def _meta_flavor_filter_hook(query, filters):
|
||||
if FLAVOR_NETWORK in filters:
|
||||
return query.filter(NetworkFlavor.flavor ==
|
||||
filters[FLAVOR_NETWORK][0])
|
||||
if ext_flavor.FLAVOR_NETWORK in filters:
|
||||
return query.filter(meta_models_v2.NetworkFlavor.flavor ==
|
||||
filters[ext_flavor.FLAVOR_NETWORK][0])
|
||||
return query
|
||||
|
||||
|
||||
@ -200,11 +201,11 @@ class MetaPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
||||
|
||||
def _extend_network_dict(self, context, network):
|
||||
flavor = self._get_flavor_by_network_id(context, network['id'])
|
||||
network[FLAVOR_NETWORK] = flavor
|
||||
network[ext_flavor.FLAVOR_NETWORK] = flavor
|
||||
|
||||
def create_network(self, context, network):
|
||||
n = network['network']
|
||||
flavor = n.get(FLAVOR_NETWORK)
|
||||
flavor = n.get(ext_flavor.FLAVOR_NETWORK)
|
||||
if str(flavor) not in self.plugins:
|
||||
flavor = self.default_flavor
|
||||
plugin = self._get_plugin(flavor)
|
||||
@ -238,7 +239,7 @@ class MetaPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
||||
plugin = self._get_plugin(flavor)
|
||||
net = plugin.get_network(context, id, fields)
|
||||
net['id'] = id
|
||||
if not fields or FLAVOR_NETWORK in fields:
|
||||
if not fields or ext_flavor.FLAVOR_NETWORK in fields:
|
||||
self._extend_network_dict(context, net)
|
||||
if fields and 'id' not in fields:
|
||||
del net['id']
|
||||
@ -247,8 +248,8 @@ class MetaPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
||||
def get_networks(self, context, filters=None, fields=None):
|
||||
nets = []
|
||||
for flavor, plugin in self.plugins.items():
|
||||
if (filters and FLAVOR_NETWORK in filters and
|
||||
not flavor in filters[FLAVOR_NETWORK]):
|
||||
if (filters and ext_flavor.FLAVOR_NETWORK in filters and
|
||||
not flavor in filters[ext_flavor.FLAVOR_NETWORK]):
|
||||
continue
|
||||
if filters:
|
||||
#NOTE: copy each time since a target plugin may modify
|
||||
@ -256,11 +257,11 @@ class MetaPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
||||
plugin_filters = filters.copy()
|
||||
else:
|
||||
plugin_filters = {}
|
||||
plugin_filters[FLAVOR_NETWORK] = [flavor]
|
||||
plugin_filters[ext_flavor.FLAVOR_NETWORK] = [flavor]
|
||||
plugin_nets = plugin.get_networks(context, plugin_filters, fields)
|
||||
for net in plugin_nets:
|
||||
if not fields or FLAVOR_NETWORK in fields:
|
||||
net[FLAVOR_NETWORK] = flavor
|
||||
if not fields or ext_flavor.FLAVOR_NETWORK in fields:
|
||||
net[ext_flavor.FLAVOR_NETWORK] = flavor
|
||||
nets.append(net)
|
||||
return nets
|
||||
|
||||
@ -316,7 +317,7 @@ class MetaPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
||||
plugin_filters = filters.copy()
|
||||
else:
|
||||
plugin_filters = {}
|
||||
plugin_filters[FLAVOR_NETWORK] = [flavor]
|
||||
plugin_filters[ext_flavor.FLAVOR_NETWORK] = [flavor]
|
||||
ports = plugin.get_ports(context, plugin_filters, fields)
|
||||
all_ports += ports
|
||||
return all_ports
|
||||
@ -343,11 +344,11 @@ class MetaPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
||||
|
||||
def _extend_router_dict(self, context, router):
|
||||
flavor = self._get_flavor_by_router_id(context, router['id'])
|
||||
router[FLAVOR_ROUTER] = flavor
|
||||
router[ext_flavor.FLAVOR_ROUTER] = flavor
|
||||
|
||||
def create_router(self, context, router):
|
||||
r = router['router']
|
||||
flavor = r.get(FLAVOR_ROUTER)
|
||||
flavor = r.get(ext_flavor.FLAVOR_ROUTER)
|
||||
if str(flavor) not in self.l3_plugins:
|
||||
flavor = self.default_l3_flavor
|
||||
plugin = self._get_l3_plugin(flavor)
|
||||
@ -381,20 +382,20 @@ class MetaPluginV2(db_base_plugin_v2.NeutronDbPluginV2,
|
||||
flavor = meta_db_v2.get_flavor_by_router(context.session, id)
|
||||
plugin = self._get_l3_plugin(flavor)
|
||||
router = plugin.get_router(context, id, fields)
|
||||
if not fields or FLAVOR_ROUTER in fields:
|
||||
if not fields or ext_flavor.FLAVOR_ROUTER in fields:
|
||||
self._extend_router_dict(context, router)
|
||||
return router
|
||||
|
||||
def get_routers_with_flavor(self, context, filters=None,
|
||||
fields=None):
|
||||
collection = self._model_query(context, l3_db.Router)
|
||||
r_model = RouterFlavor
|
||||
r_model = meta_models_v2.RouterFlavor
|
||||
collection = collection.join(r_model,
|
||||
l3_db.Router.id == r_model.router_id)
|
||||
if filters:
|
||||
for key, value in filters.iteritems():
|
||||
if key == FLAVOR_ROUTER:
|
||||
column = RouterFlavor.flavor
|
||||
if key == ext_flavor.FLAVOR_ROUTER:
|
||||
column = meta_models_v2.RouterFlavor.flavor
|
||||
else:
|
||||
column = getattr(l3_db.Router, key, None)
|
||||
if column:
|
||||
|
@ -13,8 +13,7 @@
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
|
||||
from abc import ABCMeta, abstractmethod, abstractproperty
|
||||
|
||||
import abc
|
||||
import six
|
||||
|
||||
# The following keys are used in the segment dictionaries passed via
|
||||
@ -28,7 +27,7 @@ PHYSICAL_NETWORK = 'physical_network'
|
||||
SEGMENTATION_ID = 'segmentation_id'
|
||||
|
||||
|
||||
@six.add_metaclass(ABCMeta)
|
||||
@six.add_metaclass(abc.ABCMeta)
|
||||
class TypeDriver(object):
|
||||
"""Define stable abstract interface for ML2 type drivers.
|
||||
|
||||
@ -46,7 +45,7 @@ class TypeDriver(object):
|
||||
either be excluded or stored as None.
|
||||
"""
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def get_type(self):
|
||||
"""Get driver's network type.
|
||||
|
||||
@ -54,7 +53,7 @@ class TypeDriver(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def initialize(self):
|
||||
"""Perform driver initialization.
|
||||
|
||||
@ -64,7 +63,7 @@ class TypeDriver(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def validate_provider_segment(self, segment):
|
||||
"""Validate attributes of a provider network segment.
|
||||
|
||||
@ -84,7 +83,7 @@ class TypeDriver(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def reserve_provider_segment(self, session, segment):
|
||||
"""Reserve resource associated with a provider network segment.
|
||||
|
||||
@ -98,7 +97,7 @@ class TypeDriver(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def allocate_tenant_segment(self, session):
|
||||
"""Allocate resource for a new tenant network segment.
|
||||
|
||||
@ -114,7 +113,7 @@ class TypeDriver(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def release_segment(self, session, segment):
|
||||
"""Release network segment.
|
||||
|
||||
@ -129,7 +128,7 @@ class TypeDriver(object):
|
||||
pass
|
||||
|
||||
|
||||
@six.add_metaclass(ABCMeta)
|
||||
@six.add_metaclass(abc.ABCMeta)
|
||||
class NetworkContext(object):
|
||||
"""Context passed to MechanismDrivers for changes to network resources.
|
||||
|
||||
@ -139,7 +138,7 @@ class NetworkContext(object):
|
||||
MechanismDrivers can freely access the same information.
|
||||
"""
|
||||
|
||||
@abstractproperty
|
||||
@abc.abstractproperty
|
||||
def current(self):
|
||||
"""Return the current state of the network.
|
||||
|
||||
@ -149,7 +148,7 @@ class NetworkContext(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractproperty
|
||||
@abc.abstractproperty
|
||||
def original(self):
|
||||
"""Return the original state of the network.
|
||||
|
||||
@ -159,13 +158,13 @@ class NetworkContext(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractproperty
|
||||
@abc.abstractproperty
|
||||
def network_segments(self):
|
||||
"""Return the segments associated with this network resource."""
|
||||
pass
|
||||
|
||||
|
||||
@six.add_metaclass(ABCMeta)
|
||||
@six.add_metaclass(abc.ABCMeta)
|
||||
class SubnetContext(object):
|
||||
"""Context passed to MechanismDrivers for changes to subnet resources.
|
||||
|
||||
@ -175,7 +174,7 @@ class SubnetContext(object):
|
||||
MechanismDrivers can freely access the same information.
|
||||
"""
|
||||
|
||||
@abstractproperty
|
||||
@abc.abstractproperty
|
||||
def current(self):
|
||||
"""Return the current state of the subnet.
|
||||
|
||||
@ -185,7 +184,7 @@ class SubnetContext(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractproperty
|
||||
@abc.abstractproperty
|
||||
def original(self):
|
||||
"""Return the original state of the subnet.
|
||||
|
||||
@ -196,7 +195,7 @@ class SubnetContext(object):
|
||||
pass
|
||||
|
||||
|
||||
@six.add_metaclass(ABCMeta)
|
||||
@six.add_metaclass(abc.ABCMeta)
|
||||
class PortContext(object):
|
||||
"""Context passed to MechanismDrivers for changes to port resources.
|
||||
|
||||
@ -206,7 +205,7 @@ class PortContext(object):
|
||||
freely access the same information.
|
||||
"""
|
||||
|
||||
@abstractproperty
|
||||
@abc.abstractproperty
|
||||
def current(self):
|
||||
"""Return the current state of the port.
|
||||
|
||||
@ -216,7 +215,7 @@ class PortContext(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractproperty
|
||||
@abc.abstractproperty
|
||||
def original(self):
|
||||
"""Return the original state of the port.
|
||||
|
||||
@ -226,17 +225,17 @@ class PortContext(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractproperty
|
||||
@abc.abstractproperty
|
||||
def network(self):
|
||||
"""Return the NetworkContext associated with this port."""
|
||||
pass
|
||||
|
||||
@abstractproperty
|
||||
@abc.abstractproperty
|
||||
def bound_segment(self):
|
||||
"""Return the currently bound segment dictionary."""
|
||||
pass
|
||||
|
||||
@abstractproperty
|
||||
@abc.abstractproperty
|
||||
def original_bound_segment(self):
|
||||
"""Return the original bound segment dictionary.
|
||||
|
||||
@ -246,12 +245,12 @@ class PortContext(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractproperty
|
||||
@abc.abstractproperty
|
||||
def bound_driver(self):
|
||||
"""Return the currently bound mechanism driver name."""
|
||||
pass
|
||||
|
||||
@abstractproperty
|
||||
@abc.abstractproperty
|
||||
def original_bound_driver(self):
|
||||
"""Return the original bound mechanism driver name.
|
||||
|
||||
@ -261,7 +260,7 @@ class PortContext(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def host_agents(self, agent_type):
|
||||
"""Get agents of the specified type on port's host.
|
||||
|
||||
@ -270,7 +269,7 @@ class PortContext(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def set_binding(self, segment_id, vif_type, vif_details):
|
||||
"""Set the binding for the port.
|
||||
|
||||
@ -285,7 +284,7 @@ class PortContext(object):
|
||||
pass
|
||||
|
||||
|
||||
@six.add_metaclass(ABCMeta)
|
||||
@six.add_metaclass(abc.ABCMeta)
|
||||
class MechanismDriver(object):
|
||||
"""Define stable abstract interface for ML2 mechanism drivers.
|
||||
|
||||
@ -307,7 +306,7 @@ class MechanismDriver(object):
|
||||
methods that are part of the database transaction.
|
||||
"""
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def initialize(self):
|
||||
"""Perform driver initialization.
|
||||
|
||||
|
@ -13,8 +13,7 @@
|
||||
# License for the specific language governing permissions and limitations
|
||||
# under the License.
|
||||
|
||||
from abc import ABCMeta, abstractmethod
|
||||
|
||||
import abc
|
||||
import six
|
||||
|
||||
from neutron.extensions import portbindings
|
||||
@ -24,7 +23,7 @@ from neutron.plugins.ml2 import driver_api as api
|
||||
LOG = log.getLogger(__name__)
|
||||
|
||||
|
||||
@six.add_metaclass(ABCMeta)
|
||||
@six.add_metaclass(abc.ABCMeta)
|
||||
class AgentMechanismDriverBase(api.MechanismDriver):
|
||||
"""Base class for drivers that attach to networks using an L2 agent.
|
||||
|
||||
@ -74,7 +73,7 @@ class AgentMechanismDriverBase(api.MechanismDriver):
|
||||
LOG.warning(_("Attempting to bind with dead agent: %s"),
|
||||
agent)
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def try_to_bind_segment_for_agent(self, context, segment, agent):
|
||||
"""Try to bind with segment for agent.
|
||||
|
||||
@ -94,7 +93,7 @@ class AgentMechanismDriverBase(api.MechanismDriver):
|
||||
"""
|
||||
|
||||
|
||||
@six.add_metaclass(ABCMeta)
|
||||
@six.add_metaclass(abc.ABCMeta)
|
||||
class SimpleAgentMechanismDriverBase(AgentMechanismDriverBase):
|
||||
"""Base class for simple drivers using an L2 agent.
|
||||
|
||||
@ -134,7 +133,7 @@ class SimpleAgentMechanismDriverBase(AgentMechanismDriverBase):
|
||||
else:
|
||||
return False
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def check_segment_for_agent(self, segment, agent):
|
||||
"""Check if segment can be bound for agent.
|
||||
|
||||
|
@ -12,8 +12,7 @@
|
||||
# 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, abstractmethod
|
||||
|
||||
import abc
|
||||
import six
|
||||
|
||||
from neutron.common import exceptions as exc
|
||||
@ -26,7 +25,7 @@ LOG = log.getLogger(__name__)
|
||||
TUNNEL = 'tunnel'
|
||||
|
||||
|
||||
@six.add_metaclass(ABCMeta)
|
||||
@six.add_metaclass(abc.ABCMeta)
|
||||
class TunnelTypeDriver(api.TypeDriver):
|
||||
"""Define stable abstract interface for ML2 type drivers.
|
||||
|
||||
@ -34,7 +33,7 @@ class TunnelTypeDriver(api.TypeDriver):
|
||||
methods to manage these endpoints.
|
||||
"""
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def add_endpoint(self, ip):
|
||||
"""Register the endpoint in the type_driver database.
|
||||
|
||||
@ -42,7 +41,7 @@ class TunnelTypeDriver(api.TypeDriver):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def get_endpoints(self):
|
||||
"""Get every endpoint managed by the type_driver
|
||||
|
||||
|
@ -16,12 +16,11 @@
|
||||
# @author: Ryota MIBU
|
||||
# @author: Akihiro MOTOKI
|
||||
|
||||
from abc import ABCMeta, abstractmethod
|
||||
|
||||
import abc
|
||||
import six
|
||||
|
||||
|
||||
@six.add_metaclass(ABCMeta)
|
||||
@six.add_metaclass(abc.ABCMeta)
|
||||
class OFCDriverBase(object):
|
||||
"""OpenFlow Controller (OFC) Driver Specification.
|
||||
|
||||
@ -29,7 +28,7 @@ class OFCDriverBase(object):
|
||||
It would be better that other methods like update_* are implemented.
|
||||
"""
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def create_tenant(self, description, tenant_id=None):
|
||||
"""Create a new tenant at OpenFlow Controller.
|
||||
|
||||
@ -41,7 +40,7 @@ class OFCDriverBase(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def delete_tenant(self, ofc_tenant_id):
|
||||
"""Delete a tenant at OpenFlow Controller.
|
||||
|
||||
@ -49,7 +48,7 @@ class OFCDriverBase(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def create_network(self, ofc_tenant_id, description, network_id=None):
|
||||
"""Create a new network on specified OFC tenant at OpenFlow Controller.
|
||||
|
||||
@ -64,7 +63,7 @@ class OFCDriverBase(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def delete_network(self, ofc_network_id):
|
||||
"""Delete a netwrok at OpenFlow Controller.
|
||||
|
||||
@ -72,7 +71,7 @@ class OFCDriverBase(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def create_port(self, ofc_network_id, portinfo,
|
||||
port_id=None, filters=None):
|
||||
"""Create a new port on specified network at OFC.
|
||||
@ -97,7 +96,7 @@ class OFCDriverBase(object):
|
||||
"""
|
||||
pass
|
||||
|
||||
@abstractmethod
|
||||
@abc.abstractmethod
|
||||
def delete_port(self, ofc_port_id):
|
||||
"""Delete a port at OpenFlow Controller.
|
||||
|
||||
|
@ -27,7 +27,7 @@ from neutron import context
|
||||
from neutron.db import api as db
|
||||
from neutron.db import db_base_plugin_v2
|
||||
from neutron.db import models_v2
|
||||
from neutron.extensions.flavor import (FLAVOR_NETWORK, FLAVOR_ROUTER)
|
||||
from neutron.extensions import flavor as ext_flavor
|
||||
from neutron.openstack.common import uuidutils
|
||||
from neutron.plugins.metaplugin.meta_neutron_plugin import (
|
||||
FaildToAddFlavorBinding)
|
||||
@ -130,7 +130,7 @@ class MetaNeutronPluginV2Test(base.BaseTestCase):
|
||||
'shared': False,
|
||||
'router:external': [],
|
||||
'tenant_id': self.fake_tenant_id,
|
||||
FLAVOR_NETWORK: flavor}}
|
||||
ext_flavor.FLAVOR_NETWORK: flavor}}
|
||||
return data
|
||||
|
||||
def _fake_port(self, net_id):
|
||||
@ -162,22 +162,22 @@ class MetaNeutronPluginV2Test(base.BaseTestCase):
|
||||
def _fake_router(self, flavor):
|
||||
data = {'router': {'name': flavor, 'admin_state_up': True,
|
||||
'tenant_id': self.fake_tenant_id,
|
||||
FLAVOR_ROUTER: flavor,
|
||||
ext_flavor.FLAVOR_ROUTER: flavor,
|
||||
'external_gateway_info': None}}
|
||||
return data
|
||||
|
||||
def test_create_delete_network(self):
|
||||
network1 = self._fake_network('fake1')
|
||||
ret1 = self.plugin.create_network(self.context, network1)
|
||||
self.assertEqual('fake1', ret1[FLAVOR_NETWORK])
|
||||
self.assertEqual('fake1', ret1[ext_flavor.FLAVOR_NETWORK])
|
||||
|
||||
network2 = self._fake_network('fake2')
|
||||
ret2 = self.plugin.create_network(self.context, network2)
|
||||
self.assertEqual('fake2', ret2[FLAVOR_NETWORK])
|
||||
self.assertEqual('fake2', ret2[ext_flavor.FLAVOR_NETWORK])
|
||||
|
||||
network3 = self._fake_network('proxy')
|
||||
ret3 = self.plugin.create_network(self.context, network3)
|
||||
self.assertEqual('proxy', ret3[FLAVOR_NETWORK])
|
||||
self.assertEqual('proxy', ret3[ext_flavor.FLAVOR_NETWORK])
|
||||
|
||||
db_ret1 = self.plugin.get_network(self.context, ret1['id'])
|
||||
self.assertEqual('fake1', db_ret1['name'])
|
||||
@ -191,8 +191,9 @@ class MetaNeutronPluginV2Test(base.BaseTestCase):
|
||||
db_ret4 = self.plugin.get_networks(self.context)
|
||||
self.assertEqual(3, len(db_ret4))
|
||||
|
||||
db_ret5 = self.plugin.get_networks(self.context,
|
||||
{FLAVOR_NETWORK: ['fake1']})
|
||||
db_ret5 = self.plugin.get_networks(
|
||||
self.context,
|
||||
{ext_flavor.FLAVOR_NETWORK: ['fake1']})
|
||||
self.assertEqual(1, len(db_ret5))
|
||||
self.assertEqual('fake1', db_ret5[0]['name'])
|
||||
self.plugin.delete_network(self.context, ret1['id'])
|
||||
@ -307,14 +308,14 @@ class MetaNeutronPluginV2Test(base.BaseTestCase):
|
||||
router2 = self._fake_router('fake2')
|
||||
router_ret2 = self.plugin.create_router(self.context, router2)
|
||||
|
||||
self.assertEqual('fake1', router_ret1[FLAVOR_ROUTER])
|
||||
self.assertEqual('fake2', router_ret2[FLAVOR_ROUTER])
|
||||
self.assertEqual('fake1', router_ret1[ext_flavor.FLAVOR_ROUTER])
|
||||
self.assertEqual('fake2', router_ret2[ext_flavor.FLAVOR_ROUTER])
|
||||
|
||||
router_in_db1 = self.plugin.get_router(self.context, router_ret1['id'])
|
||||
router_in_db2 = self.plugin.get_router(self.context, router_ret2['id'])
|
||||
|
||||
self.assertEqual('fake1', router_in_db1[FLAVOR_ROUTER])
|
||||
self.assertEqual('fake2', router_in_db2[FLAVOR_ROUTER])
|
||||
self.assertEqual('fake1', router_in_db1[ext_flavor.FLAVOR_ROUTER])
|
||||
self.assertEqual('fake2', router_in_db2[ext_flavor.FLAVOR_ROUTER])
|
||||
|
||||
self.plugin.delete_router(self.context, router_ret1['id'])
|
||||
self.plugin.delete_router(self.context, router_ret2['id'])
|
||||
|
@ -15,9 +15,8 @@
|
||||
import mock
|
||||
import requests
|
||||
|
||||
from neutron.services.loadbalancer.drivers.netscaler import (
|
||||
ncc_client, netscaler_driver
|
||||
)
|
||||
from neutron.services.loadbalancer.drivers.netscaler import ncc_client
|
||||
from neutron.services.loadbalancer.drivers.netscaler import netscaler_driver
|
||||
from neutron.tests.unit import testlib_api
|
||||
|
||||
NCC_CLIENT_CLASS = ('neutron.services.loadbalancer.drivers'
|
||||
|
3
tox.ini
3
tox.ini
@ -41,10 +41,9 @@ commands = {posargs}
|
||||
# E711/E712 comparison to False should be 'if cond is False:' or 'if not cond:'
|
||||
# query = query.filter(Component.disabled == False)
|
||||
# E125 continuation line does not distinguish itself from next logical line
|
||||
# H301 one import per line
|
||||
# H302 import only modules
|
||||
# TODO(marun) H404 multi line docstring should start with a summary
|
||||
ignore = E711,E712,E125,H301,H302,H404
|
||||
ignore = E711,E712,E125,H302,H404
|
||||
show-source = true
|
||||
builtins = _
|
||||
exclude=.venv,.git,.tox,dist,doc,*openstack/common*,*lib/python*,*egg,tools
|
||||
|
Loading…
x
Reference in New Issue
Block a user