Remove neutron-lib from the dependencies

The patch removes the neutron-lib from the dependencies. We do not
want/need the consumers of this library to pull in all of the
neutron-lib dependencies.

The patch adds the following:
1. callback to bind is_attr_set - set_is_attr_callback
2. A new exception NsxLibInvalidInput - this is raised when inputs
   are invalid.

Change-Id: Ia8ec71dee2d5de921700a9b4fd7e789d2aed4679
This commit is contained in:
Gary Kotton 2017-10-27 22:22:11 +03:00
parent 82ce3daf8c
commit cdcb5963da
11 changed files with 122 additions and 27 deletions

View File

@ -9,7 +9,6 @@ eventlet!=0.18.3,!=0.20.1,<0.21.0,>=0.18.2 # MIT
netaddr>=0.7.18 # BSD netaddr>=0.7.18 # BSD
tenacity>=3.2.1 # Apache-2.0 tenacity>=3.2.1 # Apache-2.0
six>=1.9.0 # MIT six>=1.9.0 # MIT
neutron-lib>=1.11.0 # Apache-2.0
oslo.i18n>=3.15.3 # Apache-2.0 oslo.i18n>=3.15.3 # Apache-2.0
oslo.log>=3.30.0 # Apache-2.0 oslo.log>=3.30.0 # Apache-2.0
oslo.serialization!=2.19.1,>=2.18.0 # Apache-2.0 oslo.serialization!=2.19.1,>=2.18.0 # Apache-2.0

View File

@ -91,9 +91,7 @@ exclude = build,dist
import-order-style = pep8 import-order-style = pep8
[hacking] [hacking]
import_exceptions = vmware_nsxlib._i18n, import_exceptions = vmware_nsxlib._i18n
vmware_nsxlib_tempest._i18n
local-check-factory = neutron_lib.hacking.checks.factory
[testenv:genconfig] [testenv:genconfig]
commands = commands =

View File

@ -15,7 +15,6 @@
# #
import os import os
from neutron_lib import exceptions
from OpenSSL import crypto from OpenSSL import crypto
from oslo_serialization import jsonutils from oslo_serialization import jsonutils
@ -291,6 +290,6 @@ class NsxV3ClientCertificateTestCase(nsxlib_testcase.NsxClientTestCase):
'subject': {}}] 'subject': {}}]
for args in bad_cert_values: for args in bad_cert_values:
self.assertRaises(exceptions.InvalidInput, self.assertRaises(nsxlib_exc.NsxLibInvalidInput,
client_cert.generate_self_signed_cert_pair, client_cert.generate_self_signed_cert_pair,
**args) **args)

View File

@ -13,9 +13,8 @@
# See the License for the specific language governing permissions and # See the License for the specific language governing permissions and
# limitations under the License. # limitations under the License.
from neutron_lib import exceptions as n_exc
from vmware_nsxlib.tests.unit.v3 import nsxlib_testcase from vmware_nsxlib.tests.unit.v3 import nsxlib_testcase
from vmware_nsxlib.v3 import exceptions
from vmware_nsxlib.v3 import nsx_constants from vmware_nsxlib.v3 import nsx_constants
from vmware_nsxlib.v3 import utils from vmware_nsxlib.v3 import utils
@ -50,7 +49,7 @@ class TestNsxV3Utils(nsxlib_testcase.NsxClientTestCase):
self.assertEqual(expected, result) self.assertEqual(expected, result)
def test_build_v3_tags_payload_invalid_length(self): def test_build_v3_tags_payload_invalid_length(self):
self.assertRaises(n_exc.InvalidInput, self.assertRaises(exceptions.NsxLibInvalidInput,
self.nsxlib.build_v3_tags_payload, self.nsxlib.build_v3_tags_payload,
{'id': 'fake_id', {'id': 'fake_id',
'project_id': 'fake_proj_id'}, 'project_id': 'fake_proj_id'},
@ -115,7 +114,7 @@ class TestNsxV3Utils(nsxlib_testcase.NsxClientTestCase):
self.assertEqual(expected, result) self.assertEqual(expected, result)
def test_add_v3_tag_invalid_scope_length(self): def test_add_v3_tag_invalid_scope_length(self):
self.assertRaises(n_exc.InvalidInput, self.assertRaises(exceptions.NsxLibInvalidInput,
utils.add_v3_tag, utils.add_v3_tag,
[], [],
'fake-scope-name-is-far-too-long', 'fake-scope-name-is-far-too-long',
@ -242,13 +241,13 @@ class TestNsxV3Utils(nsxlib_testcase.NsxClientTestCase):
max_retries = 5 max_retries = 5
total_count = {'val': 0} total_count = {'val': 0}
@utils.retry_upon_exception(n_exc.InvalidInput, @utils.retry_upon_exception(exceptions.NsxLibInvalidInput,
max_attempts=max_retries) max_attempts=max_retries)
def func_to_fail(x): def func_to_fail(x):
total_count['val'] = total_count['val'] + 1 total_count['val'] = total_count['val'] + 1
raise n_exc.InvalidInput() raise exceptions.NsxLibInvalidInput(error_message='foo')
self.assertRaises(n_exc.InvalidInput, func_to_fail, 99) self.assertRaises(exceptions.NsxLibInvalidInput, func_to_fail, 99)
self.assertEqual(max_retries, total_count['val']) self.assertEqual(max_retries, total_count['val'])

View File

@ -17,7 +17,6 @@ import datetime
from time import time from time import time
import uuid import uuid
from neutron_lib import exceptions
from OpenSSL import crypto from OpenSSL import crypto
from oslo_log import log from oslo_log import log
@ -39,7 +38,7 @@ def validate_cert_params(key_size, valid_for_days,
expected_key_sizes = (2048, 4096) expected_key_sizes = (2048, 4096)
if key_size not in expected_key_sizes: if key_size not in expected_key_sizes:
raise exceptions.InvalidInput( raise nsxlib_exceptions.NsxLibInvalidInput(
error_message=_('Invalid key size %(value)d' error_message=_('Invalid key size %(value)d'
'(must be one of %(list)s)') % '(must be one of %(list)s)') %
{'value': key_size, {'value': key_size,
@ -47,7 +46,7 @@ def validate_cert_params(key_size, valid_for_days,
expected_signature_algs = ('sha224', 'sha256') expected_signature_algs = ('sha224', 'sha256')
if signature_alg not in expected_signature_algs: if signature_alg not in expected_signature_algs:
raise exceptions.InvalidInput( raise nsxlib_exceptions.NsxLibInvalidInput(
error_message=_('Invalid signature algorithm %(value)s' error_message=_('Invalid signature algorithm %(value)s'
'(must be one of %(list)s)') % '(must be one of %(list)s)') %
{'value': signature_alg, {'value': signature_alg,
@ -55,7 +54,7 @@ def validate_cert_params(key_size, valid_for_days,
if (CERT_SUBJECT_COUNTRY in subject and if (CERT_SUBJECT_COUNTRY in subject and
(len(subject[CERT_SUBJECT_COUNTRY]) != 2)): (len(subject[CERT_SUBJECT_COUNTRY]) != 2)):
raise exceptions.InvalidInput( raise nsxlib_exceptions.NsxLibInvalidInput(
error_message=_('Invalid country %s: ' error_message=_('Invalid country %s: '
'must be exactly 2 characters') % 'must be exactly 2 characters') %
subject[CERT_SUBJECT_COUNTRY]) subject[CERT_SUBJECT_COUNTRY])
@ -68,7 +67,7 @@ def validate_cert_params(key_size, valid_for_days,
for field, max_len in max_len_constraints.items(): for field, max_len in max_len_constraints.items():
if field in subject and (len(subject[field]) > max_len): if field in subject and (len(subject[field]) > max_len):
raise exceptions.InvalidInput( raise nsxlib_exceptions.NsxLibInvalidInput(
error_message=_('Invalid %(field)s [%(value)s]: ' error_message=_('Invalid %(field)s [%(value)s]: '
'must not exceed %(max)d characters') % 'must not exceed %(max)d characters') %
{'field': field, {'field': field,

View File

@ -0,0 +1,88 @@
# Copyright 2016 VMware, Inc.
# All Rights Reserved
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
IPv4_ANY = '0.0.0.0/0'
# Protocol names and numbers for Security Groups/Firewalls
PROTO_NAME_AH = 'ah'
PROTO_NAME_DCCP = 'dccp'
PROTO_NAME_EGP = 'egp'
PROTO_NAME_ESP = 'esp'
PROTO_NAME_GRE = 'gre'
PROTO_NAME_ICMP = 'icmp'
PROTO_NAME_IGMP = 'igmp'
PROTO_NAME_IPV6_ENCAP = 'ipv6-encap'
PROTO_NAME_IPV6_FRAG = 'ipv6-frag'
PROTO_NAME_IPV6_ICMP = 'ipv6-icmp'
# For backward-compatibility of security group rule API, we keep the old value
# for IPv6 ICMP. It should be clean up in the future.
PROTO_NAME_IPV6_ICMP_LEGACY = 'icmpv6'
PROTO_NAME_IPV6_NONXT = 'ipv6-nonxt'
PROTO_NAME_IPV6_OPTS = 'ipv6-opts'
PROTO_NAME_IPV6_ROUTE = 'ipv6-route'
PROTO_NAME_OSPF = 'ospf'
PROTO_NAME_PGM = 'pgm'
PROTO_NAME_RSVP = 'rsvp'
PROTO_NAME_SCTP = 'sctp'
PROTO_NAME_TCP = 'tcp'
PROTO_NAME_UDP = 'udp'
PROTO_NAME_UDPLITE = 'udplite'
PROTO_NAME_VRRP = 'vrrp'
PROTO_NUM_AH = 51
PROTO_NUM_DCCP = 33
PROTO_NUM_EGP = 8
PROTO_NUM_ESP = 50
PROTO_NUM_GRE = 47
PROTO_NUM_ICMP = 1
PROTO_NUM_IGMP = 2
PROTO_NUM_IPV6_ENCAP = 41
PROTO_NUM_IPV6_FRAG = 44
PROTO_NUM_IPV6_ICMP = 58
PROTO_NUM_IPV6_NONXT = 59
PROTO_NUM_IPV6_OPTS = 60
PROTO_NUM_IPV6_ROUTE = 43
PROTO_NUM_OSPF = 89
PROTO_NUM_PGM = 113
PROTO_NUM_RSVP = 46
PROTO_NUM_SCTP = 132
PROTO_NUM_TCP = 6
PROTO_NUM_UDP = 17
PROTO_NUM_UDPLITE = 136
PROTO_NUM_VRRP = 112
IP_PROTOCOL_MAP = {PROTO_NAME_AH: PROTO_NUM_AH,
PROTO_NAME_DCCP: PROTO_NUM_DCCP,
PROTO_NAME_EGP: PROTO_NUM_EGP,
PROTO_NAME_ESP: PROTO_NUM_ESP,
PROTO_NAME_GRE: PROTO_NUM_GRE,
PROTO_NAME_ICMP: PROTO_NUM_ICMP,
PROTO_NAME_IGMP: PROTO_NUM_IGMP,
PROTO_NAME_IPV6_ENCAP: PROTO_NUM_IPV6_ENCAP,
PROTO_NAME_IPV6_FRAG: PROTO_NUM_IPV6_FRAG,
PROTO_NAME_IPV6_ICMP: PROTO_NUM_IPV6_ICMP,
# For backward-compatibility of security group rule API
PROTO_NAME_IPV6_ICMP_LEGACY: PROTO_NUM_IPV6_ICMP,
PROTO_NAME_IPV6_NONXT: PROTO_NUM_IPV6_NONXT,
PROTO_NAME_IPV6_OPTS: PROTO_NUM_IPV6_OPTS,
PROTO_NAME_IPV6_ROUTE: PROTO_NUM_IPV6_ROUTE,
PROTO_NAME_OSPF: PROTO_NUM_OSPF,
PROTO_NAME_PGM: PROTO_NUM_PGM,
PROTO_NAME_RSVP: PROTO_NUM_RSVP,
PROTO_NAME_SCTP: PROTO_NUM_SCTP,
PROTO_NAME_TCP: PROTO_NUM_TCP,
PROTO_NAME_UDP: PROTO_NUM_UDP,
PROTO_NAME_UDPLITE: PROTO_NUM_UDPLITE,
PROTO_NAME_VRRP: PROTO_NUM_VRRP}

View File

@ -63,6 +63,10 @@ class CertificateError(NsxLibException):
message = _("Certificate error: %(msg)s") message = _("Certificate error: %(msg)s")
class NsxLibInvalidInput(NsxLibException):
message = _("Invalid input for operation: %(error_message)s.")
class ManagerError(NsxLibException): class ManagerError(NsxLibException):
message = _("Unexpected error from backend manager (%(manager)s) " message = _("Unexpected error from backend manager (%(manager)s) "
"for %(operation)s %(details)s") "for %(operation)s %(details)s")

View File

@ -14,9 +14,8 @@
# under the License. # under the License.
import netaddr import netaddr
from neutron_lib.api import validators
from neutron_lib import constants
from vmware_nsxlib.v3 import constants
from vmware_nsxlib.v3 import utils from vmware_nsxlib.v3 import utils
@ -49,14 +48,14 @@ class NsxLibNativeDhcp(utils.NsxLibApiBase):
server_ip = "%s/%u" % (port['fixed_ips'][0]['ip_address'], server_ip = "%s/%u" % (port['fixed_ips'][0]['ip_address'],
netaddr.IPNetwork(subnet['cidr']).prefixlen) netaddr.IPNetwork(subnet['cidr']).prefixlen)
dns_nameservers = subnet['dns_nameservers'] dns_nameservers = subnet['dns_nameservers']
if not dns_nameservers or not validators.is_attr_set(dns_nameservers): if not dns_nameservers or not utils.is_attr_set(dns_nameservers):
# use the default one , or the globally configured one # use the default one , or the globally configured one
if default_dns_nameservers is not None: if default_dns_nameservers is not None:
dns_nameservers = default_dns_nameservers dns_nameservers = default_dns_nameservers
else: else:
dns_nameservers = self.nsxlib_config.dns_nameservers dns_nameservers = self.nsxlib_config.dns_nameservers
gateway_ip = subnet['gateway_ip'] gateway_ip = subnet['gateway_ip']
if not validators.is_attr_set(gateway_ip): if not utils.is_attr_set(gateway_ip):
gateway_ip = None gateway_ip = None
static_routes, gateway_ip = self.build_static_routes( static_routes, gateway_ip = self.build_static_routes(
gateway_ip, subnet['cidr'], subnet['host_routes']) gateway_ip, subnet['cidr'], subnet['host_routes'])

View File

@ -18,7 +18,6 @@ NSX-V3 Plugin router module
""" """
import copy import copy
from neutron_lib import exceptions as n_exc
from oslo_log import log from oslo_log import log
from vmware_nsxlib._i18n import _ from vmware_nsxlib._i18n import _
@ -72,7 +71,7 @@ class RouterLib(object):
'exp_num': MIN_EDGE_NODE_NUM, 'exp_num': MIN_EDGE_NODE_NUM,
'cluster_id': edge_cluster_uuid} 'cluster_id': edge_cluster_uuid}
if err_msg: if err_msg:
raise n_exc.InvalidInput(error_message=err_msg) raise exceptions.NsxLibInvalidInput(error_message=err_msg)
else: else:
tier0_groups_dict[tier0_uuid] = { tier0_groups_dict[tier0_uuid] = {
'edge_cluster_uuid': edge_cluster_uuid, 'edge_cluster_uuid': edge_cluster_uuid,

View File

@ -18,10 +18,10 @@
NSX-V3 Plugin security & Distributed Firewall integration module NSX-V3 Plugin security & Distributed Firewall integration module
""" """
from neutron_lib import constants
from oslo_log import log from oslo_log import log
from oslo_utils import excutils from oslo_utils import excutils
from vmware_nsxlib.v3 import constants
from vmware_nsxlib.v3 import exceptions from vmware_nsxlib.v3 import exceptions
from vmware_nsxlib.v3 import nsx_constants as consts from vmware_nsxlib.v3 import nsx_constants as consts
from vmware_nsxlib.v3 import utils from vmware_nsxlib.v3 import utils

View File

@ -18,7 +18,6 @@ import inspect
import re import re
import time import time
from neutron_lib import exceptions
from oslo_log import log from oslo_log import log
import tenacity import tenacity
from tenacity import _utils as tenacity_utils from tenacity import _utils as tenacity_utils
@ -33,6 +32,18 @@ MAX_TAG_LEN = 40
DEFAULT_MAX_ATTEMPTS = 10 DEFAULT_MAX_ATTEMPTS = 10
DEFAULT_CACHE_AGE_SEC = 600 DEFAULT_CACHE_AGE_SEC = 600
INJECT_HEADERS_CALLBACK = None INJECT_HEADERS_CALLBACK = None
IS_ATTR_SET_CALLBACK = None
def set_is_attr_callback(callback):
global IS_ATTR_SET_CALLBACK
IS_ATTR_SET_CALLBACK = callback
def is_attr_set(attr):
if IS_ATTR_SET_CALLBACK:
return IS_ATTR_SET_CALLBACK(attr)
return attr is not None
def set_inject_headers_callback(callback): def set_inject_headers_callback(callback):
@ -43,7 +54,7 @@ def set_inject_headers_callback(callback):
def _validate_resource_type_length(resource_type): def _validate_resource_type_length(resource_type):
# Add in a validation to ensure that we catch this at build time # Add in a validation to ensure that we catch this at build time
if len(resource_type) > MAX_RESOURCE_TYPE_LEN: if len(resource_type) > MAX_RESOURCE_TYPE_LEN:
raise exceptions.InvalidInput( raise nsxlib_exceptions.NsxLibInvalidInput(
error_message=(_('Resource type cannot exceed %(max_len)s ' error_message=(_('Resource type cannot exceed %(max_len)s '
'characters: %(resource_type)s') % 'characters: %(resource_type)s') %
{'max_len': MAX_RESOURCE_TYPE_LEN, {'max_len': MAX_RESOURCE_TYPE_LEN,