BGP unittests
Depends-On: I320e0124719cb03632fa86fbc49812c0fea35e4f Change-Id: I03eb8e6bdbc99117d9978513681ceaa762614cd3
This commit is contained in:
parent
8fa99768c3
commit
cd624df88e
@ -297,8 +297,9 @@ class NSXvBgpDriver(object):
|
||||
self._plugin._validate_peer_ips(bgp_speaker_id, peers, new_peer)
|
||||
|
||||
def add_bgp_peer(self, context, bgp_speaker_id, bgp_peer_info):
|
||||
bgp_peer_id = self._plugin._get_id_for(bgp_peer_info, 'bgp_peer_id')
|
||||
bgp_peer_obj = self._plugin.get_bgp_peer(context,
|
||||
bgp_peer_info['bgp_peer_id'])
|
||||
bgp_peer_id)
|
||||
nbr = bgp_neighbour(bgp_peer_obj)
|
||||
bgp_bindings = nsxv_db.get_nsxv_bgp_speaker_bindings(context.session,
|
||||
bgp_speaker_id)
|
||||
|
@ -12,26 +12,32 @@
|
||||
# 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 mock
|
||||
|
||||
from neutron.tests import base
|
||||
from neutron.api import extensions
|
||||
from neutron_dynamic_routing.db import bgp_db # noqa
|
||||
from neutron_dynamic_routing import extensions as dr_extensions
|
||||
from neutron_dynamic_routing.extensions import bgp as ext_bgp
|
||||
from neutron_dynamic_routing.tests.unit.db import test_bgp_db
|
||||
from neutron_lib import context
|
||||
from neutron_lib import exceptions as n_exc
|
||||
from neutron_lib.plugins import directory
|
||||
|
||||
from vmware_nsx.services.dynamic_routing.nsx_v import driver as nsxv_driver
|
||||
from vmware_nsx.services.dynamic_routing import bgp_plugin
|
||||
from vmware_nsx.tests.unit.nsx_v import test_plugin
|
||||
|
||||
BGP_PLUGIN = 'vmware_nsx.services.dynamic_routing.bgp_plugin.NSXvBgpPlugin'
|
||||
|
||||
|
||||
class TestNSXvBgpDriver(base.BaseTestCase):
|
||||
|
||||
class TestNSXvBgpPlugin(test_plugin.NsxVPluginV2TestCase,
|
||||
test_bgp_db.BgpTests):
|
||||
def setUp(self):
|
||||
super(TestNSXvBgpDriver, self).setUp()
|
||||
extensions.append_api_extensions_path(dr_extensions.__path__)
|
||||
service_plugins = {ext_bgp.BGP_EXT_ALIAS: BGP_PLUGIN}
|
||||
super(TestNSXvBgpPlugin, self).setUp(service_plugins=service_plugins)
|
||||
self.bgp_plugin = bgp_plugin.NSXvBgpPlugin()
|
||||
self.plugin = directory.get_plugin()
|
||||
self.l3plugin = self.plugin
|
||||
self.plugin.init_is_complete = True
|
||||
self.context = context.get_admin_context()
|
||||
with mock.patch.object(directory, 'get_plugin',
|
||||
new=mock.Mock()):
|
||||
self.provider = nsxv_driver.NSXvBgpDriver(mock.MagicMock())
|
||||
|
||||
def test_create_v6_bgp_speaker(self):
|
||||
fake_bgp_speaker = {
|
||||
@ -42,7 +48,7 @@ class TestNSXvBgpDriver(base.BaseTestCase):
|
||||
}
|
||||
}
|
||||
self.assertRaises(n_exc.InvalidInput,
|
||||
self.provider.create_bgp_speaker,
|
||||
self.bgp_plugin.create_bgp_speaker,
|
||||
self.context, fake_bgp_speaker)
|
||||
|
||||
def test_create_v6_bgp_peer(self):
|
||||
@ -55,5 +61,91 @@ class TestNSXvBgpDriver(base.BaseTestCase):
|
||||
}
|
||||
}
|
||||
self.assertRaises(n_exc.InvalidInput,
|
||||
self.provider.create_bgp_peer,
|
||||
self.bgp_plugin.create_bgp_peer,
|
||||
self.context, fake_bgp_peer)
|
||||
|
||||
def test_create_bgp_peer_md5_auth_no_password(self):
|
||||
# TODO(roeyc): Test requires a minor fix in base class.
|
||||
pass
|
||||
|
||||
def test__bgp_speakers_for_gateway_network_by_ip_version(self):
|
||||
# REVISIT(roeyc): Base class test use ipv6 which is not supported.
|
||||
pass
|
||||
|
||||
def test__bgp_speakers_for_gateway_network_by_ip_version_no_binding(self):
|
||||
# REVISIT(roeyc): Base class test use ipv6 which is not supported.
|
||||
pass
|
||||
|
||||
def test__tenant_prefixes_by_router_no_gateway_port(self):
|
||||
# REVISIT(roeyc): Base class test use ipv6 which is not supported.
|
||||
pass
|
||||
|
||||
def test_all_routes_by_bgp_speaker_different_tenant_address_scope(self):
|
||||
# REVISIT(roeyc): Base class test use ipv6 which is not supported.
|
||||
pass
|
||||
|
||||
def test__get_address_scope_ids_for_bgp_speaker(self):
|
||||
# REVISIT(roeyc): Base class creates subnets with gateway-ip on
|
||||
# external network, NSXv plugin requires that gateway-ip is not
|
||||
# specified for subnets in BGP backed networks.
|
||||
pass
|
||||
|
||||
def test_get_ipv4_tenant_subnet_routes_by_bgp_speaker_dvr_router(self):
|
||||
# REVISIT(roeyc): Base class creates subnets with gateway-ip on
|
||||
# external network, NSXv plugin requires that gateway-ip is not
|
||||
# specified for subnets in BGP backed networks.
|
||||
pass
|
||||
|
||||
def test_get_ipv4_tenant_subnet_routes_by_bgp_speaker_ipv4(self):
|
||||
# REVISIT(roeyc): Base class creates subnets with gateway-ip on
|
||||
# external network, NSXv plugin requires that gateway-ip is not
|
||||
# specified for subnets in BGP backed networks.
|
||||
pass
|
||||
|
||||
def test_get_routes_by_bgp_speaker_binding(self):
|
||||
# REVISIT(roeyc): Base class creates subnets with gateway-ip on
|
||||
# external network, NSXv plugin requires that gateway-ip is not
|
||||
# specified for subnets in BGP backed networks.
|
||||
pass
|
||||
|
||||
def test_get_routes_by_binding_network(self):
|
||||
# REVISIT(roeyc): Base class creates subnets with gateway-ip on
|
||||
# external network, NSXv plugin requires that gateway-ip is not
|
||||
# specified for subnets in BGP backed networks.
|
||||
pass
|
||||
|
||||
def test__get_dvr_fip_host_routes_by_binding(self):
|
||||
pass
|
||||
|
||||
def test__get_dvr_fip_host_routes_by_router(self):
|
||||
pass
|
||||
|
||||
def test__get_fip_next_hop_dvr(self):
|
||||
pass
|
||||
|
||||
def test__get_fip_next_hop_legacy(self):
|
||||
pass
|
||||
|
||||
def test__get_routes_by_router_with_fip(self):
|
||||
pass
|
||||
|
||||
def test_get_routes_by_bgp_speaker_binding_with_fip(self):
|
||||
pass
|
||||
|
||||
def test_get_routes_by_bgp_speaker_id_with_fip(self):
|
||||
pass
|
||||
|
||||
def test_get_routes_by_bgp_speaker_id_with_fip_dvr(self):
|
||||
pass
|
||||
|
||||
def test_ha_router_fips_has_no_next_hop_to_fip_agent_gateway(self):
|
||||
pass
|
||||
|
||||
def test_legacy_router_fips_has_no_next_hop_to_fip_agent_gateway(self):
|
||||
pass
|
||||
|
||||
def test_floatingip_update_callback(self):
|
||||
pass
|
||||
|
||||
def test_get_ipv6_tenant_subnet_routes_by_bgp_speaker_ipv6(self):
|
||||
pass
|
||||
|
Loading…
x
Reference in New Issue
Block a user