Merge "Mox removal for ClustersTests"
This commit is contained in:
commit
45fa932db7
@ -16,10 +16,9 @@
|
|||||||
|
|
||||||
import logging
|
import logging
|
||||||
|
|
||||||
from django import http
|
|
||||||
from django.urls import reverse
|
from django.urls import reverse
|
||||||
|
|
||||||
from mox3.mox import IsA # noqa
|
import mock
|
||||||
|
|
||||||
from openstack_dashboard import api
|
from openstack_dashboard import api
|
||||||
from troveclient import common
|
from troveclient import common
|
||||||
@ -38,95 +37,81 @@ RESET_PASSWORD_VIEWNAME = 'horizon:project:database_clusters:reset_password'
|
|||||||
|
|
||||||
|
|
||||||
class ClustersTests(test.TestCase):
|
class ClustersTests(test.TestCase):
|
||||||
@test.create_stubs({trove_api.trove: ('cluster_list',
|
@test.create_mocks({trove_api.trove: ('cluster_list',
|
||||||
'flavor_list')})
|
'flavor_list')})
|
||||||
def test_index(self):
|
def test_index(self):
|
||||||
clusters = common.Paginated(self.trove_clusters.list())
|
clusters = common.Paginated(self.trove_clusters.list())
|
||||||
trove_api.trove.cluster_list(IsA(http.HttpRequest), marker=None)\
|
self.mock_cluster_list.return_value = clusters
|
||||||
.AndReturn(clusters)
|
self.mock_flavor_list.return_value = self.flavors.list()
|
||||||
trove_api.trove.flavor_list(IsA(http.HttpRequest))\
|
|
||||||
.AndReturn(self.flavors.list())
|
|
||||||
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
res = self.client.get(INDEX_URL)
|
res = self.client.get(INDEX_URL)
|
||||||
|
self.mock_cluster_list.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), marker=None)
|
||||||
|
self.mock_flavor_list.assert_called_once_with(test.IsHttpRequest())
|
||||||
self.assertTemplateUsed(res, 'project/database_clusters/index.html')
|
self.assertTemplateUsed(res, 'project/database_clusters/index.html')
|
||||||
|
|
||||||
@test.create_stubs({trove_api.trove: ('cluster_list',
|
@test.create_mocks({trove_api.trove: ('cluster_list',
|
||||||
'flavor_list')})
|
'flavor_list')})
|
||||||
def test_index_flavor_exception(self):
|
def test_index_flavor_exception(self):
|
||||||
clusters = common.Paginated(self.trove_clusters.list())
|
clusters = common.Paginated(self.trove_clusters.list())
|
||||||
trove_api.trove.cluster_list(IsA(http.HttpRequest), marker=None)\
|
self.mock_cluster_list.return_value = clusters
|
||||||
.AndReturn(clusters)
|
self.mock_flavor_list.side_effect = self.exceptions.trove
|
||||||
trove_api.trove.flavor_list(IsA(http.HttpRequest))\
|
|
||||||
.AndRaise(self.exceptions.trove)
|
|
||||||
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
res = self.client.get(INDEX_URL)
|
res = self.client.get(INDEX_URL)
|
||||||
|
self.mock_cluster_list.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), marker=None)
|
||||||
|
self.mock_flavor_list.assert_called_once_with(test.IsHttpRequest())
|
||||||
self.assertTemplateUsed(res, 'project/database_clusters/index.html')
|
self.assertTemplateUsed(res, 'project/database_clusters/index.html')
|
||||||
self.assertMessageCount(res, error=1)
|
self.assertMessageCount(res, error=1)
|
||||||
|
|
||||||
@test.create_stubs({trove_api.trove: ('cluster_list',)})
|
@test.create_mocks({trove_api.trove: ('cluster_list',)})
|
||||||
def test_index_list_exception(self):
|
def test_index_list_exception(self):
|
||||||
trove_api.trove.cluster_list(IsA(http.HttpRequest), marker=None)\
|
self.mock_cluster_list.side_effect = self.exceptions.trove
|
||||||
.AndRaise(self.exceptions.trove)
|
|
||||||
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
res = self.client.get(INDEX_URL)
|
res = self.client.get(INDEX_URL)
|
||||||
|
self.mock_cluster_list.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), marker=None)
|
||||||
self.assertTemplateUsed(res, 'project/database_clusters/index.html')
|
self.assertTemplateUsed(res, 'project/database_clusters/index.html')
|
||||||
self.assertMessageCount(res, error=1)
|
self.assertMessageCount(res, error=1)
|
||||||
|
|
||||||
@test.create_stubs({trove_api.trove: ('cluster_list',
|
@test.create_mocks({trove_api.trove: ('cluster_list',
|
||||||
'flavor_list')})
|
'flavor_list')})
|
||||||
def test_index_pagination(self):
|
def test_index_pagination(self):
|
||||||
clusters = self.trove_clusters.list()
|
clusters = self.trove_clusters.list()
|
||||||
last_record = clusters[1]
|
last_record = clusters[1]
|
||||||
clusters = common.Paginated(clusters, next_marker="foo")
|
clusters = common.Paginated(clusters, next_marker="foo")
|
||||||
trove_api.trove.cluster_list(IsA(http.HttpRequest), marker=None)\
|
self.mock_cluster_list.return_value = clusters
|
||||||
.AndReturn(clusters)
|
self.mock_flavor_list.return_value = self.flavors.list()
|
||||||
trove_api.trove.flavor_list(IsA(http.HttpRequest))\
|
|
||||||
.AndReturn(self.flavors.list())
|
|
||||||
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
res = self.client.get(INDEX_URL)
|
res = self.client.get(INDEX_URL)
|
||||||
|
self.mock_cluster_list.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), marker=None)
|
||||||
|
self.mock_flavor_list.assert_called_once_with(test.IsHttpRequest())
|
||||||
self.assertTemplateUsed(res, 'project/database_clusters/index.html')
|
self.assertTemplateUsed(res, 'project/database_clusters/index.html')
|
||||||
self.assertContains(
|
self.assertContains(
|
||||||
res, 'marker=' + last_record.id)
|
res, 'marker=' + last_record.id)
|
||||||
|
|
||||||
@test.create_stubs({trove_api.trove: ('cluster_list',
|
@test.create_mocks({trove_api.trove: ('datastore_flavors',
|
||||||
'flavor_list')})
|
|
||||||
def test_index_flavor_list_exception(self):
|
|
||||||
clusters = common.Paginated(self.trove_clusters.list())
|
|
||||||
trove_api.trove.cluster_list(IsA(http.HttpRequest), marker=None)\
|
|
||||||
.AndReturn(clusters)
|
|
||||||
trove_api.trove.flavor_list(IsA(http.HttpRequest))\
|
|
||||||
.AndRaise(self.exceptions.trove)
|
|
||||||
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
res = self.client.get(INDEX_URL)
|
|
||||||
|
|
||||||
self.assertTemplateUsed(res, 'project/database_clusters/index.html')
|
|
||||||
self.assertMessageCount(res, error=1)
|
|
||||||
|
|
||||||
@test.create_stubs({trove_api.trove: ('datastore_flavors',
|
|
||||||
'datastore_list',
|
'datastore_list',
|
||||||
'datastore_version_list'),
|
'datastore_version_list'),
|
||||||
api.base: ['is_service_enabled']})
|
api.base: ['is_service_enabled']})
|
||||||
def test_launch_cluster(self):
|
def test_launch_cluster(self):
|
||||||
api.base.is_service_enabled(IsA(http.HttpRequest), 'network')\
|
self.mock_is_service_enabled.return_value = False
|
||||||
.AndReturn(False)
|
self.mock_datastore_flavors.return_value = self.flavors.list()
|
||||||
|
|
||||||
filtered_datastores = self._get_filtered_datastores('mongodb')
|
filtered_datastores = self._get_filtered_datastores('mongodb')
|
||||||
trove_api.trove.datastore_flavors(IsA(http.HttpRequest),
|
self.mock_datastore_list.return_value = filtered_datastores
|
||||||
'mongodb', '2.6')\
|
self.mock_datastore_version_list.return_value = (
|
||||||
.AndReturn(self.flavors.list())
|
self._get_filtered_datastore_versions(filtered_datastores))
|
||||||
trove_api.trove.datastore_list(IsA(http.HttpRequest))\
|
|
||||||
.AndReturn(filtered_datastores)
|
|
||||||
trove_api.trove.datastore_version_list(IsA(http.HttpRequest),
|
|
||||||
IsA(str))\
|
|
||||||
.AndReturn(
|
|
||||||
self._get_filtered_datastore_versions(filtered_datastores))
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
res = self.client.get(LAUNCH_URL)
|
res = self.client.get(LAUNCH_URL)
|
||||||
|
self.mock_is_service_enabled.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), 'network')
|
||||||
|
self.mock_datastore_flavors.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), 'mongodb', '2.6')
|
||||||
|
self.mock_datastore_list.assert_called_once_with(test.IsHttpRequest())
|
||||||
|
self.mock_datastore_version_list.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), test.IsA(str))
|
||||||
self.assertTemplateUsed(res, 'project/database_clusters/launch.html')
|
self.assertTemplateUsed(res, 'project/database_clusters/launch.html')
|
||||||
|
|
||||||
def test_launch_cluster_mongo_fields(self):
|
def test_launch_cluster_mongo_fields(self):
|
||||||
@ -186,45 +171,44 @@ class ClustersTests(test.TestCase):
|
|||||||
self.assertTrue(self._contains_datastore_in_attribute(
|
self.assertTrue(self._contains_datastore_in_attribute(
|
||||||
fields['num_instances_vertica'], field_name))
|
fields['num_instances_vertica'], field_name))
|
||||||
|
|
||||||
@test.create_stubs({trove_api.trove: ('datastore_flavors',
|
@test.create_mocks({trove_api.trove: ('datastore_flavors',
|
||||||
'datastore_list',
|
'datastore_list',
|
||||||
'datastore_version_list'),
|
'datastore_version_list'),
|
||||||
api.base: ['is_service_enabled']})
|
api.base: ['is_service_enabled']})
|
||||||
def launch_cluster_fields_setup(self, datastore, datastore_version):
|
def launch_cluster_fields_setup(self, datastore, datastore_version):
|
||||||
api.base.is_service_enabled(IsA(http.HttpRequest), 'network')\
|
self.mock_is_service_enabled.return_value = False
|
||||||
.AndReturn(False)
|
self.mock_datastore_flavors.return_value = self.flavors.list()
|
||||||
|
|
||||||
filtered_datastores = self._get_filtered_datastores(datastore)
|
filtered_datastores = self._get_filtered_datastores(datastore)
|
||||||
trove_api.trove.datastore_flavors(IsA(http.HttpRequest),
|
self.mock_datastore_list.return_value = filtered_datastores
|
||||||
datastore, datastore_version)\
|
self.mock_datastore_version_list.return_value = (
|
||||||
.AndReturn(self.flavors.list())
|
self._get_filtered_datastore_versions(filtered_datastores))
|
||||||
trove_api.trove.datastore_list(IsA(http.HttpRequest))\
|
|
||||||
.AndReturn(filtered_datastores)
|
|
||||||
trove_api.trove.datastore_version_list(IsA(http.HttpRequest),
|
|
||||||
IsA(str))\
|
|
||||||
.AndReturn(
|
|
||||||
self._get_filtered_datastore_versions(filtered_datastores))
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
res = self.client.get(LAUNCH_URL)
|
res = self.client.get(LAUNCH_URL)
|
||||||
|
self.mock_is_service_enabled.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), 'network')
|
||||||
|
self.mock_datastore_flavors.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), datastore, datastore_version)
|
||||||
|
self.mock_datastore_list.assert_called_once_with(test.IsHttpRequest())
|
||||||
|
self.mock_datastore_version_list.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), test.IsA(str))
|
||||||
return res.context_data['form'].fields
|
return res.context_data['form'].fields
|
||||||
|
|
||||||
@test.create_stubs({trove_api.trove: ['datastore_flavors',
|
@test.create_mocks({trove_api.trove: ['datastore_flavors',
|
||||||
'cluster_create',
|
'cluster_create',
|
||||||
'datastore_list',
|
'datastore_list',
|
||||||
'datastore_version_list'],
|
'datastore_version_list'],
|
||||||
api.base: ['is_service_enabled']})
|
api.base: ['is_service_enabled']})
|
||||||
def test_create_simple_cluster(self):
|
def test_create_simple_cluster(self):
|
||||||
api.base.is_service_enabled(IsA(http.HttpRequest), 'network')\
|
self.mock_is_service_enabled.return_value = False
|
||||||
.AndReturn(False)
|
self.mock_datastore_flavors.return_value = self.flavors.list()
|
||||||
|
|
||||||
filtered_datastores = self._get_filtered_datastores('mongodb')
|
filtered_datastores = self._get_filtered_datastores('mongodb')
|
||||||
trove_api.trove.datastore_flavors(IsA(http.HttpRequest),
|
self.mock_datastore_list.return_value = filtered_datastores
|
||||||
'mongodb', '2.6')\
|
self.mock_datastore_version_list.return_value = (
|
||||||
.AndReturn(self.flavors.list())
|
self._get_filtered_datastore_versions(filtered_datastores))
|
||||||
trove_api.trove.datastore_list(IsA(http.HttpRequest))\
|
|
||||||
.AndReturn(filtered_datastores)
|
self.mock_cluster_create.return_value = self.trove_clusters.first()
|
||||||
trove_api.trove.datastore_version_list(IsA(http.HttpRequest),
|
|
||||||
IsA(str))\
|
|
||||||
.AndReturn(
|
|
||||||
self._get_filtered_datastore_versions(filtered_datastores))
|
|
||||||
|
|
||||||
cluster_name = u'MyCluster'
|
cluster_name = u'MyCluster'
|
||||||
cluster_volume = 1
|
cluster_volume = 1
|
||||||
@ -233,21 +217,9 @@ class ClustersTests(test.TestCase):
|
|||||||
cluster_datastore = u'mongodb'
|
cluster_datastore = u'mongodb'
|
||||||
cluster_datastore_version = u'2.6'
|
cluster_datastore_version = u'2.6'
|
||||||
cluster_network = u''
|
cluster_network = u''
|
||||||
trove_api.trove.cluster_create(
|
|
||||||
IsA(http.HttpRequest),
|
|
||||||
cluster_name,
|
|
||||||
cluster_volume,
|
|
||||||
cluster_flavor,
|
|
||||||
cluster_instances,
|
|
||||||
datastore=cluster_datastore,
|
|
||||||
datastore_version=cluster_datastore_version,
|
|
||||||
nics=cluster_network,
|
|
||||||
root_password=None,
|
|
||||||
locality=None).AndReturn(self.trove_clusters.first())
|
|
||||||
|
|
||||||
field_name = self._build_flavor_widget_name(cluster_datastore,
|
field_name = self._build_flavor_widget_name(cluster_datastore,
|
||||||
cluster_datastore_version)
|
cluster_datastore_version)
|
||||||
self.mox.ReplayAll()
|
|
||||||
post = {
|
post = {
|
||||||
'name': cluster_name,
|
'name': cluster_name,
|
||||||
'volume': cluster_volume,
|
'volume': cluster_volume,
|
||||||
@ -258,40 +230,15 @@ class ClustersTests(test.TestCase):
|
|||||||
}
|
}
|
||||||
|
|
||||||
res = self.client.post(LAUNCH_URL, post)
|
res = self.client.post(LAUNCH_URL, post)
|
||||||
self.assertNoFormErrors(res)
|
self.mock_is_service_enabled.assert_called_once_with(
|
||||||
self.assertMessageCount(success=1)
|
test.IsHttpRequest(), 'network')
|
||||||
|
self.mock_datastore_flavors.assert_called_once_with(
|
||||||
@test.create_stubs({trove_api.trove: ['datastore_flavors',
|
test.IsHttpRequest(), 'mongodb', '2.6')
|
||||||
'cluster_create',
|
self.mock_datastore_list.assert_called_once_with(test.IsHttpRequest())
|
||||||
'datastore_list',
|
self.mock_datastore_version_list.assert_called_once_with(
|
||||||
'datastore_version_list'],
|
test.IsHttpRequest(), test.IsA(str))
|
||||||
api.neutron: ['network_list_for_tenant'],
|
self.mock_cluster_create.assert_called_once_with(
|
||||||
api.base: ['is_service_enabled']})
|
test.IsHttpRequest(),
|
||||||
def test_create_simple_cluster_neutron(self):
|
|
||||||
api.base.is_service_enabled(IsA(http.HttpRequest), 'network')\
|
|
||||||
.AndReturn(True)
|
|
||||||
api.neutron.network_list_for_tenant(IsA(http.HttpRequest), '1')\
|
|
||||||
.AndReturn(self.networks.list())
|
|
||||||
filtered_datastores = self._get_filtered_datastores('mongodb')
|
|
||||||
trove_api.trove.datastore_flavors(IsA(http.HttpRequest),
|
|
||||||
'mongodb', '2.6')\
|
|
||||||
.AndReturn(self.flavors.list())
|
|
||||||
trove_api.trove.datastore_list(IsA(http.HttpRequest))\
|
|
||||||
.AndReturn(filtered_datastores)
|
|
||||||
trove_api.trove.datastore_version_list(IsA(http.HttpRequest),
|
|
||||||
IsA(str))\
|
|
||||||
.AndReturn(
|
|
||||||
self._get_filtered_datastore_versions(filtered_datastores))
|
|
||||||
|
|
||||||
cluster_name = u'MyCluster'
|
|
||||||
cluster_volume = 1
|
|
||||||
cluster_flavor = u'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa'
|
|
||||||
cluster_instances = 3
|
|
||||||
cluster_datastore = u'mongodb'
|
|
||||||
cluster_datastore_version = u'2.6'
|
|
||||||
cluster_network = u'82288d84-e0a5-42ac-95be-e6af08727e42'
|
|
||||||
trove_api.trove.cluster_create(
|
|
||||||
IsA(http.HttpRequest),
|
|
||||||
cluster_name,
|
cluster_name,
|
||||||
cluster_volume,
|
cluster_volume,
|
||||||
cluster_flavor,
|
cluster_flavor,
|
||||||
@ -300,11 +247,38 @@ class ClustersTests(test.TestCase):
|
|||||||
datastore_version=cluster_datastore_version,
|
datastore_version=cluster_datastore_version,
|
||||||
nics=cluster_network,
|
nics=cluster_network,
|
||||||
root_password=None,
|
root_password=None,
|
||||||
locality=None).AndReturn(self.trove_clusters.first())
|
locality=None)
|
||||||
|
self.assertNoFormErrors(res)
|
||||||
|
self.assertMessageCount(success=1)
|
||||||
|
|
||||||
|
@test.create_mocks({trove_api.trove: ['datastore_flavors',
|
||||||
|
'cluster_create',
|
||||||
|
'datastore_list',
|
||||||
|
'datastore_version_list'],
|
||||||
|
api.neutron: ['network_list_for_tenant'],
|
||||||
|
api.base: ['is_service_enabled']})
|
||||||
|
def test_create_simple_cluster_neutron(self):
|
||||||
|
self.mock_is_service_enabled.return_value = True
|
||||||
|
self.mock_network_list_for_tenant.return_value = self.networks.list()
|
||||||
|
self.mock_datastore_flavors.return_value = self.flavors.list()
|
||||||
|
|
||||||
|
filtered_datastores = self._get_filtered_datastores('mongodb')
|
||||||
|
self.mock_datastore_list.return_value = filtered_datastores
|
||||||
|
self.mock_datastore_version_list.return_value = (
|
||||||
|
self._get_filtered_datastore_versions(filtered_datastores))
|
||||||
|
|
||||||
|
self.mock_cluster_create.return_value = self.trove_clusters.first()
|
||||||
|
|
||||||
|
cluster_name = u'MyCluster'
|
||||||
|
cluster_volume = 1
|
||||||
|
cluster_flavor = u'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa'
|
||||||
|
cluster_instances = 3
|
||||||
|
cluster_datastore = u'mongodb'
|
||||||
|
cluster_datastore_version = u'2.6'
|
||||||
|
cluster_network = u'82288d84-e0a5-42ac-95be-e6af08727e42'
|
||||||
|
|
||||||
field_name = self._build_flavor_widget_name(cluster_datastore,
|
field_name = self._build_flavor_widget_name(cluster_datastore,
|
||||||
cluster_datastore_version)
|
cluster_datastore_version)
|
||||||
self.mox.ReplayAll()
|
|
||||||
post = {
|
post = {
|
||||||
'name': cluster_name,
|
'name': cluster_name,
|
||||||
'volume': cluster_volume,
|
'volume': cluster_volume,
|
||||||
@ -316,37 +290,17 @@ class ClustersTests(test.TestCase):
|
|||||||
}
|
}
|
||||||
|
|
||||||
res = self.client.post(LAUNCH_URL, post)
|
res = self.client.post(LAUNCH_URL, post)
|
||||||
self.assertNoFormErrors(res)
|
self.mock_is_service_enabled.assert_called_once_with(
|
||||||
self.assertMessageCount(success=1)
|
test.IsHttpRequest(), 'network')
|
||||||
|
self.mock_network_list_for_tenant.assert_called_once_with(
|
||||||
@test.create_stubs({trove_api.trove: ['datastore_flavors',
|
test.IsHttpRequest(), '1')
|
||||||
'cluster_create',
|
self.mock_datastore_flavors.assert_called_once_with(
|
||||||
'datastore_list',
|
test.IsHttpRequest(), 'mongodb', '2.6')
|
||||||
'datastore_version_list'],
|
self.mock_datastore_list.assert_called_once_with(test.IsHttpRequest())
|
||||||
api.neutron: ['network_list_for_tenant']})
|
self.mock_datastore_version_list.assert_called_once_with(
|
||||||
def test_create_simple_cluster_exception(self):
|
test.IsHttpRequest(), test.IsA(str))
|
||||||
api.neutron.network_list_for_tenant(IsA(http.HttpRequest), '1')\
|
self.mock_cluster_create.assert_called_once_with(
|
||||||
.AndReturn(self.networks.list())
|
test.IsHttpRequest(),
|
||||||
filtered_datastores = self._get_filtered_datastores('mongodb')
|
|
||||||
trove_api.trove.datastore_flavors(IsA(http.HttpRequest),
|
|
||||||
'mongodb', '2.6')\
|
|
||||||
.AndReturn(self.flavors.list())
|
|
||||||
trove_api.trove.datastore_list(IsA(http.HttpRequest))\
|
|
||||||
.AndReturn(filtered_datastores)
|
|
||||||
trove_api.trove.datastore_version_list(IsA(http.HttpRequest),
|
|
||||||
IsA(str))\
|
|
||||||
.AndReturn(
|
|
||||||
self._get_filtered_datastore_versions(filtered_datastores))
|
|
||||||
|
|
||||||
cluster_name = u'MyCluster'
|
|
||||||
cluster_volume = 1
|
|
||||||
cluster_flavor = u'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa'
|
|
||||||
cluster_instances = 3
|
|
||||||
cluster_datastore = u'mongodb'
|
|
||||||
cluster_datastore_version = u'2.6'
|
|
||||||
cluster_network = u'82288d84-e0a5-42ac-95be-e6af08727e42'
|
|
||||||
trove_api.trove.cluster_create(
|
|
||||||
IsA(http.HttpRequest),
|
|
||||||
cluster_name,
|
cluster_name,
|
||||||
cluster_volume,
|
cluster_volume,
|
||||||
cluster_flavor,
|
cluster_flavor,
|
||||||
@ -355,11 +309,36 @@ class ClustersTests(test.TestCase):
|
|||||||
datastore_version=cluster_datastore_version,
|
datastore_version=cluster_datastore_version,
|
||||||
nics=cluster_network,
|
nics=cluster_network,
|
||||||
root_password=None,
|
root_password=None,
|
||||||
locality=None).AndReturn(self.trove_clusters.first())
|
locality=None)
|
||||||
|
self.assertNoFormErrors(res)
|
||||||
|
self.assertMessageCount(success=1)
|
||||||
|
|
||||||
|
@test.create_mocks({trove_api.trove: ['datastore_flavors',
|
||||||
|
'cluster_create',
|
||||||
|
'datastore_list',
|
||||||
|
'datastore_version_list'],
|
||||||
|
api.neutron: ['network_list_for_tenant']})
|
||||||
|
def test_create_simple_cluster_exception(self):
|
||||||
|
self.mock_network_list_for_tenant.return_value = self.networks.list()
|
||||||
|
self.mock_datastore_flavors.return_value = self.flavors.list()
|
||||||
|
|
||||||
|
filtered_datastores = self._get_filtered_datastores('mongodb')
|
||||||
|
self.mock_datastore_list.return_value = filtered_datastores
|
||||||
|
self.mock_datastore_version_list.return_value = (
|
||||||
|
self._get_filtered_datastore_versions(filtered_datastores))
|
||||||
|
|
||||||
|
self.mock_cluster_create.side_effect = self.exceptions.trove
|
||||||
|
|
||||||
|
cluster_name = u'MyCluster'
|
||||||
|
cluster_volume = 1
|
||||||
|
cluster_flavor = u'aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa'
|
||||||
|
cluster_instances = 3
|
||||||
|
cluster_datastore = u'mongodb'
|
||||||
|
cluster_datastore_version = u'2.6'
|
||||||
|
cluster_network = u''
|
||||||
|
|
||||||
field_name = self._build_flavor_widget_name(cluster_datastore,
|
field_name = self._build_flavor_widget_name(cluster_datastore,
|
||||||
cluster_datastore_version)
|
cluster_datastore_version)
|
||||||
self.mox.ReplayAll()
|
|
||||||
post = {
|
post = {
|
||||||
'name': cluster_name,
|
'name': cluster_name,
|
||||||
'volume': cluster_volume,
|
'volume': cluster_volume,
|
||||||
@ -370,74 +349,107 @@ class ClustersTests(test.TestCase):
|
|||||||
}
|
}
|
||||||
|
|
||||||
res = self.client.post(LAUNCH_URL, post)
|
res = self.client.post(LAUNCH_URL, post)
|
||||||
|
self.mock_network_list_for_tenant.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), '1')
|
||||||
|
self.mock_datastore_flavors.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), 'mongodb', '2.6')
|
||||||
|
self.mock_datastore_list.assert_called_once_with(test.IsHttpRequest())
|
||||||
|
self.mock_datastore_version_list.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), test.IsA(str))
|
||||||
|
self.mock_cluster_create.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(),
|
||||||
|
cluster_name,
|
||||||
|
cluster_volume,
|
||||||
|
cluster_flavor,
|
||||||
|
cluster_instances,
|
||||||
|
datastore=cluster_datastore,
|
||||||
|
datastore_version=cluster_datastore_version,
|
||||||
|
nics=cluster_network,
|
||||||
|
root_password=None,
|
||||||
|
locality=None)
|
||||||
self.assertRedirectsNoFollow(res, INDEX_URL)
|
self.assertRedirectsNoFollow(res, INDEX_URL)
|
||||||
|
self.assertMessageCount(error=1)
|
||||||
|
|
||||||
@test.create_stubs({trove_api.trove: ('cluster_get',
|
@test.create_mocks({trove_api.trove: ('cluster_get',
|
||||||
'instance_get',
|
'instance_get',
|
||||||
'flavor_get',)})
|
'flavor_get',)})
|
||||||
def test_details(self):
|
def test_details(self):
|
||||||
cluster = self.trove_clusters.first()
|
cluster = self.trove_clusters.first()
|
||||||
trove_api.trove.cluster_get(IsA(http.HttpRequest), cluster.id)\
|
self.mock_cluster_get.return_value = cluster
|
||||||
.MultipleTimes().AndReturn(cluster)
|
self.mock_instance_get.return_value = self.databases.first()
|
||||||
trove_api.trove.instance_get(IsA(http.HttpRequest), IsA(str))\
|
self.mock_flavor_get.return_value = self.flavors.first()
|
||||||
.MultipleTimes().AndReturn(self.databases.first())
|
|
||||||
trove_api.trove.flavor_get(IsA(http.HttpRequest), IsA(str))\
|
|
||||||
.MultipleTimes().AndReturn(self.flavors.first())
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
details_url = reverse('horizon:project:database_clusters:detail',
|
details_url = reverse('horizon:project:database_clusters:detail',
|
||||||
args=[cluster.id])
|
args=[cluster.id])
|
||||||
res = self.client.get(details_url)
|
res = self.client.get(details_url)
|
||||||
|
self.assert_mock_multiple_calls_with_same_arguments(
|
||||||
|
self.mock_cluster_get, 2,
|
||||||
|
mock.call(test.IsHttpRequest(), cluster.id))
|
||||||
|
self.assert_mock_multiple_calls_with_same_arguments(
|
||||||
|
self.mock_instance_get, 3,
|
||||||
|
mock.call(test.IsHttpRequest(), test.IsA(str)))
|
||||||
|
self.assert_mock_multiple_calls_with_same_arguments(
|
||||||
|
self.mock_flavor_get, 4,
|
||||||
|
mock.call(test.IsHttpRequest(), test.IsA(str)))
|
||||||
self.assertTemplateUsed(res, 'horizon/common/_detail.html')
|
self.assertTemplateUsed(res, 'horizon/common/_detail.html')
|
||||||
self.assertContains(res, cluster.ip[0])
|
self.assertContains(res, cluster.ip[0])
|
||||||
|
|
||||||
@test.create_stubs({trove_api.trove: ('cluster_get',
|
@test.create_mocks({trove_api.trove: ('cluster_get',
|
||||||
'instance_get',
|
'instance_get',
|
||||||
'flavor_get',)})
|
'flavor_get',)})
|
||||||
def test_details_without_locality(self):
|
def test_details_without_locality(self):
|
||||||
cluster = self.trove_clusters.list()[1]
|
cluster = self.trove_clusters.list()[1]
|
||||||
trove_api.trove.cluster_get(IsA(http.HttpRequest), cluster.id) \
|
self.mock_cluster_get.return_value = cluster
|
||||||
.MultipleTimes().AndReturn(cluster)
|
self.mock_instance_get.return_value = self.databases.first()
|
||||||
trove_api.trove.instance_get(IsA(http.HttpRequest), IsA(str)) \
|
self.mock_flavor_get.return_value = self.flavors.first()
|
||||||
.MultipleTimes().AndReturn(self.databases.first())
|
|
||||||
trove_api.trove.flavor_get(IsA(http.HttpRequest), IsA(str)) \
|
|
||||||
.MultipleTimes().AndReturn(self.flavors.first())
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
details_url = reverse('horizon:project:database_clusters:detail',
|
details_url = reverse('horizon:project:database_clusters:detail',
|
||||||
args=[cluster.id])
|
args=[cluster.id])
|
||||||
res = self.client.get(details_url)
|
res = self.client.get(details_url)
|
||||||
|
self.assert_mock_multiple_calls_with_same_arguments(
|
||||||
|
self.mock_cluster_get, 2,
|
||||||
|
mock.call(test.IsHttpRequest(), cluster.id))
|
||||||
|
self.assert_mock_multiple_calls_with_same_arguments(
|
||||||
|
self.mock_instance_get, 3,
|
||||||
|
mock.call(test.IsHttpRequest(), test.IsA(str)))
|
||||||
|
self.assert_mock_multiple_calls_with_same_arguments(
|
||||||
|
self.mock_flavor_get, 4,
|
||||||
|
mock.call(test.IsHttpRequest(), test.IsA(str)))
|
||||||
self.assertTemplateUsed(res, 'horizon/common/_detail.html')
|
self.assertTemplateUsed(res, 'horizon/common/_detail.html')
|
||||||
self.assertNotContains(res, "Locality")
|
self.assertNotContains(res, "Locality")
|
||||||
|
|
||||||
@test.create_stubs({trove_api.trove: ('cluster_get',
|
@test.create_mocks({trove_api.trove: ('cluster_get',
|
||||||
'instance_get',
|
'instance_get',
|
||||||
'flavor_get',)})
|
'flavor_get',)})
|
||||||
def test_details_with_locality(self):
|
def test_details_with_locality(self):
|
||||||
cluster = self.trove_clusters.first()
|
cluster = self.trove_clusters.first()
|
||||||
trove_api.trove.cluster_get(IsA(http.HttpRequest), cluster.id) \
|
self.mock_cluster_get.return_value = cluster
|
||||||
.MultipleTimes().AndReturn(cluster)
|
self.mock_instance_get.return_value = self.databases.first()
|
||||||
trove_api.trove.instance_get(IsA(http.HttpRequest), IsA(str)) \
|
self.mock_flavor_get.return_value = self.flavors.first()
|
||||||
.MultipleTimes().AndReturn(self.databases.first())
|
|
||||||
trove_api.trove.flavor_get(IsA(http.HttpRequest), IsA(str)) \
|
|
||||||
.MultipleTimes().AndReturn(self.flavors.first())
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
details_url = reverse('horizon:project:database_clusters:detail',
|
details_url = reverse('horizon:project:database_clusters:detail',
|
||||||
args=[cluster.id])
|
args=[cluster.id])
|
||||||
res = self.client.get(details_url)
|
res = self.client.get(details_url)
|
||||||
|
self.assert_mock_multiple_calls_with_same_arguments(
|
||||||
|
self.mock_cluster_get, 2,
|
||||||
|
mock.call(test.IsHttpRequest(), cluster.id))
|
||||||
|
self.assert_mock_multiple_calls_with_same_arguments(
|
||||||
|
self.mock_instance_get, 3,
|
||||||
|
mock.call(test.IsHttpRequest(), test.IsA(str)))
|
||||||
|
self.assert_mock_multiple_calls_with_same_arguments(
|
||||||
|
self.mock_flavor_get, 4,
|
||||||
|
mock.call(test.IsHttpRequest(), test.IsA(str)))
|
||||||
self.assertTemplateUsed(res, 'project/database_clusters/'
|
self.assertTemplateUsed(res, 'project/database_clusters/'
|
||||||
'_detail_overview.html')
|
'_detail_overview.html')
|
||||||
self.assertContains(res, "Locality")
|
self.assertContains(res, "Locality")
|
||||||
|
|
||||||
@test.create_stubs(
|
@test.create_mocks(
|
||||||
{trove_api.trove: ('cluster_get',
|
{trove_api.trove: ('cluster_get',
|
||||||
'cluster_grow'),
|
'cluster_grow'),
|
||||||
cluster_manager: ('get',)})
|
cluster_manager: ('get',)})
|
||||||
def test_grow_cluster(self):
|
def test_grow_cluster(self):
|
||||||
cluster = self.trove_clusters.first()
|
cluster = self.trove_clusters.first()
|
||||||
trove_api.trove.cluster_get(IsA(http.HttpRequest), cluster.id)\
|
self.mock_cluster_get.return_value = cluster
|
||||||
.AndReturn(cluster)
|
|
||||||
cluster_volume = 1
|
cluster_volume = 1
|
||||||
flavor = self.flavors.first()
|
flavor = self.flavors.first()
|
||||||
cluster_flavor = flavor.id
|
cluster_flavor = flavor.id
|
||||||
@ -458,11 +470,7 @@ class ClustersTests(test.TestCase):
|
|||||||
|
|
||||||
manager = cluster_manager.ClusterInstanceManager(cluster.id)
|
manager = cluster_manager.ClusterInstanceManager(cluster.id)
|
||||||
manager.instances = instances
|
manager.instances = instances
|
||||||
cluster_manager.get(cluster.id).MultipleTimes().AndReturn(manager)
|
self.mock_get.return_value = manager
|
||||||
trove_api.trove.cluster_grow(IsA(http.HttpRequest),
|
|
||||||
cluster.id,
|
|
||||||
instances)
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
url = reverse('horizon:project:database_clusters:cluster_grow_details',
|
url = reverse('horizon:project:database_clusters:cluster_grow_details',
|
||||||
args=[cluster.id])
|
args=[cluster.id])
|
||||||
@ -483,15 +491,19 @@ class ClustersTests(test.TestCase):
|
|||||||
tables.ClusterGrowAction.name, '__',
|
tables.ClusterGrowAction.name, '__',
|
||||||
cluster.id])
|
cluster.id])
|
||||||
res = self.client.post(url, {'action': action})
|
res = self.client.post(url, {'action': action})
|
||||||
|
self.mock_cluster_get.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), cluster.id)
|
||||||
|
self.assert_mock_multiple_calls_with_same_arguments(
|
||||||
|
self.mock_get, 5, mock.call(cluster.id))
|
||||||
|
self.mock_cluster_grow.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), cluster.id, instances)
|
||||||
self.assertMessageCount(success=1)
|
self.assertMessageCount(success=1)
|
||||||
self.assertRedirectsNoFollow(res, INDEX_URL)
|
self.assertRedirectsNoFollow(res, INDEX_URL)
|
||||||
|
|
||||||
@test.create_stubs({trove_api.trove: ('cluster_get',)})
|
@test.create_mocks({trove_api.trove: ('cluster_get',)})
|
||||||
def test_grow_cluster_no_instances(self):
|
def test_grow_cluster_no_instances(self):
|
||||||
cluster = self.trove_clusters.first()
|
cluster = self.trove_clusters.first()
|
||||||
trove_api.trove.cluster_get(IsA(http.HttpRequest), cluster.id)\
|
self.mock_cluster_get.return_value = cluster
|
||||||
.AndReturn(cluster)
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
url = reverse('horizon:project:database_clusters:cluster_grow_details',
|
url = reverse('horizon:project:database_clusters:cluster_grow_details',
|
||||||
args=[cluster.id])
|
args=[cluster.id])
|
||||||
@ -503,16 +515,17 @@ class ClustersTests(test.TestCase):
|
|||||||
tables.ClusterGrowAction.name, '__',
|
tables.ClusterGrowAction.name, '__',
|
||||||
cluster.id])
|
cluster.id])
|
||||||
self.client.post(url, {'action': action})
|
self.client.post(url, {'action': action})
|
||||||
|
self.mock_cluster_get.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), cluster.id)
|
||||||
self.assertMessageCount(info=1)
|
self.assertMessageCount(info=1)
|
||||||
|
|
||||||
@test.create_stubs(
|
@test.create_mocks(
|
||||||
{trove_api.trove: ('cluster_get',
|
{trove_api.trove: ('cluster_get',
|
||||||
'cluster_grow',),
|
'cluster_grow',),
|
||||||
cluster_manager: ('get',)})
|
cluster_manager: ('get',)})
|
||||||
def test_grow_cluster_exception(self):
|
def test_grow_cluster_exception(self):
|
||||||
cluster = self.trove_clusters.first()
|
cluster = self.trove_clusters.first()
|
||||||
trove_api.trove.cluster_get(IsA(http.HttpRequest), cluster.id)\
|
self.mock_cluster_get.return_value = cluster
|
||||||
.AndReturn(cluster)
|
|
||||||
cluster_volume = 1
|
cluster_volume = 1
|
||||||
flavor = self.flavors.first()
|
flavor = self.flavors.first()
|
||||||
cluster_flavor = flavor.id
|
cluster_flavor = flavor.id
|
||||||
@ -533,11 +546,8 @@ class ClustersTests(test.TestCase):
|
|||||||
|
|
||||||
manager = cluster_manager.ClusterInstanceManager(cluster.id)
|
manager = cluster_manager.ClusterInstanceManager(cluster.id)
|
||||||
manager.instances = instances
|
manager.instances = instances
|
||||||
cluster_manager.get(cluster.id).MultipleTimes().AndReturn(manager)
|
self.mock_get.return_value = manager
|
||||||
trove_api.trove.cluster_grow(IsA(http.HttpRequest),
|
self.mock_cluster_grow.side_effect = self.exceptions.trove
|
||||||
cluster.id,
|
|
||||||
instances).AndRaise(self.exceptions.trove)
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
url = reverse('horizon:project:database_clusters:cluster_grow_details',
|
url = reverse('horizon:project:database_clusters:cluster_grow_details',
|
||||||
args=[cluster.id])
|
args=[cluster.id])
|
||||||
@ -560,6 +570,12 @@ class ClustersTests(test.TestCase):
|
|||||||
cluster.id])
|
cluster.id])
|
||||||
res = self.client.post(url, {'action': action})
|
res = self.client.post(url, {'action': action})
|
||||||
|
|
||||||
|
self.mock_cluster_get.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), cluster.id)
|
||||||
|
self.assert_mock_multiple_calls_with_same_arguments(
|
||||||
|
self.mock_get, 3, mock.call(cluster.id))
|
||||||
|
self.mock_cluster_grow.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), cluster.id, instances)
|
||||||
self.assertMessageCount(error=1)
|
self.assertMessageCount(error=1)
|
||||||
self.assertRedirectsNoFollow(res, INDEX_URL)
|
self.assertRedirectsNoFollow(res, INDEX_URL)
|
||||||
finally:
|
finally:
|
||||||
@ -567,18 +583,13 @@ class ClustersTests(test.TestCase):
|
|||||||
for (log, level) in loggers:
|
for (log, level) in loggers:
|
||||||
log.setLevel(level)
|
log.setLevel(level)
|
||||||
|
|
||||||
@test.create_stubs({trove_api.trove: ('cluster_get',
|
@test.create_mocks({trove_api.trove: ('cluster_get',
|
||||||
'cluster_shrink')})
|
'cluster_shrink')})
|
||||||
def test_shrink_cluster(self):
|
def test_shrink_cluster(self):
|
||||||
cluster = self.trove_clusters.first()
|
cluster = self.trove_clusters.first()
|
||||||
trove_api.trove.cluster_get(IsA(http.HttpRequest), cluster.id)\
|
self.mock_cluster_get.return_value = cluster
|
||||||
.MultipleTimes().AndReturn(cluster)
|
|
||||||
instance_id = cluster.instances[0]['id']
|
instance_id = cluster.instances[0]['id']
|
||||||
cluster_instances = [{'id': instance_id}]
|
cluster_instances = [{'id': instance_id}]
|
||||||
trove_api.trove.cluster_shrink(IsA(http.HttpRequest),
|
|
||||||
cluster.id,
|
|
||||||
cluster_instances)
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
url = reverse(
|
url = reverse(
|
||||||
'horizon:project:database_clusters:cluster_shrink_details',
|
'horizon:project:database_clusters:cluster_shrink_details',
|
||||||
@ -594,30 +605,30 @@ class ClustersTests(test.TestCase):
|
|||||||
tables.ClusterShrinkAction.name, '__',
|
tables.ClusterShrinkAction.name, '__',
|
||||||
instance_id])
|
instance_id])
|
||||||
res = self.client.post(url, {'action': action})
|
res = self.client.post(url, {'action': action})
|
||||||
|
self.assert_mock_multiple_calls_with_same_arguments(
|
||||||
|
self.mock_cluster_get, 2,
|
||||||
|
mock.call(test.IsHttpRequest(), cluster.id))
|
||||||
|
self.mock_cluster_shrink.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), cluster.id, cluster_instances)
|
||||||
self.assertNoFormErrors(res)
|
self.assertNoFormErrors(res)
|
||||||
self.assertMessageCount(info=1)
|
self.assertMessageCount(info=1)
|
||||||
self.assertRedirectsNoFollow(res, INDEX_URL)
|
self.assertRedirectsNoFollow(res, INDEX_URL)
|
||||||
|
|
||||||
@test.create_stubs({trove_api.trove: ('cluster_get',
|
@test.create_mocks({trove_api.trove: ('cluster_get',
|
||||||
'cluster_shrink')})
|
'cluster_shrink')})
|
||||||
def test_shrink_cluster_exception(self):
|
def test_shrink_cluster_exception(self):
|
||||||
cluster = self.trove_clusters.first()
|
cluster = self.trove_clusters.first()
|
||||||
trove_api.trove.cluster_get(IsA(http.HttpRequest), cluster.id)\
|
self.mock_cluster_get.return_value = cluster
|
||||||
.MultipleTimes().AndReturn(cluster)
|
instance_id = cluster.instances[0]['id']
|
||||||
cluster_id = cluster.instances[0]['id']
|
cluster_instances = [{'id': instance_id}]
|
||||||
cluster_instances = [cluster_id]
|
self.mock_cluster_shrink.side_effect = self.exceptions.trove
|
||||||
trove_api.trove.cluster_shrink(IsA(http.HttpRequest),
|
|
||||||
cluster.id,
|
|
||||||
cluster_instances)\
|
|
||||||
.AndRaise(self.exceptions.trove)
|
|
||||||
self.mox.ReplayAll()
|
|
||||||
|
|
||||||
url = reverse(
|
url = reverse(
|
||||||
'horizon:project:database_clusters:cluster_shrink_details',
|
'horizon:project:database_clusters:cluster_shrink_details',
|
||||||
args=[cluster.id])
|
args=[cluster.id])
|
||||||
action = "".join([tables.ClusterShrinkInstancesTable.Meta.name, '__',
|
action = "".join([tables.ClusterShrinkInstancesTable.Meta.name, '__',
|
||||||
tables.ClusterShrinkAction.name, '__',
|
tables.ClusterShrinkAction.name, '__',
|
||||||
cluster_id])
|
instance_id])
|
||||||
|
|
||||||
toSuppress = ["trove_dashboard.content.database_clusters.tables"]
|
toSuppress = ["trove_dashboard.content.database_clusters.tables"]
|
||||||
|
|
||||||
@ -630,6 +641,10 @@ class ClustersTests(test.TestCase):
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
res = self.client.post(url, {'action': action})
|
res = self.client.post(url, {'action': action})
|
||||||
|
self.mock_cluster_get.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), cluster.id)
|
||||||
|
self.mock_cluster_shrink.assert_called_once_with(
|
||||||
|
test.IsHttpRequest(), cluster.id, cluster_instances)
|
||||||
self.assertMessageCount(error=1)
|
self.assertMessageCount(error=1)
|
||||||
self.assertRedirectsNoFollow(res, INDEX_URL)
|
self.assertRedirectsNoFollow(res, INDEX_URL)
|
||||||
finally:
|
finally:
|
||||||
|
Loading…
Reference in New Issue
Block a user