Merge "Test coverage improvement for sahara.service.networks"
This commit is contained in:
commit
3cbcdf6818
140
sahara/tests/unit/service/test_networks.py
Normal file
140
sahara/tests/unit/service/test_networks.py
Normal file
@ -0,0 +1,140 @@
|
||||
# Copyright (c) 2015 Mirantis Inc.
|
||||
#
|
||||
# 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 mock
|
||||
|
||||
from sahara.service import networks
|
||||
from sahara.tests.unit import base
|
||||
|
||||
|
||||
class TestNetworks(base.SaharaTestCase):
|
||||
|
||||
@mock.patch('sahara.service.networks.conductor.instance_update')
|
||||
@mock.patch('sahara.utils.openstack.nova.get_instance_info')
|
||||
def test_init_instances_ips_with_floating(self, nova, upd):
|
||||
server = mock.Mock()
|
||||
server.addresses = {
|
||||
'network': [
|
||||
{
|
||||
'version': 4,
|
||||
'OS-EXT-IPS:type': 'fixed',
|
||||
'addr': '10.2.2.2'
|
||||
},
|
||||
{
|
||||
'version': 4,
|
||||
'OS-EXT-IPS:type': 'floating',
|
||||
'addr': '172.1.1.1'
|
||||
}
|
||||
]
|
||||
}
|
||||
nova.return_value = server
|
||||
|
||||
self.assertEqual('172.1.1.1', networks.init_instances_ips(mock.Mock()))
|
||||
|
||||
@mock.patch('sahara.service.networks.conductor.instance_update')
|
||||
@mock.patch('sahara.utils.openstack.nova.get_instance_info')
|
||||
def test_init_instances_ips_without_floating(self, nova, upd):
|
||||
self.override_config('use_floating_ips', False)
|
||||
server = mock.Mock()
|
||||
server.addresses = {
|
||||
'network': [
|
||||
{
|
||||
'version': 4,
|
||||
'OS-EXT-IPS:type': 'fixed',
|
||||
'addr': '10.2.2.2'
|
||||
}
|
||||
]
|
||||
}
|
||||
nova.return_value = server
|
||||
|
||||
self.assertEqual('10.2.2.2', networks.init_instances_ips(mock.Mock()))
|
||||
|
||||
@mock.patch('sahara.service.networks.conductor.instance_update')
|
||||
@mock.patch('sahara.utils.openstack.nova.get_instance_info')
|
||||
def test_init_instances_ips_with_proxy(self, nova, upd):
|
||||
|
||||
instance = mock.Mock()
|
||||
instance.cluster.has_proxy_gateway.return_value = True
|
||||
instance.node_group.is_proxy_gateway = False
|
||||
server = mock.Mock()
|
||||
server.addresses = {
|
||||
'network': [
|
||||
{
|
||||
'version': 4,
|
||||
'OS-EXT-IPS:type': 'fixed',
|
||||
'addr': '10.2.2.2'
|
||||
}
|
||||
]
|
||||
}
|
||||
nova.return_value = server
|
||||
|
||||
self.assertEqual('10.2.2.2', networks.init_instances_ips(instance))
|
||||
|
||||
@mock.patch('sahara.utils.openstack.neutron.client')
|
||||
@mock.patch('sahara.service.networks.conductor.instance_update')
|
||||
@mock.patch('sahara.utils.openstack.nova.get_instance_info')
|
||||
def test_init_instances_ips_neutron_with_floating(
|
||||
self, nova, upd, neutron):
|
||||
|
||||
self.override_config('use_neutron', True)
|
||||
server = mock.Mock(addresses={}, id='serv_id')
|
||||
nova.return_value = server
|
||||
neutron_client = mock.Mock()
|
||||
neutron_client.list_ports.return_value = {
|
||||
'ports': [
|
||||
{'id': 'port_id'}
|
||||
]
|
||||
}
|
||||
|
||||
neutron_client.list_floatingips.return_value = {
|
||||
'floatingips': [
|
||||
{
|
||||
'floating_ip_address': '172.1.1.1',
|
||||
'fixed_ip_address': '10.2.2.2',
|
||||
}
|
||||
]
|
||||
}
|
||||
neutron.return_value = neutron_client
|
||||
|
||||
self.assertEqual('172.1.1.1', networks.init_instances_ips(mock.Mock()))
|
||||
|
||||
@mock.patch('sahara.utils.openstack.neutron.client')
|
||||
@mock.patch('sahara.service.networks.conductor.instance_update')
|
||||
@mock.patch('sahara.utils.openstack.nova.get_instance_info')
|
||||
def test_init_instances_ips_neutron_without_floating(
|
||||
self, nova, upd, neutron):
|
||||
|
||||
self.override_config('use_neutron', True)
|
||||
self.override_config('use_floating_ips', False)
|
||||
server = mock.Mock(addresses={}, id='serv_id')
|
||||
nova.return_value = server
|
||||
neutron_client = mock.Mock()
|
||||
neutron_client.list_ports.return_value = {
|
||||
'ports': [
|
||||
{'id': 'port_id'}
|
||||
]
|
||||
}
|
||||
|
||||
neutron_client.list_floatingips.return_value = {
|
||||
'floatingips': [
|
||||
{
|
||||
'floating_ip_address': '172.1.1.1',
|
||||
'fixed_ip_address': '10.2.2.2',
|
||||
}
|
||||
]
|
||||
}
|
||||
neutron.return_value = neutron_client
|
||||
|
||||
self.assertEqual('10.2.2.2', networks.init_instances_ips(mock.Mock()))
|
Loading…
Reference in New Issue
Block a user