Merge "Nova: make nova server scenarios easier with existing users"

This commit is contained in:
Jenkins 2015-08-20 14:54:11 +00:00 committed by Gerrit Code Review
commit f76acc91d6
2 changed files with 49 additions and 126 deletions

View File

@ -102,11 +102,8 @@ class NovaScenario(scenario.OpenStackScenario):
nets = [net["id"] nets = [net["id"]
for net in ctxt.get("tenant", {}).get("networks", [])] for net in ctxt.get("tenant", {}).get("networks", [])]
if nets: if nets:
# NOTE(amaretskiy): Balance servers among networks: # NOTE(amaretskiy): Balance servers among networks.
# divmod(iteration % tenants_num, nets_num)[1] net_idx = self.context["iteration"] % len(nets)
net_idx = divmod(
(ctxt["iteration"] % ctxt["config"]["users"]["tenants"]),
len(nets))[1]
return [{"net-id": nets[net_idx]}] return [{"net-id": nets[net_idx]}]
@atomic.action_timer("nova.boot_server") @atomic.action_timer("nova.boot_server")

View File

@ -13,6 +13,7 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
import ddt
import mock import mock
from oslo_config import cfg from oslo_config import cfg
@ -26,6 +27,7 @@ NOVA_UTILS = "rally.plugins.openstack.scenarios.nova.utils"
CONF = cfg.CONF CONF = cfg.CONF
@ddt.ddt
class NovaScenarioTestCase(test.ScenarioTestCase): class NovaScenarioTestCase(test.ScenarioTestCase):
def setUp(self): def setUp(self):
@ -49,8 +51,7 @@ class NovaScenarioTestCase(test.ScenarioTestCase):
def test__pick_random_nic(self): def test__pick_random_nic(self):
context = {"tenant": {"networks": [{"id": "net_id_1"}, context = {"tenant": {"networks": [{"id": "net_id_1"},
{"id": "net_id_2"}]}, {"id": "net_id_2"}]},
"iteration": 0, "iteration": 0}
"config": {"users": {"tenants": 2}}}
nova_scenario = utils.NovaScenario(context=context) nova_scenario = utils.NovaScenario(context=context)
nic1 = nova_scenario._pick_random_nic() nic1 = nova_scenario._pick_random_nic()
self.assertEqual(nic1, [{"net-id": "net_id_1"}]) self.assertEqual(nic1, [{"net-id": "net_id_1"}])
@ -67,41 +68,33 @@ class NovaScenarioTestCase(test.ScenarioTestCase):
# balance again, get net 1 # balance again, get net 1
self.assertEqual(nic3, [{"net-id": "net_id_1"}]) self.assertEqual(nic3, [{"net-id": "net_id_1"}])
@mock.patch(NOVA_UTILS + ".NovaScenario._generate_random_name", @ddt.data(
return_value="foo_server_name") {},
def test__boot_server(self, mock__generate_random_name): {"kwargs": {"auto_assign_nic": True}},
{"kwargs": {"auto_assign_nic": True, "nics": [{"net-id": "baz_id"}]}},
{"context": {"user": {"secgroup": {"name": "test"}}}},
{"context": {"user": {"secgroup": {"name": "new"}}},
"kwargs": {"security_groups": ["test"]}},
{"context": {"user": {"secgroup": {"name": "test1"}}},
"kwargs": {"security_groups": ["test1"]}},
)
@ddt.unpack
def test__boot_server(self, context=None, kwargs=None):
self.clients("nova").servers.create.return_value = self.server self.clients("nova").servers.create.return_value = self.server
nova_scenario = utils.NovaScenario(context={})
return_server = nova_scenario._boot_server("image_id",
"flavor_id")
self.mock_wait_for.mock.assert_called_once_with(
self.server,
is_ready=self.mock_resource_is.mock.return_value,
update_resource=self.mock_get_from_manager.mock.return_value,
check_interval=CONF.benchmark.nova_server_boot_poll_interval,
timeout=CONF.benchmark.nova_server_boot_timeout)
self.mock_resource_is.mock.assert_called_once_with("ACTIVE")
self.mock_get_from_manager.mock.assert_called_once_with()
self.assertEqual(self.mock_wait_for.mock.return_value, return_server)
self.clients("nova").servers.create.assert_called_once_with(
"foo_server_name", "image_id", "flavor_id")
self._test_atomic_action_timer(nova_scenario.atomic_actions(),
"nova.boot_server")
@mock.patch(NOVA_UTILS + ".NovaScenario._generate_random_name", if context is None:
return_value="foo_server_name") context = {}
def test__boot_server_with_network(self, mock__generate_random_name): context.setdefault("user", {}).setdefault("endpoint", mock.MagicMock())
self.clients("nova").servers.create.return_value = self.server context.setdefault("config", {})
networks = [{"id": "foo_id", "external": False},
{"id": "bar_id", "external": False}] nova_scenario = utils.NovaScenario(context=context)
self.clients("nova").networks.list.return_value = networks nova_scenario._generate_random_name = mock.Mock()
nova_scenario = utils.NovaScenario(context={ nova_scenario._pick_random_nic = mock.Mock()
"iteration": 3, if kwargs is None:
"config": {"users": {"tenants": 2}}, kwargs = {}
"tenant": {"networks": networks}}) kwargs["fakearg"] = "fakearg"
return_server = nova_scenario._boot_server("image_id", return_server = nova_scenario._boot_server("image_id", "flavor_id",
"flavor_id", **kwargs)
auto_assign_nic=True)
self.mock_wait_for.mock.assert_called_once_with( self.mock_wait_for.mock.assert_called_once_with(
self.server, self.server,
is_ready=self.mock_resource_is.mock.return_value, is_ready=self.mock_resource_is.mock.return_value,
@ -110,10 +103,26 @@ class NovaScenarioTestCase(test.ScenarioTestCase):
timeout=CONF.benchmark.nova_server_boot_timeout) timeout=CONF.benchmark.nova_server_boot_timeout)
self.mock_resource_is.mock.assert_called_once_with("ACTIVE") self.mock_resource_is.mock.assert_called_once_with("ACTIVE")
self.mock_get_from_manager.mock.assert_called_once_with() self.mock_get_from_manager.mock.assert_called_once_with()
self.clients("nova").servers.create.assert_called_once_with(
"foo_server_name", "image_id", "flavor_id",
nics=[{"net-id": "bar_id"}])
self.assertEqual(self.mock_wait_for.mock.return_value, return_server) self.assertEqual(self.mock_wait_for.mock.return_value, return_server)
expected_kwargs = {"fakearg": "fakearg"}
if "nics" in kwargs:
expected_kwargs["nics"] = kwargs["nics"]
elif "auto_assign_nic" in kwargs:
expected_kwargs["nics"] = (nova_scenario._pick_random_nic.
return_value)
expected_secgroups = set()
if "security_groups" in kwargs:
expected_secgroups.update(kwargs["security_groups"])
if "secgroup" in context["user"]:
expected_secgroups.add(context["user"]["secgroup"]["name"])
if expected_secgroups:
expected_kwargs["security_groups"] = list(expected_secgroups)
self.clients("nova").servers.create.assert_called_once_with(
nova_scenario._generate_random_name.return_value,
"image_id", "flavor_id", **expected_kwargs)
self._test_atomic_action_timer(nova_scenario.atomic_actions(), self._test_atomic_action_timer(nova_scenario.atomic_actions(),
"nova.boot_server") "nova.boot_server")
@ -125,89 +134,6 @@ class NovaScenarioTestCase(test.ScenarioTestCase):
"image_id", "flavor_id", "image_id", "flavor_id",
auto_assign_nic=True) auto_assign_nic=True)
@mock.patch(NOVA_UTILS + ".NovaScenario._generate_random_name",
return_value="foo_server_name")
def test__boot_server_with_ssh(self, mock__generate_random_name):
self.clients("nova").servers.create.return_value = self.server
nova_scenario = utils.NovaScenario(context={
"user": {
"secgroup": {"name": "test"},
"endpoint": mock.MagicMock()
}}
)
return_server = nova_scenario._boot_server("image_id", "flavor_id")
self.mock_wait_for.mock.assert_called_once_with(
self.server,
is_ready=self.mock_resource_is.mock.return_value,
update_resource=self.mock_get_from_manager.mock.return_value,
check_interval=CONF.benchmark.nova_server_boot_poll_interval,
timeout=CONF.benchmark.nova_server_boot_timeout)
self.mock_resource_is.mock.assert_called_once_with("ACTIVE")
self.mock_get_from_manager.mock.assert_called_once_with()
self.assertEqual(self.mock_wait_for.mock.return_value, return_server)
self.clients("nova").servers.create.assert_called_once_with(
"foo_server_name", "image_id", "flavor_id",
security_groups=["test"])
self._test_atomic_action_timer(nova_scenario.atomic_actions(),
"nova.boot_server")
@mock.patch(NOVA_UTILS + ".NovaScenario._generate_random_name",
return_value="foo_server_name")
def test__boot_server_with_sec_group(self, mock__generate_random_name):
self.clients("nova").servers.create.return_value = self.server
nova_scenario = utils.NovaScenario(context={
"user": {
"secgroup": {"name": "new"},
"endpoint": mock.MagicMock()
}
})
return_server = nova_scenario._boot_server(
"image_id", "flavor_id",
security_groups=["test"])
self.mock_wait_for.mock.assert_called_once_with(
self.server,
is_ready=self.mock_resource_is.mock.return_value,
update_resource=self.mock_get_from_manager.mock.return_value,
check_interval=CONF.benchmark.nova_server_boot_poll_interval,
timeout=CONF.benchmark.nova_server_boot_timeout)
self.mock_resource_is.mock.assert_called_once_with("ACTIVE")
self.mock_get_from_manager.mock.assert_called_once_with()
self.assertEqual(self.mock_wait_for.mock.return_value, return_server)
self.clients("nova").servers.create.assert_called_once_with(
"foo_server_name", "image_id", "flavor_id",
security_groups=["test", "new"])
self._test_atomic_action_timer(nova_scenario.atomic_actions(),
"nova.boot_server")
@mock.patch(NOVA_UTILS + ".NovaScenario._generate_random_name",
return_value="foo_server_name")
def test__boot_server_with_similar_sec_group(self,
mock__generate_random_name):
self.clients("nova").servers.create.return_value = self.server
nova_scenario = utils.NovaScenario(context={
"user": {
"secgroup": {"name": "test1"},
"endpoint": mock.MagicMock()
}}
)
return_server = nova_scenario._boot_server(
"image_id", "flavor_id",
security_groups=["test1"])
self.mock_wait_for.mock.assert_called_once_with(
self.server,
is_ready=self.mock_resource_is.mock.return_value,
update_resource=self.mock_get_from_manager.mock.return_value,
check_interval=CONF.benchmark.nova_server_boot_poll_interval,
timeout=CONF.benchmark.nova_server_boot_timeout)
self.mock_resource_is.mock.assert_called_once_with("ACTIVE")
self.mock_get_from_manager.mock.assert_called_once_with()
self.assertEqual(self.mock_wait_for.mock.return_value, return_server)
self.clients("nova").servers.create.assert_called_once_with(
"foo_server_name", "image_id", "flavor_id",
security_groups=["test1"])
self._test_atomic_action_timer(nova_scenario.atomic_actions(),
"nova.boot_server")
def test__suspend_server(self): def test__suspend_server(self):
nova_scenario = utils.NovaScenario() nova_scenario = utils.NovaScenario()
nova_scenario._suspend_server(self.server) nova_scenario._suspend_server(self.server)