
As discussed on the neutron-performance meeting [1] floating IP operations should be covered in the neutron gate rally job. As I set out to write the missing tests I discovered that some of them were already written by rally folks. For example see [2]. Keep in mind the test code has been relocated since to the rally-openstack repository. For example see [3]. They were later added to neutron's rally job definition [4]. Here we add one more scenario to exercise the floating IP operations left uncovered by the above changes: associate and dissociate. [1] http://eavesdrop.openstack.org/meetings/neutron_performance/2018/neutron_performance.2018-10-22-16.02.log.html#l-143 [2] https://review.openstack.org/225223 [3] https://github.com/openstack/rally-openstack/blob/4e4bfc5/rally_openstack/scenarios/neutron/network.py [4] https://review.openstack.org/620952 Change-Id: I32f3bad82fa0ca822e80d51220c120568a709332 Needed-By: https://review.openstack.org/624038
626 lines
27 KiB
Python
626 lines
27 KiB
Python
# Copyright 2014: Intel 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.
|
|
|
|
import ddt
|
|
import mock
|
|
|
|
from rally import exceptions as rally_exceptions
|
|
from rally_openstack.scenarios.neutron import network
|
|
from tests.unit import test
|
|
|
|
BASE = "rally_openstack.scenarios.neutron.network"
|
|
|
|
|
|
@ddt.ddt
|
|
class NeutronNetworksTestCase(test.ScenarioTestCase):
|
|
|
|
@ddt.data(
|
|
{"network_create_args": {}},
|
|
{"network_create_args": {"name": "given-name"}},
|
|
{"network_create_args": {"provider:network_type": "vxlan"}}
|
|
)
|
|
@ddt.unpack
|
|
@mock.patch("%s.CreateAndListNetworks._list_networks" % BASE)
|
|
@mock.patch("%s.CreateAndListNetworks._create_network" % BASE)
|
|
def test_create_and_list_networks(self,
|
|
mock__create_network,
|
|
mock__list_networks,
|
|
network_create_args):
|
|
scenario = network.CreateAndListNetworks(self.context)
|
|
|
|
scenario.run(network_create_args=network_create_args)
|
|
mock__create_network.assert_called_once_with(network_create_args)
|
|
mock__list_networks.assert_called_once_with()
|
|
|
|
mock__create_network.reset_mock()
|
|
mock__list_networks.reset_mock()
|
|
|
|
@ddt.data(
|
|
{"network_create_args": {}},
|
|
{"network_create_args": {"name": "given-name"}},
|
|
)
|
|
@ddt.unpack
|
|
@mock.patch("%s.CreateAndShowNetwork._show_network" % BASE)
|
|
@mock.patch("%s.CreateAndShowNetwork._create_network" % BASE)
|
|
def test_create_and_show_network(self,
|
|
mock__create_network,
|
|
mock__show_network,
|
|
network_create_args):
|
|
scenario = network.CreateAndShowNetwork(self.context)
|
|
mock_net = mock.Mock()
|
|
|
|
mock__create_network.return_value = mock_net
|
|
scenario.run(network_create_args=network_create_args)
|
|
|
|
mock__create_network.assert_called_once_with(network_create_args)
|
|
mock__show_network.assert_called_once_with(mock_net)
|
|
|
|
mock__create_network.reset_mock()
|
|
mock__show_network.reset_mock()
|
|
|
|
@mock.patch("%s.CreateAndUpdateNetworks._update_network" % BASE)
|
|
@mock.patch("%s.CreateAndUpdateNetworks._create_network" % BASE,
|
|
return_value={
|
|
"network": {
|
|
"id": "network-id",
|
|
"name": "network-name",
|
|
"admin_state_up": False
|
|
}
|
|
})
|
|
def test_create_and_update_networks(self,
|
|
mock__create_network,
|
|
mock__update_network):
|
|
scenario = network.CreateAndUpdateNetworks(self.context)
|
|
|
|
network_update_args = {"name": "_updated", "admin_state_up": True}
|
|
|
|
# Default options
|
|
scenario.run(network_update_args=network_update_args)
|
|
|
|
mock__create_network.assert_called_once_with({})
|
|
|
|
mock__update_network.assert_has_calls(
|
|
[mock.call(
|
|
mock__create_network.return_value, network_update_args
|
|
)])
|
|
|
|
mock__create_network.reset_mock()
|
|
mock__update_network.reset_mock()
|
|
|
|
# Explicit network name is specified
|
|
network_create_args = {
|
|
"name": "network-name",
|
|
"admin_state_up": False
|
|
}
|
|
|
|
scenario.run(network_create_args=network_create_args,
|
|
network_update_args=network_update_args)
|
|
mock__create_network.assert_called_once_with(network_create_args)
|
|
mock__update_network.assert_has_calls(
|
|
[mock.call(mock__create_network.return_value,
|
|
network_update_args)])
|
|
|
|
@mock.patch("%s.CreateAndDeleteNetworks._delete_network" % BASE)
|
|
@mock.patch("%s.CreateAndDeleteNetworks._create_network" % BASE)
|
|
def test_create_and_delete_networks(self,
|
|
mock__create_network,
|
|
mock__delete_network):
|
|
scenario = network.CreateAndDeleteNetworks(self.context)
|
|
|
|
# Default options
|
|
network_create_args = {}
|
|
scenario.run()
|
|
mock__create_network.assert_called_once_with(network_create_args)
|
|
self.assertTrue(mock__delete_network.call_count)
|
|
|
|
mock__create_network.reset_mock()
|
|
mock__delete_network.reset_mock()
|
|
|
|
# Explicit network name is specified
|
|
network_create_args = {"name": "given-name"}
|
|
scenario.run(network_create_args=network_create_args)
|
|
mock__create_network.assert_called_once_with(network_create_args)
|
|
self.assertTrue(mock__delete_network.call_count)
|
|
|
|
def test_create_and_list_subnets(self):
|
|
network_create_args = {"router:external": True}
|
|
subnet_create_args = {"allocation_pools": []}
|
|
subnet_cidr_start = "default_cidr"
|
|
subnets_per_network = 5
|
|
net = mock.MagicMock()
|
|
|
|
scenario = network.CreateAndListSubnets(self.context)
|
|
scenario._create_network = mock.Mock(return_value=net)
|
|
scenario._create_subnets = mock.Mock()
|
|
scenario._list_subnets = mock.Mock()
|
|
|
|
scenario.run(network_create_args=network_create_args,
|
|
subnet_create_args=subnet_create_args,
|
|
subnet_cidr_start=subnet_cidr_start,
|
|
subnets_per_network=subnets_per_network)
|
|
|
|
scenario._create_network.assert_called_once_with(
|
|
network_create_args)
|
|
scenario._create_subnets.assert_called_once_with(
|
|
net, subnet_create_args, subnet_cidr_start, subnets_per_network)
|
|
|
|
scenario._list_subnets.assert_called_once_with()
|
|
|
|
def test_create_and_show_subnets(self):
|
|
network_create_args = {"router:external": True}
|
|
subnet_create_args = {"allocation_pools": []}
|
|
subnet_cidr_start = "1.1.0.0/30"
|
|
subnets_per_network = 5
|
|
net = mock.MagicMock()
|
|
|
|
scenario = network.CreateAndShowSubnets(self.context)
|
|
scenario._get_or_create_network = mock.Mock(return_value=net)
|
|
scenario._create_subnets = mock.MagicMock()
|
|
scenario._show_subnet = mock.Mock()
|
|
|
|
scenario.run(network_create_args=network_create_args,
|
|
subnet_create_args=subnet_create_args,
|
|
subnet_cidr_start=subnet_cidr_start,
|
|
subnets_per_network=subnets_per_network)
|
|
|
|
scenario._get_or_create_network.assert_called_once_with(
|
|
network_create_args)
|
|
scenario._create_subnets.assert_called_once_with(
|
|
net, subnet_create_args, subnet_cidr_start, subnets_per_network)
|
|
for subnet in scenario._create_subnets.return_value:
|
|
scenario._show_subnet.assert_called_with(subnet)
|
|
|
|
def test_set_and_clear_router_gateway(self):
|
|
network_create_args = {"router:external": True}
|
|
router_create_args = {"admin_state_up": True}
|
|
enable_snat = True
|
|
ext_net = mock.MagicMock()
|
|
router = mock.MagicMock()
|
|
scenario = network.SetAndClearRouterGateway(self.context)
|
|
scenario._create_network = mock.Mock(return_value=ext_net)
|
|
scenario._create_router = mock.Mock(return_value=router)
|
|
scenario._add_gateway_router = mock.Mock()
|
|
scenario._remove_gateway_router = mock.Mock()
|
|
|
|
scenario.run(enable_snat, network_create_args, router_create_args)
|
|
|
|
scenario._create_network.assert_called_once_with(
|
|
network_create_args)
|
|
scenario._create_router.assert_called_once_with(router_create_args)
|
|
scenario._add_gateway_router.assert_called_once_with(router, ext_net,
|
|
enable_snat)
|
|
scenario._remove_gateway_router.assert_called_once_with(router)
|
|
|
|
def test_create_and_update_subnets(self):
|
|
network_create_args = {"router:external": True}
|
|
subnet_create_args = {"allocation_pools": []}
|
|
subnet_update_args = {"enabled_dhcp": True}
|
|
subnet_cidr_start = "default_cidr"
|
|
subnets_per_network = 5
|
|
net = mock.MagicMock()
|
|
subnets = [mock.MagicMock() for _ in range(subnets_per_network)]
|
|
|
|
scenario = network.CreateAndUpdateSubnets(self.context)
|
|
scenario._create_network = mock.Mock(return_value=net)
|
|
scenario._create_subnets = mock.Mock(return_value=subnets)
|
|
scenario._update_subnet = mock.Mock()
|
|
|
|
scenario.run(subnet_update_args,
|
|
network_create_args=network_create_args,
|
|
subnet_create_args=subnet_create_args,
|
|
subnet_cidr_start=subnet_cidr_start,
|
|
subnets_per_network=subnets_per_network)
|
|
|
|
scenario._create_network.assert_called_once_with(
|
|
network_create_args)
|
|
scenario._create_subnets.assert_called_once_with(
|
|
net, subnet_create_args, subnet_cidr_start, subnets_per_network)
|
|
scenario._update_subnet.assert_has_calls(
|
|
[mock.call(s, subnet_update_args) for s in subnets])
|
|
|
|
def test_create_and_delete_subnets(self):
|
|
network_create_args = {"router:external": True}
|
|
subnet_create_args = {"allocation_pools": []}
|
|
subnet_cidr_start = "default_cidr"
|
|
subnets_per_network = 5
|
|
net = mock.MagicMock()
|
|
subnets = [mock.MagicMock() for _ in range(subnets_per_network)]
|
|
|
|
scenario = network.CreateAndDeleteSubnets(self.context)
|
|
scenario._get_or_create_network = mock.Mock(return_value=net)
|
|
scenario._create_subnets = mock.Mock(return_value=subnets)
|
|
scenario._delete_subnet = mock.Mock()
|
|
|
|
scenario.run(network_create_args=network_create_args,
|
|
subnet_create_args=subnet_create_args,
|
|
subnet_cidr_start=subnet_cidr_start,
|
|
subnets_per_network=subnets_per_network)
|
|
|
|
scenario._get_or_create_network.assert_called_once_with(
|
|
network_create_args)
|
|
scenario._create_subnets.assert_called_once_with(
|
|
net, subnet_create_args, subnet_cidr_start, subnets_per_network)
|
|
scenario._delete_subnet.assert_has_calls(
|
|
[mock.call(s) for s in subnets])
|
|
|
|
def test_create_and_list_routers(self):
|
|
network_create_args = {"router:external": True}
|
|
subnet_create_args = {"allocation_pools": []}
|
|
subnet_cidr_start = "default_cidr"
|
|
subnets_per_network = 5
|
|
router_create_args = {"admin_state_up": True}
|
|
|
|
scenario = network.CreateAndListRouters(self.context)
|
|
scenario._create_network_structure = mock.Mock()
|
|
scenario._list_routers = mock.Mock()
|
|
|
|
scenario.run(network_create_args=network_create_args,
|
|
subnet_create_args=subnet_create_args,
|
|
subnet_cidr_start=subnet_cidr_start,
|
|
subnets_per_network=subnets_per_network,
|
|
router_create_args=router_create_args)
|
|
|
|
scenario._create_network_structure.assert_called_once_with(
|
|
network_create_args, subnet_create_args, subnet_cidr_start,
|
|
subnets_per_network, router_create_args)
|
|
scenario._list_routers.assert_called_once_with()
|
|
|
|
def test_list_agents(self):
|
|
agent_args = {
|
|
"F": "id",
|
|
"sort-dir": "asc"
|
|
}
|
|
scenario = network.ListAgents(self.context)
|
|
scenario._list_agents = mock.Mock()
|
|
|
|
scenario.run(agent_args=agent_args)
|
|
scenario._list_agents.assert_called_once_with(**agent_args)
|
|
|
|
def test_create_and_update_routers(self):
|
|
router_update_args = {"admin_state_up": False}
|
|
network_create_args = {"router:external": True}
|
|
subnet_create_args = {"allocation_pools": []}
|
|
subnet_cidr_start = "default_cidr"
|
|
subnets_per_network = 5
|
|
router_create_args = {"admin_state_up": True}
|
|
net = mock.MagicMock()
|
|
subnets = [mock.MagicMock() for i in range(subnets_per_network)]
|
|
routers = [mock.MagicMock() for i in range(subnets_per_network)]
|
|
|
|
scenario = network.CreateAndUpdateRouters(self.context)
|
|
scenario._create_network_structure = mock.Mock(
|
|
return_value=(net, subnets, routers))
|
|
scenario._update_router = mock.Mock()
|
|
|
|
scenario.run(router_update_args,
|
|
network_create_args=network_create_args,
|
|
subnet_create_args=subnet_create_args,
|
|
subnet_cidr_start=subnet_cidr_start,
|
|
subnets_per_network=subnets_per_network,
|
|
router_create_args=router_create_args)
|
|
|
|
scenario._create_network_structure.assert_called_once_with(
|
|
network_create_args, subnet_create_args, subnet_cidr_start,
|
|
subnets_per_network, router_create_args)
|
|
|
|
update_calls = [mock.call(router, router_update_args)
|
|
for router in routers]
|
|
scenario._update_router.assert_has_calls(update_calls)
|
|
|
|
def test_create_and_delete_routers(self):
|
|
network_create_args = {"router:external": True}
|
|
subnet_create_args = {"allocation_pools": []}
|
|
subnet_cidr_start = "default_cidr"
|
|
subnets_per_network = 5
|
|
router_create_args = {"admin_state_up": True}
|
|
net = mock.MagicMock()
|
|
subnets = [mock.MagicMock() for i in range(subnets_per_network)]
|
|
routers = [mock.MagicMock() for i in range(subnets_per_network)]
|
|
|
|
scenario = network.CreateAndDeleteRouters(self.context)
|
|
scenario._create_network_structure = mock.Mock(
|
|
return_value=(net, subnets, routers))
|
|
scenario._remove_interface_router = mock.Mock()
|
|
scenario._delete_router = mock.Mock()
|
|
|
|
scenario.run(network_create_args=network_create_args,
|
|
subnet_create_args=subnet_create_args,
|
|
subnet_cidr_start=subnet_cidr_start,
|
|
subnets_per_network=subnets_per_network,
|
|
router_create_args=router_create_args)
|
|
|
|
scenario._create_network_structure.assert_called_once_with(
|
|
network_create_args, subnet_create_args, subnet_cidr_start,
|
|
subnets_per_network, router_create_args)
|
|
|
|
scenario._remove_interface_router.assert_has_calls([
|
|
mock.call(subnets[i]["subnet"], routers[i]["router"])
|
|
for i in range(subnets_per_network)])
|
|
scenario._delete_router.assert_has_calls(
|
|
[mock.call(router) for router in routers])
|
|
|
|
def test_create_and_show_routers(self):
|
|
network_create_args = {"router:external": True}
|
|
subnet_create_args = {"allocation_pools": []}
|
|
subnet_cidr_start = "default_cidr"
|
|
subnets_per_network = 5
|
|
router_create_args = {"admin_state_up": True}
|
|
net = mock.MagicMock()
|
|
subnets = [mock.MagicMock() for i in range(subnets_per_network)]
|
|
routers = [mock.MagicMock() for i in range(subnets_per_network)]
|
|
|
|
scenario = network.CreateAndShowRouters(self.context)
|
|
scenario._create_network_structure = mock.Mock(
|
|
return_value=(net, subnets, routers))
|
|
scenario._show_router = mock.Mock()
|
|
|
|
scenario.run(network_create_args=network_create_args,
|
|
subnet_create_args=subnet_create_args,
|
|
subnet_cidr_start=subnet_cidr_start,
|
|
subnets_per_network=subnets_per_network,
|
|
router_create_args=router_create_args)
|
|
|
|
scenario._create_network_structure.assert_called_once_with(
|
|
network_create_args, subnet_create_args, subnet_cidr_start,
|
|
subnets_per_network, router_create_args)
|
|
|
|
scenario._show_router.assert_has_calls(
|
|
[mock.call(router) for router in routers])
|
|
|
|
def test_create_and_list_ports(self):
|
|
port_create_args = {"allocation_pools": []}
|
|
ports_per_network = 10
|
|
network_create_args = {"router:external": True}
|
|
net = mock.MagicMock()
|
|
|
|
scenario = network.CreateAndListPorts(self.context)
|
|
scenario._get_or_create_network = mock.Mock(return_value=net)
|
|
scenario._create_port = mock.MagicMock()
|
|
scenario._list_ports = mock.Mock()
|
|
|
|
scenario.run(network_create_args=network_create_args,
|
|
port_create_args=port_create_args,
|
|
ports_per_network=ports_per_network)
|
|
scenario._get_or_create_network.assert_called_once_with(
|
|
network_create_args)
|
|
scenario._create_port.assert_has_calls(
|
|
[mock.call(net, port_create_args)
|
|
for _ in range(ports_per_network)])
|
|
|
|
scenario._list_ports.assert_called_once_with()
|
|
|
|
def test_create_and_update_ports(self):
|
|
port_update_args = {"admin_state_up": False},
|
|
port_create_args = {"allocation_pools": []}
|
|
ports_per_network = 10
|
|
network_create_args = {"router:external": True}
|
|
net = mock.MagicMock()
|
|
ports = [mock.MagicMock() for _ in range(ports_per_network)]
|
|
|
|
scenario = network.CreateAndUpdatePorts(self.context)
|
|
scenario._get_or_create_network = mock.Mock(return_value=net)
|
|
scenario._create_port = mock.Mock(side_effect=ports)
|
|
scenario._update_port = mock.Mock()
|
|
|
|
scenario.run(port_update_args,
|
|
network_create_args=network_create_args,
|
|
port_create_args=port_create_args,
|
|
ports_per_network=ports_per_network)
|
|
scenario._get_or_create_network.assert_called_once_with(
|
|
network_create_args)
|
|
scenario._create_port.assert_has_calls(
|
|
[mock.call(net, port_create_args)
|
|
for _ in range(ports_per_network)])
|
|
scenario._update_port.assert_has_calls(
|
|
[mock.call(p, port_update_args) for p in ports])
|
|
|
|
def test_create_and_show_ports_positive(self):
|
|
port_create_args = {"allocation_pools": []}
|
|
ports_per_network = 1
|
|
network_create_args = {"router:external": True}
|
|
net = mock.MagicMock()
|
|
|
|
scenario = network.CreateAndShowPorts(self.context)
|
|
scenario._get_or_create_network = mock.MagicMock(return_value=net)
|
|
scenario._create_port = mock.MagicMock()
|
|
scenario._show_port = mock.MagicMock()
|
|
port = {"port": {"id": 1, "name": "f"}}
|
|
port_info = {"port": {"id": 1, "name": "f", "status": "ACTIVE"}}
|
|
scenario._show_port.return_value = port_info
|
|
|
|
# Positive case:
|
|
scenario._create_port.return_value = port
|
|
scenario.run(network_create_args=network_create_args,
|
|
port_create_args=port_create_args,
|
|
ports_per_network=ports_per_network)
|
|
scenario._get_or_create_network.assert_called_once_with(
|
|
network_create_args)
|
|
scenario._create_port.assert_called_with(net, port_create_args)
|
|
scenario._show_port.assert_called_with(port)
|
|
|
|
def test_create_and_show_ports_negative(self):
|
|
port_create_args = {"allocation_pools": []}
|
|
ports_per_network = 1
|
|
network_create_args = {"router:external": True}
|
|
net = mock.MagicMock()
|
|
|
|
scenario = network.CreateAndShowPorts(self.context)
|
|
scenario._get_or_create_network = mock.MagicMock(return_value=net)
|
|
scenario._create_port = mock.MagicMock()
|
|
scenario._show_port = mock.MagicMock()
|
|
|
|
# Negative case1: port isn't created
|
|
scenario._create_port.return_value = None
|
|
self.assertRaises(rally_exceptions.RallyAssertionError,
|
|
scenario.run,
|
|
network_create_args,
|
|
port_create_args,
|
|
ports_per_network)
|
|
scenario._get_or_create_network.assert_called_once_with(
|
|
network_create_args)
|
|
scenario._create_port.assert_called_once_with(net, port_create_args)
|
|
|
|
# Negative case2: port isn't show
|
|
port = {"port": {"id": 1, "name": "f1"}}
|
|
port_info = {"port": {"id": 2, "name": "f2", "status": "ACTIVE"}}
|
|
scenario._show_port.return_value = port_info
|
|
scenario._create_port.return_value = port
|
|
|
|
self.assertRaises(rally_exceptions.RallyAssertionError,
|
|
scenario.run,
|
|
network_create_args,
|
|
port_create_args,
|
|
ports_per_network)
|
|
|
|
scenario._get_or_create_network.assert_called_with(
|
|
network_create_args)
|
|
scenario._create_port.assert_called_with(net, port_create_args)
|
|
scenario._show_port.assert_called_with(port)
|
|
|
|
def test_create_and_delete_ports(self):
|
|
port_create_args = {"allocation_pools": []}
|
|
ports_per_network = 10
|
|
network_create_args = {"router:external": True}
|
|
net = mock.MagicMock()
|
|
ports = [mock.MagicMock() for _ in range(ports_per_network)]
|
|
|
|
scenario = network.CreateAndDeletePorts(self.context)
|
|
scenario._get_or_create_network = mock.Mock(return_value=net)
|
|
scenario._create_port = mock.Mock(side_effect=ports)
|
|
scenario._delete_port = mock.Mock()
|
|
|
|
scenario.run(network_create_args=network_create_args,
|
|
port_create_args=port_create_args,
|
|
ports_per_network=ports_per_network)
|
|
scenario._get_or_create_network.assert_called_once_with(
|
|
network_create_args)
|
|
scenario._create_port.assert_has_calls(
|
|
[mock.call(net, port_create_args)
|
|
for _ in range(ports_per_network)])
|
|
scenario._delete_port.assert_has_calls(
|
|
[mock.call(p) for p in ports])
|
|
|
|
@ddt.data(
|
|
{"floating_network": "ext-net"},
|
|
{"floating_network": "ext-net",
|
|
"floating_ip_args": {"floating_ip_address": "1.1.1.1"}},
|
|
)
|
|
@ddt.unpack
|
|
def test_create_and_list_floating_ips(self, floating_network=None,
|
|
floating_ip_args=None):
|
|
scenario = network.CreateAndListFloatingIps(self.context)
|
|
floating_ip_args = floating_ip_args or {}
|
|
scenario._create_floatingip = mock.Mock()
|
|
scenario._list_floating_ips = mock.Mock()
|
|
scenario.run(floating_network=floating_network,
|
|
floating_ip_args=floating_ip_args)
|
|
scenario._create_floatingip.assert_called_once_with(
|
|
floating_network, **floating_ip_args)
|
|
scenario._list_floating_ips.assert_called_once_with()
|
|
|
|
@ddt.data(
|
|
{"floating_network": "ext-net"},
|
|
{"floating_network": "ext-net",
|
|
"floating_ip_args": {"floating_ip_address": "1.1.1.1"}},
|
|
)
|
|
@ddt.unpack
|
|
def test_create_and_delete_floating_ips(self, floating_network=None,
|
|
floating_ip_args=None):
|
|
scenario = network.CreateAndDeleteFloatingIps(self.context)
|
|
floating_ip_args = floating_ip_args or {}
|
|
fip = {"floatingip": {"id": "floating-ip-id"}}
|
|
scenario._create_floatingip = mock.Mock(return_value=fip)
|
|
scenario._delete_floating_ip = mock.Mock()
|
|
scenario.run(floating_network=floating_network,
|
|
floating_ip_args=floating_ip_args)
|
|
scenario._create_floatingip.assert_called_once_with(
|
|
floating_network, **floating_ip_args)
|
|
scenario._delete_floating_ip.assert_called_once_with(
|
|
scenario._create_floatingip.return_value["floatingip"])
|
|
|
|
def test_associate_and_dissociate_floating_ips(self):
|
|
scenario = network.AssociateAndDissociateFloatingIps(self.context)
|
|
|
|
fip = {"floatingip": {"id": "floating-ip-id"}}
|
|
subnet = {"subnet": {}}
|
|
port = {"port": {"id": "port-id"}}
|
|
router = {"router": {}}
|
|
|
|
scenario._create_floatingip = mock.Mock(return_value=fip)
|
|
scenario._create_network = mock.Mock()
|
|
scenario._create_subnet = mock.Mock(return_value=subnet)
|
|
scenario._create_port = mock.Mock(return_value=port)
|
|
scenario._create_router = mock.Mock(return_value=router)
|
|
scenario._get_network_id = mock.Mock()
|
|
scenario._add_gateway_router = mock.Mock()
|
|
scenario._add_interface_router = mock.Mock()
|
|
|
|
scenario._associate_floating_ip = mock.Mock()
|
|
scenario._dissociate_floating_ip = mock.Mock()
|
|
|
|
scenario.run(floating_network="public")
|
|
|
|
scenario._associate_floating_ip.assert_called_once_with(
|
|
floatingip=fip["floatingip"], port=port["port"])
|
|
scenario._dissociate_floating_ip.assert_called_once_with(
|
|
floatingip=fip["floatingip"])
|
|
|
|
@mock.patch("%s.DeleteSubnets._delete_subnet" % BASE)
|
|
def test_delete_subnets(self, mock__delete_subnet):
|
|
# do not guess what user will be used
|
|
self.context["user_choice_method"] = "round_robin"
|
|
# if it is the 4th iteration, the second user from the second tenant
|
|
# should be taken, which means that the second subnets from each
|
|
# tenant network should be removed.
|
|
self.context["iteration"] = 4
|
|
# in case of `round_robin` the user will be selected from the list of
|
|
# available users of particular tenant, not from the list of all
|
|
# tenants (i.e random choice). BUT to trigger selecting user and
|
|
# tenant `users` key should present in context dict
|
|
self.context["users"] = []
|
|
|
|
self.context["tenants"] = {
|
|
# this should not be used
|
|
"uuid-1": {
|
|
"id": "uuid-1",
|
|
"networks": [{"subnets": ["subnet-1"]}],
|
|
"users": [{"id": "user-1", "credential": mock.MagicMock()},
|
|
{"id": "user-2", "credential": mock.MagicMock()}]
|
|
},
|
|
# this is expected user
|
|
"uuid-2": {
|
|
"id": "uuid-2",
|
|
"networks": [
|
|
{"subnets": ["subnet-2", "subnet-3"]},
|
|
{"subnets": ["subnet-4", "subnet-5"]}],
|
|
"users": [{"id": "user-3", "credential": mock.MagicMock()},
|
|
{"id": "user-4", "credential": mock.MagicMock()}]
|
|
}
|
|
}
|
|
|
|
scenario = network.DeleteSubnets(self.context)
|
|
self.assertEqual("user-4", scenario.context["user"]["id"],
|
|
"Unexpected user is taken. The wrong subnets can be "
|
|
"affected(removed).")
|
|
|
|
scenario.run()
|
|
|
|
self.assertEqual(
|
|
[
|
|
mock.call({"subnet": {"id": "subnet-3"}}),
|
|
mock.call({"subnet": {"id": "subnet-5"}})
|
|
],
|
|
mock__delete_subnet.call_args_list)
|