calling nova extensions api to enable certain nova features
Fixes: bug #1202310 Change-Id: I47365b0a89ab572f25cb71bfe17cae547261df9d
This commit is contained in:
parent
9bb75cf631
commit
db9c08e172
@ -28,6 +28,7 @@ from django.conf import settings
|
|||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
|
|
||||||
from novaclient.v1_1 import client as nova_client
|
from novaclient.v1_1 import client as nova_client
|
||||||
|
from novaclient.v1_1.contrib.list_extensions import ListExtManager
|
||||||
from novaclient.v1_1 import security_group_rules as nova_rules
|
from novaclient.v1_1 import security_group_rules as nova_rules
|
||||||
from novaclient.v1_1.security_groups import SecurityGroup as NovaSecurityGroup
|
from novaclient.v1_1.security_groups import SecurityGroup as NovaSecurityGroup
|
||||||
from novaclient.v1_1.servers import REBOOT_HARD
|
from novaclient.v1_1.servers import REBOOT_HARD
|
||||||
@ -628,3 +629,22 @@ def aggregate_list(request):
|
|||||||
result.append(novaclient(request).aggregates.get(aggregate.id))
|
result.append(novaclient(request).aggregates.get(aggregate.id))
|
||||||
|
|
||||||
return result
|
return result
|
||||||
|
|
||||||
|
|
||||||
|
@memoized
|
||||||
|
def list_extensions(request):
|
||||||
|
return ListExtManager(novaclient(request)).show_all()
|
||||||
|
|
||||||
|
|
||||||
|
@memoized
|
||||||
|
def extension_supported(extension_name, request):
|
||||||
|
"""
|
||||||
|
this method will determine if nova supports a given extension name.
|
||||||
|
example values for the extension_name include AdminActions, ConsoleOutput,
|
||||||
|
etc.
|
||||||
|
"""
|
||||||
|
extensions = list_extensions(request)
|
||||||
|
for extension in extensions:
|
||||||
|
if extension.name == extension_name:
|
||||||
|
return True
|
||||||
|
return False
|
||||||
|
@ -27,12 +27,15 @@ from openstack_dashboard.test import helpers as test
|
|||||||
|
|
||||||
|
|
||||||
class InstanceViewTest(test.BaseAdminViewTests):
|
class InstanceViewTest(test.BaseAdminViewTests):
|
||||||
@test.create_stubs({api.nova: ('flavor_list', 'server_list',),
|
@test.create_stubs({api.nova: ('flavor_list', 'server_list',
|
||||||
|
'extension_supported',),
|
||||||
api.keystone: ('tenant_list',)})
|
api.keystone: ('tenant_list',)})
|
||||||
def test_index(self):
|
def test_index(self):
|
||||||
servers = self.servers.list()
|
servers = self.servers.list()
|
||||||
flavors = self.flavors.list()
|
flavors = self.flavors.list()
|
||||||
tenants = self.tenants.list()
|
tenants = self.tenants.list()
|
||||||
|
api.nova.extension_supported('AdminActions', IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.keystone.tenant_list(IsA(http.HttpRequest)).\
|
api.keystone.tenant_list(IsA(http.HttpRequest)).\
|
||||||
AndReturn([tenants, False])
|
AndReturn([tenants, False])
|
||||||
search_opts = {'marker': None, 'paginate': True}
|
search_opts = {'marker': None, 'paginate': True}
|
||||||
@ -48,7 +51,7 @@ class InstanceViewTest(test.BaseAdminViewTests):
|
|||||||
self.assertItemsEqual(instances, servers)
|
self.assertItemsEqual(instances, servers)
|
||||||
|
|
||||||
@test.create_stubs({api.nova: ('flavor_list', 'flavor_get',
|
@test.create_stubs({api.nova: ('flavor_list', 'flavor_get',
|
||||||
'server_list',),
|
'server_list', 'extension_supported',),
|
||||||
api.keystone: ('tenant_list',)})
|
api.keystone: ('tenant_list',)})
|
||||||
def test_index_flavor_list_exception(self):
|
def test_index_flavor_list_exception(self):
|
||||||
servers = self.servers.list()
|
servers = self.servers.list()
|
||||||
@ -60,6 +63,8 @@ class InstanceViewTest(test.BaseAdminViewTests):
|
|||||||
api.nova.server_list(IsA(http.HttpRequest),
|
api.nova.server_list(IsA(http.HttpRequest),
|
||||||
all_tenants=True, search_opts=search_opts) \
|
all_tenants=True, search_opts=search_opts) \
|
||||||
.AndReturn([servers, False])
|
.AndReturn([servers, False])
|
||||||
|
api.nova.extension_supported('AdminActions', IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.nova.flavor_list(IsA(http.HttpRequest)). \
|
api.nova.flavor_list(IsA(http.HttpRequest)). \
|
||||||
AndRaise(self.exceptions.nova)
|
AndRaise(self.exceptions.nova)
|
||||||
api.keystone.tenant_list(IsA(http.HttpRequest)).\
|
api.keystone.tenant_list(IsA(http.HttpRequest)).\
|
||||||
@ -76,7 +81,7 @@ class InstanceViewTest(test.BaseAdminViewTests):
|
|||||||
self.assertItemsEqual(instances, servers)
|
self.assertItemsEqual(instances, servers)
|
||||||
|
|
||||||
@test.create_stubs({api.nova: ('flavor_list', 'flavor_get',
|
@test.create_stubs({api.nova: ('flavor_list', 'flavor_get',
|
||||||
'server_list',),
|
'server_list', 'extension_supported', ),
|
||||||
api.keystone: ('tenant_list',)})
|
api.keystone: ('tenant_list',)})
|
||||||
def test_index_flavor_get_exception(self):
|
def test_index_flavor_get_exception(self):
|
||||||
servers = self.servers.list()
|
servers = self.servers.list()
|
||||||
@ -91,6 +96,8 @@ class InstanceViewTest(test.BaseAdminViewTests):
|
|||||||
api.nova.server_list(IsA(http.HttpRequest),
|
api.nova.server_list(IsA(http.HttpRequest),
|
||||||
all_tenants=True, search_opts=search_opts) \
|
all_tenants=True, search_opts=search_opts) \
|
||||||
.AndReturn([servers, False])
|
.AndReturn([servers, False])
|
||||||
|
api.nova.extension_supported('AdminActions', IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.nova.flavor_list(IsA(http.HttpRequest)). \
|
api.nova.flavor_list(IsA(http.HttpRequest)). \
|
||||||
AndReturn(flavors)
|
AndReturn(flavors)
|
||||||
api.keystone.tenant_list(IsA(http.HttpRequest)).\
|
api.keystone.tenant_list(IsA(http.HttpRequest)).\
|
||||||
@ -119,7 +126,8 @@ class InstanceViewTest(test.BaseAdminViewTests):
|
|||||||
self.assertTemplateUsed(res, 'admin/instances/index.html')
|
self.assertTemplateUsed(res, 'admin/instances/index.html')
|
||||||
self.assertEqual(len(res.context['instances_table'].data), 0)
|
self.assertEqual(len(res.context['instances_table'].data), 0)
|
||||||
|
|
||||||
@test.create_stubs({api.nova: ('server_get', 'flavor_get',),
|
@test.create_stubs({api.nova: ('server_get', 'flavor_get',
|
||||||
|
'extension_supported', ),
|
||||||
api.keystone: ('tenant_get',)})
|
api.keystone: ('tenant_get',)})
|
||||||
def test_ajax_loading_instances(self):
|
def test_ajax_loading_instances(self):
|
||||||
server = self.servers.first()
|
server = self.servers.first()
|
||||||
@ -127,6 +135,8 @@ class InstanceViewTest(test.BaseAdminViewTests):
|
|||||||
tenant = self.tenants.list()[0]
|
tenant = self.tenants.list()[0]
|
||||||
|
|
||||||
api.nova.server_get(IsA(http.HttpRequest), server.id).AndReturn(server)
|
api.nova.server_get(IsA(http.HttpRequest), server.id).AndReturn(server)
|
||||||
|
api.nova.extension_supported('AdminActions', IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.nova.flavor_get(IsA(http.HttpRequest),
|
api.nova.flavor_get(IsA(http.HttpRequest),
|
||||||
server.flavor['id']).AndReturn(flavor)
|
server.flavor['id']).AndReturn(flavor)
|
||||||
api.keystone.tenant_get(IsA(http.HttpRequest),
|
api.keystone.tenant_get(IsA(http.HttpRequest),
|
||||||
@ -150,7 +160,8 @@ class InstanceViewTest(test.BaseAdminViewTests):
|
|||||||
self.assertContains(res, "Active", 1, 200)
|
self.assertContains(res, "Active", 1, 200)
|
||||||
self.assertContains(res, "Running", 1, 200)
|
self.assertContains(res, "Running", 1, 200)
|
||||||
|
|
||||||
@test.create_stubs({api.nova: ('flavor_list', 'server_list',),
|
@test.create_stubs({api.nova: ('flavor_list', 'server_list',
|
||||||
|
'extension_supported', ),
|
||||||
api.keystone: ('tenant_list',)})
|
api.keystone: ('tenant_list',)})
|
||||||
def test_index_options_before_migrate(self):
|
def test_index_options_before_migrate(self):
|
||||||
api.keystone.tenant_list(IsA(http.HttpRequest)).\
|
api.keystone.tenant_list(IsA(http.HttpRequest)).\
|
||||||
@ -159,6 +170,8 @@ class InstanceViewTest(test.BaseAdminViewTests):
|
|||||||
api.nova.server_list(IsA(http.HttpRequest),
|
api.nova.server_list(IsA(http.HttpRequest),
|
||||||
all_tenants=True, search_opts=search_opts) \
|
all_tenants=True, search_opts=search_opts) \
|
||||||
.AndReturn([self.servers.list(), False])
|
.AndReturn([self.servers.list(), False])
|
||||||
|
api.nova.extension_supported('AdminActions', IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.nova.flavor_list(IsA(http.HttpRequest)).\
|
api.nova.flavor_list(IsA(http.HttpRequest)).\
|
||||||
AndReturn(self.flavors.list())
|
AndReturn(self.flavors.list())
|
||||||
self.mox.ReplayAll()
|
self.mox.ReplayAll()
|
||||||
@ -168,7 +181,8 @@ class InstanceViewTest(test.BaseAdminViewTests):
|
|||||||
self.assertNotContains(res, "instances__confirm")
|
self.assertNotContains(res, "instances__confirm")
|
||||||
self.assertNotContains(res, "instances__revert")
|
self.assertNotContains(res, "instances__revert")
|
||||||
|
|
||||||
@test.create_stubs({api.nova: ('flavor_list', 'server_list',),
|
@test.create_stubs({api.nova: ('flavor_list', 'server_list',
|
||||||
|
'extension_supported', ),
|
||||||
api.keystone: ('tenant_list',)})
|
api.keystone: ('tenant_list',)})
|
||||||
def test_index_options_after_migrate(self):
|
def test_index_options_after_migrate(self):
|
||||||
servers = self.servers.list()
|
servers = self.servers.list()
|
||||||
@ -179,6 +193,8 @@ class InstanceViewTest(test.BaseAdminViewTests):
|
|||||||
api.keystone.tenant_list(IsA(http.HttpRequest)) \
|
api.keystone.tenant_list(IsA(http.HttpRequest)) \
|
||||||
.AndReturn([self.tenants.list(), False])
|
.AndReturn([self.tenants.list(), False])
|
||||||
search_opts = {'marker': None, 'paginate': True}
|
search_opts = {'marker': None, 'paginate': True}
|
||||||
|
api.nova.extension_supported('AdminActions', IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.nova.server_list(IsA(http.HttpRequest),
|
api.nova.server_list(IsA(http.HttpRequest),
|
||||||
all_tenants=True, search_opts=search_opts) \
|
all_tenants=True, search_opts=search_opts) \
|
||||||
.AndReturn([self.servers.list(), False])
|
.AndReturn([self.servers.list(), False])
|
||||||
|
@ -127,6 +127,9 @@ class TogglePause(tables.BatchAction):
|
|||||||
classes = ("btn-pause",)
|
classes = ("btn-pause",)
|
||||||
|
|
||||||
def allowed(self, request, instance=None):
|
def allowed(self, request, instance=None):
|
||||||
|
if not api.nova.extension_supported('AdminActions',
|
||||||
|
request):
|
||||||
|
return False
|
||||||
self.paused = False
|
self.paused = False
|
||||||
if not instance:
|
if not instance:
|
||||||
return self.paused
|
return self.paused
|
||||||
@ -156,6 +159,9 @@ class ToggleSuspend(tables.BatchAction):
|
|||||||
classes = ("btn-suspend",)
|
classes = ("btn-suspend",)
|
||||||
|
|
||||||
def allowed(self, request, instance=None):
|
def allowed(self, request, instance=None):
|
||||||
|
if not api.nova.extension_supported('AdminActions',
|
||||||
|
request):
|
||||||
|
return False
|
||||||
self.suspended = False
|
self.suspended = False
|
||||||
if not instance:
|
if not instance:
|
||||||
self.suspended
|
self.suspended
|
||||||
|
@ -49,8 +49,12 @@ INDEX_URL = reverse('horizon:project:instances:index')
|
|||||||
class InstanceTests(test.TestCase):
|
class InstanceTests(test.TestCase):
|
||||||
@test.create_stubs({api.nova: ('flavor_list',
|
@test.create_stubs({api.nova: ('flavor_list',
|
||||||
'server_list',
|
'server_list',
|
||||||
'tenant_absolute_limits')})
|
'tenant_absolute_limits',
|
||||||
|
'extension_supported',)})
|
||||||
def test_index(self):
|
def test_index(self):
|
||||||
|
api.nova.extension_supported('AdminActions',
|
||||||
|
IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
||||||
.AndReturn(self.flavors.list())
|
.AndReturn(self.flavors.list())
|
||||||
search_opts = {'marker': None, 'paginate': True}
|
search_opts = {'marker': None, 'paginate': True}
|
||||||
@ -61,8 +65,7 @@ class InstanceTests(test.TestCase):
|
|||||||
|
|
||||||
self.mox.ReplayAll()
|
self.mox.ReplayAll()
|
||||||
|
|
||||||
res = self.client.get(
|
res = self.client.get(INDEX_URL)
|
||||||
reverse('horizon:project:instances:index'))
|
|
||||||
|
|
||||||
self.assertTemplateUsed(res,
|
self.assertTemplateUsed(res,
|
||||||
'project/instances/index.html')
|
'project/instances/index.html')
|
||||||
@ -71,7 +74,7 @@ class InstanceTests(test.TestCase):
|
|||||||
self.assertItemsEqual(instances, self.servers.list())
|
self.assertItemsEqual(instances, self.servers.list())
|
||||||
|
|
||||||
@test.create_stubs({api.nova: ('server_list',
|
@test.create_stubs({api.nova: ('server_list',
|
||||||
'tenant_absolute_limits')})
|
'tenant_absolute_limits',)})
|
||||||
def test_index_server_list_exception(self):
|
def test_index_server_list_exception(self):
|
||||||
search_opts = {'marker': None, 'paginate': True}
|
search_opts = {'marker': None, 'paginate': True}
|
||||||
api.nova.server_list(IsA(http.HttpRequest), search_opts=search_opts) \
|
api.nova.server_list(IsA(http.HttpRequest), search_opts=search_opts) \
|
||||||
@ -81,7 +84,7 @@ class InstanceTests(test.TestCase):
|
|||||||
|
|
||||||
self.mox.ReplayAll()
|
self.mox.ReplayAll()
|
||||||
|
|
||||||
res = self.client.get(reverse('horizon:project:instances:index'))
|
res = self.client.get(INDEX_URL)
|
||||||
|
|
||||||
self.assertTemplateUsed(res, 'project/instances/index.html')
|
self.assertTemplateUsed(res, 'project/instances/index.html')
|
||||||
self.assertEqual(len(res.context['instances_table'].data), 0)
|
self.assertEqual(len(res.context['instances_table'].data), 0)
|
||||||
@ -90,12 +93,16 @@ class InstanceTests(test.TestCase):
|
|||||||
@test.create_stubs({api.nova: ('flavor_list',
|
@test.create_stubs({api.nova: ('flavor_list',
|
||||||
'server_list',
|
'server_list',
|
||||||
'flavor_get',
|
'flavor_get',
|
||||||
'tenant_absolute_limits')})
|
'tenant_absolute_limits',
|
||||||
|
'extension_supported',)})
|
||||||
def test_index_flavor_list_exception(self):
|
def test_index_flavor_list_exception(self):
|
||||||
servers = self.servers.list()
|
servers = self.servers.list()
|
||||||
flavors = self.flavors.list()
|
flavors = self.flavors.list()
|
||||||
full_flavors = SortedDict([(f.id, f) for f in flavors])
|
full_flavors = SortedDict([(f.id, f) for f in flavors])
|
||||||
search_opts = {'marker': None, 'paginate': True}
|
search_opts = {'marker': None, 'paginate': True}
|
||||||
|
api.nova.extension_supported('AdminActions',
|
||||||
|
IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.nova.server_list(IsA(http.HttpRequest), search_opts=search_opts) \
|
api.nova.server_list(IsA(http.HttpRequest), search_opts=search_opts) \
|
||||||
.AndReturn([servers, False])
|
.AndReturn([servers, False])
|
||||||
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
||||||
@ -108,7 +115,7 @@ class InstanceTests(test.TestCase):
|
|||||||
|
|
||||||
self.mox.ReplayAll()
|
self.mox.ReplayAll()
|
||||||
|
|
||||||
res = self.client.get(reverse('horizon:project:instances:index'))
|
res = self.client.get(INDEX_URL)
|
||||||
|
|
||||||
self.assertTemplateUsed(res, 'project/instances/index.html')
|
self.assertTemplateUsed(res, 'project/instances/index.html')
|
||||||
instances = res.context['instances_table'].data
|
instances = res.context['instances_table'].data
|
||||||
@ -118,10 +125,14 @@ class InstanceTests(test.TestCase):
|
|||||||
@test.create_stubs({api.nova: ('flavor_list',
|
@test.create_stubs({api.nova: ('flavor_list',
|
||||||
'server_list',
|
'server_list',
|
||||||
'flavor_get',
|
'flavor_get',
|
||||||
'tenant_absolute_limits')})
|
'tenant_absolute_limits',
|
||||||
|
'extension_supported',)})
|
||||||
def test_index_flavor_get_exception(self):
|
def test_index_flavor_get_exception(self):
|
||||||
servers = self.servers.list()
|
servers = self.servers.list()
|
||||||
flavors = self.flavors.list()
|
flavors = self.flavors.list()
|
||||||
|
api.nova.extension_supported('AdminActions',
|
||||||
|
IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
# UUIDs generated using indexes are unlikely to match
|
# UUIDs generated using indexes are unlikely to match
|
||||||
# any of existing flavor ids and are guaranteed to be deterministic.
|
# any of existing flavor ids and are guaranteed to be deterministic.
|
||||||
for i, server in enumerate(servers):
|
for i, server in enumerate(servers):
|
||||||
@ -139,7 +150,7 @@ class InstanceTests(test.TestCase):
|
|||||||
|
|
||||||
self.mox.ReplayAll()
|
self.mox.ReplayAll()
|
||||||
|
|
||||||
res = self.client.get(reverse('horizon:project:instances:index'))
|
res = self.client.get(INDEX_URL)
|
||||||
|
|
||||||
instances = res.context['instances_table'].data
|
instances = res.context['instances_table'].data
|
||||||
|
|
||||||
@ -188,10 +199,14 @@ class InstanceTests(test.TestCase):
|
|||||||
|
|
||||||
@test.create_stubs({api.nova: ('server_pause',
|
@test.create_stubs({api.nova: ('server_pause',
|
||||||
'server_list',
|
'server_list',
|
||||||
'flavor_list',)})
|
'flavor_list',
|
||||||
|
'extension_supported',)})
|
||||||
def test_pause_instance(self):
|
def test_pause_instance(self):
|
||||||
server = self.servers.first()
|
server = self.servers.first()
|
||||||
|
|
||||||
|
api.nova.extension_supported('AdminActions',
|
||||||
|
IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
||||||
.AndReturn(self.flavors.list())
|
.AndReturn(self.flavors.list())
|
||||||
search_opts = {'marker': None, 'paginate': True}
|
search_opts = {'marker': None, 'paginate': True}
|
||||||
@ -208,10 +223,14 @@ class InstanceTests(test.TestCase):
|
|||||||
|
|
||||||
@test.create_stubs({api.nova: ('server_pause',
|
@test.create_stubs({api.nova: ('server_pause',
|
||||||
'server_list',
|
'server_list',
|
||||||
'flavor_list',)})
|
'flavor_list',
|
||||||
|
'extension_supported',)})
|
||||||
def test_pause_instance_exception(self):
|
def test_pause_instance_exception(self):
|
||||||
server = self.servers.first()
|
server = self.servers.first()
|
||||||
|
|
||||||
|
api.nova.extension_supported('AdminActions',
|
||||||
|
IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
||||||
.AndReturn(self.flavors.list())
|
.AndReturn(self.flavors.list())
|
||||||
search_opts = {'marker': None, 'paginate': True}
|
search_opts = {'marker': None, 'paginate': True}
|
||||||
@ -229,11 +248,14 @@ class InstanceTests(test.TestCase):
|
|||||||
|
|
||||||
@test.create_stubs({api.nova: ('server_unpause',
|
@test.create_stubs({api.nova: ('server_unpause',
|
||||||
'server_list',
|
'server_list',
|
||||||
'flavor_list',)})
|
'flavor_list',
|
||||||
|
'extension_supported',)})
|
||||||
def test_unpause_instance(self):
|
def test_unpause_instance(self):
|
||||||
server = self.servers.first()
|
server = self.servers.first()
|
||||||
server.status = "PAUSED"
|
server.status = "PAUSED"
|
||||||
|
api.nova.extension_supported('AdminActions',
|
||||||
|
IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
||||||
.AndReturn(self.flavors.list())
|
.AndReturn(self.flavors.list())
|
||||||
search_opts = {'marker': None, 'paginate': True}
|
search_opts = {'marker': None, 'paginate': True}
|
||||||
@ -250,11 +272,15 @@ class InstanceTests(test.TestCase):
|
|||||||
|
|
||||||
@test.create_stubs({api.nova: ('server_unpause',
|
@test.create_stubs({api.nova: ('server_unpause',
|
||||||
'server_list',
|
'server_list',
|
||||||
'flavor_list',)})
|
'flavor_list',
|
||||||
|
'extension_supported',)})
|
||||||
def test_unpause_instance_exception(self):
|
def test_unpause_instance_exception(self):
|
||||||
server = self.servers.first()
|
server = self.servers.first()
|
||||||
server.status = "PAUSED"
|
server.status = "PAUSED"
|
||||||
|
|
||||||
|
api.nova.extension_supported('AdminActions',
|
||||||
|
IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
||||||
.AndReturn(self.flavors.list())
|
.AndReturn(self.flavors.list())
|
||||||
search_opts = {'marker': None, 'paginate': True}
|
search_opts = {'marker': None, 'paginate': True}
|
||||||
@ -275,7 +301,6 @@ class InstanceTests(test.TestCase):
|
|||||||
'flavor_list',)})
|
'flavor_list',)})
|
||||||
def test_reboot_instance(self):
|
def test_reboot_instance(self):
|
||||||
server = self.servers.first()
|
server = self.servers.first()
|
||||||
|
|
||||||
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
||||||
.AndReturn(self.flavors.list())
|
.AndReturn(self.flavors.list())
|
||||||
search_opts = {'marker': None, 'paginate': True}
|
search_opts = {'marker': None, 'paginate': True}
|
||||||
@ -336,10 +361,14 @@ class InstanceTests(test.TestCase):
|
|||||||
|
|
||||||
@test.create_stubs({api.nova: ('server_suspend',
|
@test.create_stubs({api.nova: ('server_suspend',
|
||||||
'server_list',
|
'server_list',
|
||||||
'flavor_list',)})
|
'flavor_list',
|
||||||
|
'extension_supported',)})
|
||||||
def test_suspend_instance(self):
|
def test_suspend_instance(self):
|
||||||
server = self.servers.first()
|
server = self.servers.first()
|
||||||
|
|
||||||
|
api.nova.extension_supported('AdminActions',
|
||||||
|
IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
||||||
.AndReturn(self.flavors.list())
|
.AndReturn(self.flavors.list())
|
||||||
search_opts = {'marker': None, 'paginate': True}
|
search_opts = {'marker': None, 'paginate': True}
|
||||||
@ -356,10 +385,14 @@ class InstanceTests(test.TestCase):
|
|||||||
|
|
||||||
@test.create_stubs({api.nova: ('server_suspend',
|
@test.create_stubs({api.nova: ('server_suspend',
|
||||||
'server_list',
|
'server_list',
|
||||||
'flavor_list',)})
|
'flavor_list',
|
||||||
|
'extension_supported',)})
|
||||||
def test_suspend_instance_exception(self):
|
def test_suspend_instance_exception(self):
|
||||||
server = self.servers.first()
|
server = self.servers.first()
|
||||||
|
|
||||||
|
api.nova.extension_supported('AdminActions',
|
||||||
|
IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
||||||
.AndReturn(self.flavors.list())
|
.AndReturn(self.flavors.list())
|
||||||
search_opts = {'marker': None, 'paginate': True}
|
search_opts = {'marker': None, 'paginate': True}
|
||||||
@ -377,11 +410,15 @@ class InstanceTests(test.TestCase):
|
|||||||
|
|
||||||
@test.create_stubs({api.nova: ('server_resume',
|
@test.create_stubs({api.nova: ('server_resume',
|
||||||
'server_list',
|
'server_list',
|
||||||
'flavor_list',)})
|
'flavor_list',
|
||||||
|
'extension_supported',)})
|
||||||
def test_resume_instance(self):
|
def test_resume_instance(self):
|
||||||
server = self.servers.first()
|
server = self.servers.first()
|
||||||
server.status = "SUSPENDED"
|
server.status = "SUSPENDED"
|
||||||
|
|
||||||
|
api.nova.extension_supported('AdminActions',
|
||||||
|
IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
||||||
.AndReturn(self.flavors.list())
|
.AndReturn(self.flavors.list())
|
||||||
search_opts = {'marker': None, 'paginate': True}
|
search_opts = {'marker': None, 'paginate': True}
|
||||||
@ -398,11 +435,15 @@ class InstanceTests(test.TestCase):
|
|||||||
|
|
||||||
@test.create_stubs({api.nova: ('server_resume',
|
@test.create_stubs({api.nova: ('server_resume',
|
||||||
'server_list',
|
'server_list',
|
||||||
'flavor_list',)})
|
'flavor_list',
|
||||||
|
'extension_supported',)})
|
||||||
def test_resume_instance_exception(self):
|
def test_resume_instance_exception(self):
|
||||||
server = self.servers.first()
|
server = self.servers.first()
|
||||||
server.status = "SUSPENDED"
|
server.status = "SUSPENDED"
|
||||||
|
|
||||||
|
api.nova.extension_supported('AdminActions',
|
||||||
|
IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
||||||
.AndReturn(self.flavors.list())
|
.AndReturn(self.flavors.list())
|
||||||
search_opts = {'marker': None, 'paginate': True}
|
search_opts = {'marker': None, 'paginate': True}
|
||||||
@ -1429,11 +1470,15 @@ class InstanceTests(test.TestCase):
|
|||||||
self.assertContains(res, "greater than or equal to 1")
|
self.assertContains(res, "greater than or equal to 1")
|
||||||
|
|
||||||
@test.create_stubs({api.nova: ('flavor_list', 'server_list',
|
@test.create_stubs({api.nova: ('flavor_list', 'server_list',
|
||||||
'tenant_absolute_limits',)})
|
'tenant_absolute_limits',
|
||||||
|
'extension_supported',)})
|
||||||
def test_launch_button_disabled_when_quota_exceeded(self):
|
def test_launch_button_disabled_when_quota_exceeded(self):
|
||||||
limits = self.limits['absolute']
|
limits = self.limits['absolute']
|
||||||
limits['totalInstancesUsed'] = limits['maxTotalInstances']
|
limits['totalInstancesUsed'] = limits['maxTotalInstances']
|
||||||
|
|
||||||
|
api.nova.extension_supported('AdminActions',
|
||||||
|
IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
||||||
.AndReturn(self.flavors.list())
|
.AndReturn(self.flavors.list())
|
||||||
search_opts = {'marker': None, 'paginate': True}
|
search_opts = {'marker': None, 'paginate': True}
|
||||||
@ -1458,11 +1503,14 @@ class InstanceTests(test.TestCase):
|
|||||||
msg_prefix="The launch button is not disabled")
|
msg_prefix="The launch button is not disabled")
|
||||||
|
|
||||||
@test.create_stubs({api.nova: ('flavor_list', 'server_list',
|
@test.create_stubs({api.nova: ('flavor_list', 'server_list',
|
||||||
'tenant_absolute_limits')})
|
'tenant_absolute_limits',
|
||||||
|
'extension_supported',)})
|
||||||
def test_index_options_after_migrate(self):
|
def test_index_options_after_migrate(self):
|
||||||
server = self.servers.first()
|
server = self.servers.first()
|
||||||
server.status = "VERIFY_RESIZE"
|
server.status = "VERIFY_RESIZE"
|
||||||
|
api.nova.extension_supported('AdminActions',
|
||||||
|
IsA(http.HttpRequest)) \
|
||||||
|
.MultipleTimes().AndReturn(True)
|
||||||
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
api.nova.flavor_list(IsA(http.HttpRequest)) \
|
||||||
.AndReturn(self.flavors.list())
|
.AndReturn(self.flavors.list())
|
||||||
search_opts = {'marker': None, 'paginate': True}
|
search_opts = {'marker': None, 'paginate': True}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user