d2f4e9717d
Move all modules under the next structure: - rally_openstack.common - rally_openstack.enviromnet - rally_openstack.task - rally_openstack.verification Change-Id: I41702d017cd49b117da3b8e12b19c7327229ae32
183 lines
6.5 KiB
Python
183 lines
6.5 KiB
Python
# 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.
|
|
|
|
from unittest import mock
|
|
|
|
from rally import exceptions
|
|
from rally_openstack.task.contexts.sahara import sahara_image
|
|
from tests.unit import fakes
|
|
from tests.unit import test
|
|
|
|
|
|
BASE_CTX = "rally.task.context"
|
|
CTX = "rally_openstack.task.contexts.sahara.sahara_image"
|
|
BASE_SCN = "rally.task.scenarios"
|
|
|
|
|
|
class SaharaImageTestCase(test.ScenarioTestCase):
|
|
|
|
def setUp(self):
|
|
super(SaharaImageTestCase, self).setUp()
|
|
self.tenants_num = 2
|
|
self.users_per_tenant = 2
|
|
self.users = self.tenants_num * self.users_per_tenant
|
|
self.task = mock.MagicMock()
|
|
|
|
self.tenants = {}
|
|
self.users_key = []
|
|
|
|
for i in range(self.tenants_num):
|
|
self.tenants[str(i)] = {"id": str(i), "name": str(i),
|
|
"sahara": {"image": "42"}}
|
|
for j in range(self.users_per_tenant):
|
|
self.users_key.append({"id": "%s_%s" % (str(i), str(j)),
|
|
"tenant_id": str(i),
|
|
"credential": fakes.FakeCredential()})
|
|
|
|
@property
|
|
def url_image_context(self):
|
|
self.context.update({
|
|
"config": {
|
|
"users": {
|
|
"tenants": self.tenants_num,
|
|
"users_per_tenant": self.users_per_tenant,
|
|
},
|
|
"sahara_image": {
|
|
"image_url": "http://somewhere",
|
|
"plugin_name": "test_plugin",
|
|
"hadoop_version": "test_version",
|
|
"username": "test_user"
|
|
}
|
|
},
|
|
"admin": {"credential": fakes.FakeCredential()},
|
|
"users": self.users_key,
|
|
"tenants": self.tenants
|
|
})
|
|
return self.context
|
|
|
|
@property
|
|
def existing_image_context(self):
|
|
self.context.update({
|
|
"config": {
|
|
"users": {
|
|
"tenants": self.tenants_num,
|
|
"users_per_tenant": self.users_per_tenant,
|
|
},
|
|
"sahara_image": {
|
|
"image_uuid": "some_id"
|
|
}
|
|
},
|
|
"admin": {"credential": fakes.FakeCredential()},
|
|
"users": self.users_key,
|
|
"tenants": self.tenants,
|
|
})
|
|
return self.context
|
|
|
|
@mock.patch("rally_openstack.common.services."
|
|
"image.image.Image")
|
|
@mock.patch("%s.resource_manager.cleanup" % CTX)
|
|
@mock.patch("rally_openstack.common.osclients.Clients")
|
|
def test_setup_and_cleanup_url_image(self, mock_clients,
|
|
mock_cleanup, mock_image):
|
|
|
|
ctx = self.url_image_context
|
|
sahara_ctx = sahara_image.SaharaImage(ctx)
|
|
sahara_ctx.generate_random_name = mock.Mock()
|
|
image_service = mock.Mock()
|
|
mock_image.return_value = image_service
|
|
image_service.create_image.return_value = mock.Mock(id=42)
|
|
clients = mock.Mock()
|
|
mock_clients.return_value = clients
|
|
sahara_client = mock.Mock()
|
|
clients.sahara.return_value = sahara_client
|
|
|
|
glance_calls = []
|
|
|
|
for i in range(self.tenants_num):
|
|
glance_calls.append(
|
|
mock.call(container_format="bare",
|
|
image_location="http://somewhere",
|
|
disk_format="qcow2"))
|
|
|
|
sahara_update_image_calls = []
|
|
sahara_update_tags_calls = []
|
|
|
|
for i in range(self.tenants_num):
|
|
sahara_update_image_calls.append(mock.call(image_id=42,
|
|
user_name="test_user",
|
|
desc=""))
|
|
sahara_update_tags_calls.append(mock.call(
|
|
image_id=42,
|
|
new_tags=["test_plugin", "test_version"]))
|
|
|
|
sahara_ctx.setup()
|
|
image_service.create_image.assert_has_calls(glance_calls)
|
|
sahara_client.images.update_image.assert_has_calls(
|
|
sahara_update_image_calls)
|
|
sahara_client.images.update_tags.assert_has_calls(
|
|
sahara_update_tags_calls)
|
|
|
|
sahara_ctx.cleanup()
|
|
mock_cleanup.assert_called_once_with(
|
|
names=["glance.images"],
|
|
users=ctx["users"],
|
|
superclass=sahara_ctx.__class__,
|
|
task_id=ctx["owner_id"])
|
|
|
|
@mock.patch("%s.resource_manager.cleanup" % CTX)
|
|
@mock.patch("%s.osclients.Clients" % CTX)
|
|
def test_setup_and_cleanup_existing_image(
|
|
self, mock_clients, mock_cleanup):
|
|
|
|
mock_clients.glance.images.get.return_value = mock.MagicMock(
|
|
is_public=True)
|
|
|
|
ctx = self.existing_image_context
|
|
sahara_ctx = sahara_image.SaharaImage(ctx)
|
|
sahara_ctx._create_image = mock.Mock()
|
|
|
|
sahara_ctx.setup()
|
|
for tenant_id in sahara_ctx.context["tenants"]:
|
|
image_id = (
|
|
sahara_ctx.context["tenants"][tenant_id]["sahara"]["image"])
|
|
self.assertEqual("some_id", image_id)
|
|
|
|
self.assertFalse(sahara_ctx._create_image.called)
|
|
|
|
sahara_ctx.cleanup()
|
|
self.assertFalse(mock_cleanup.called)
|
|
|
|
@mock.patch("%s.osclients.Glance.create_client" % CTX)
|
|
def test_check_existing_image(self, mock_glance_create_client):
|
|
|
|
ctx = self.existing_image_context
|
|
sahara_ctx = sahara_image.SaharaImage(ctx)
|
|
sahara_ctx.setup()
|
|
|
|
mock_glance_create_client.images.get.asser_called_once_with("some_id")
|
|
|
|
@mock.patch("%s.osclients.Glance.create_client" % CTX)
|
|
def test_check_existing_private_image_fail(self,
|
|
mock_glance_create_client):
|
|
|
|
mock_glance_create_client.return_value.images.get.return_value = (
|
|
mock.MagicMock(is_public=False))
|
|
|
|
ctx = self.existing_image_context
|
|
sahara_ctx = sahara_image.SaharaImage(ctx)
|
|
self.assertRaises(exceptions.ContextSetupFailure,
|
|
sahara_ctx.setup)
|
|
|
|
mock_glance_create_client.images.get.asser_called_once_with("some_id")
|