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:
parent
82ce3daf8c
commit
cdcb5963da
@ -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
|
||||||
|
4
tox.ini
4
tox.ini
@ -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 =
|
||||||
|
@ -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)
|
||||||
|
@ -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'])
|
||||||
|
|
||||||
|
|
||||||
|
@ -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,
|
||||||
|
88
vmware_nsxlib/v3/constants.py
Normal file
88
vmware_nsxlib/v3/constants.py
Normal 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}
|
@ -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")
|
||||||
|
@ -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'])
|
||||||
|
@ -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,
|
||||||
|
@ -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
|
||||||
|
@ -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,
|
||||||
|
Loading…
Reference in New Issue
Block a user