summaryrefslogtreecommitdiffstats
path: root/os_net_config/tests
diff options
context:
space:
mode:
Diffstat (limited to 'os_net_config/tests')
-rw-r--r--os_net_config/tests/test_impl_eni.py162
1 files changed, 162 insertions, 0 deletions
diff --git a/os_net_config/tests/test_impl_eni.py b/os_net_config/tests/test_impl_eni.py
new file mode 100644
index 0000000..ff4f827
--- /dev/null
+++ b/os_net_config/tests/test_impl_eni.py
@@ -0,0 +1,162 @@
+
+# -*- coding: utf-8 -*-
+
+# 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.
+
+import tempfile
+
+from os_net_config import impl_eni
+from os_net_config import objects
+from os_net_config.openstack.common import processutils
+from os_net_config.tests import base
+from os_net_config import utils
+
+_AUTO = "auto eth0\n"
+
+_BASE_IFACE = "iface eth0"
+
+_v4_IFACE_NO_IP = _AUTO + _BASE_IFACE + " inet manual\n"
+
+_V4_IFACE_STATIC_IP = _AUTO + _BASE_IFACE + """ inet static
+address 192.168.1.2
+netmask 255.255.255.0
+"""
+
+_V6_IFACE_STATIC_IP = _AUTO + _BASE_IFACE + """ inet6 static
+address fe80::2677:3ff:fe7d:4c
+netmask ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff
+"""
+
+_OVS_PORT_BASE = "allow-br0 eth0\n"
+
+_OVS_IFACE_DHCP = _BASE_IFACE + " inet dhcp\n"
+
+_OVS_PORT_IFACE = _OVS_PORT_BASE + _OVS_IFACE_DHCP + """ovs_bridge br0
+ovs_type OVSPort\n"""
+
+_OVS_BRIDGE_DHCP = """allow-ovs br0
+iface br0 inet dhcp
+ovs_type OVSBridge
+ovs_ports eth0
+"""
+
+_RTS = """up route add -net 172.19.0.0 netmask 255.255.255.0 gw 192.168.1.1
+down route del -net 172.19.0.0 netmask 255.255.255.0 gw 192.168.1.1
+"""
+
+
+class TestENINetConfig(base.TestCase):
+
+ def setUp(self):
+ super(TestENINetConfig, self).setUp()
+
+ self.provider = impl_eni.ENINetConfig()
+ self.if_name = 'eth0'
+
+ def tearDown(self):
+ super(TestENINetConfig, self).tearDown()
+
+ def get_interface_config(self):
+ return self.provider.interfaces[self.if_name]
+
+ def get_route_config(self):
+ return self.provider.routes[self.if_name]
+
+ def _default_interface(self, addr=[], rts=[]):
+ return objects.Interface(self.if_name, addresses=addr, routes=rts)
+
+ def test_add_base_interface(self):
+ interface = self._default_interface()
+ self.provider.addInterface(interface)
+ self.assertEqual(_v4_IFACE_NO_IP, self.get_interface_config())
+
+ def test_add_ovs_port_interface(self):
+ interface = self._default_interface()
+ interface.type = 'ovs_port'
+ interface.bridge_name = 'br0'
+ interface.use_dhcp = True
+ self.provider.addInterface(interface)
+ self.assertEqual(_OVS_PORT_IFACE, self.get_interface_config())
+
+ def test_add_interface_with_v4(self):
+ v4_addr = objects.Address('192.168.1.2/24')
+ interface = self._default_interface([v4_addr])
+ self.provider.addInterface(interface)
+ self.assertEqual(_V4_IFACE_STATIC_IP, self.get_interface_config())
+
+ def test_add_interface_with_v6(self):
+ v6_addr = objects.Address('fe80::2677:3ff:fe7d:4c')
+ interface = self._default_interface([v6_addr])
+ self.provider.addInterface(interface)
+ self.assertEqual(_V6_IFACE_STATIC_IP, self.get_interface_config())
+
+ def test_network_with_routes(self):
+ route1 = objects.Route('192.168.1.1', '172.19.0.0/24')
+ v4_addr = objects.Address('192.168.1.2/24')
+ interface = self._default_interface([v4_addr], [route1])
+ self.provider.addInterface(interface)
+ self.assertEqual(_V4_IFACE_STATIC_IP, self.get_interface_config())
+ self.assertEqual(_RTS, self.get_route_config())
+
+ def test_network_ovs_bridge_with_dhcp(self):
+ interface = self._default_interface()
+ interface.use_dhcp = True
+ bridge = objects.OvsBridge('br0', use_dhcp=True,
+ members=[interface])
+ self.provider.addBridge(bridge)
+ self.provider.addInterface(interface)
+ self.assertEqual(_OVS_PORT_IFACE, self.get_interface_config())
+ self.assertEqual(_OVS_BRIDGE_DHCP, self.provider.bridges['br0'])
+
+
+class TestENINetConfigApply(base.TestCase):
+
+ def setUp(self):
+ super(TestENINetConfigApply, self).setUp()
+ self.temp_config_file = tempfile.NamedTemporaryFile()
+
+ def test_config_path():
+ return self.temp_config_file.name
+ self.stubs.Set(impl_eni, '_network_config_path', test_config_path)
+
+ def test_execute(*args, **kwargs):
+ pass
+ self.stubs.Set(processutils, 'execute', test_execute)
+
+ self.provider = impl_eni.ENINetConfig()
+
+ def tearDown(self):
+ self.temp_config_file.close()
+ super(TestENINetConfigApply, self).tearDown()
+
+ def test_network_apply(self):
+ route = objects.Route('192.168.1.1', '172.19.0.0/24')
+ v4_addr = objects.Address('192.168.1.2/24')
+ interface = objects.Interface('eth0', addresses=[v4_addr],
+ routes=[route])
+ self.provider.addInterface(interface)
+
+ self.provider.apply()
+ iface_data = utils.get_file_data(self.temp_config_file.name)
+ self.assertEqual((_V4_IFACE_STATIC_IP + _RTS), iface_data)
+
+ def test_dhcp_ovs_bridge_network_apply(self):
+ interface = objects.Interface('eth0')
+ interface.use_dhcp = True
+ bridge = objects.OvsBridge('br0', use_dhcp=True,
+ members=[interface])
+ self.provider.addInterface(interface)
+ self.provider.addBridge(bridge)
+ self.provider.apply()
+ iface_data = utils.get_file_data(self.temp_config_file.name)
+ self.assertEqual((_OVS_PORT_IFACE + _OVS_BRIDGE_DHCP), iface_data)