Merge "Hide the "Host Aggregates" admin panel if not enabled"
This commit is contained in:
commit
6cf2b0658d
@ -14,6 +14,7 @@ from django.utils.translation import ugettext_lazy as _
|
|||||||
|
|
||||||
import horizon
|
import horizon
|
||||||
|
|
||||||
|
from openstack_dashboard.api import nova
|
||||||
from openstack_dashboard.dashboards.admin import dashboard
|
from openstack_dashboard.dashboards.admin import dashboard
|
||||||
|
|
||||||
|
|
||||||
@ -22,5 +23,12 @@ class Aggregates(horizon.Panel):
|
|||||||
slug = 'aggregates'
|
slug = 'aggregates'
|
||||||
permissions = ('openstack.services.compute',)
|
permissions = ('openstack.services.compute',)
|
||||||
|
|
||||||
|
def can_access(self, context):
|
||||||
|
# extend basic permission-based check with a check to see whether
|
||||||
|
# the Aggregates extension is even enabled in nova
|
||||||
|
if not nova.extension_supported('Aggregates', context['request']):
|
||||||
|
return False
|
||||||
|
return super(Aggregates, self).can_access(context)
|
||||||
|
|
||||||
|
|
||||||
dashboard.Admin.register(Aggregates)
|
dashboard.Admin.register(Aggregates)
|
||||||
|
@ -12,6 +12,8 @@
|
|||||||
|
|
||||||
import json
|
import json
|
||||||
|
|
||||||
|
import mock
|
||||||
|
|
||||||
from django.core.urlresolvers import reverse
|
from django.core.urlresolvers import reverse
|
||||||
from django import http
|
from django import http
|
||||||
from mox import IsA # noqa
|
from mox import IsA # noqa
|
||||||
@ -176,6 +178,13 @@ class CreateAggregateWorkflowTests(BaseAggregateWorkflowTests):
|
|||||||
|
|
||||||
class AggregatesViewTests(test.BaseAdminViewTests):
|
class AggregatesViewTests(test.BaseAdminViewTests):
|
||||||
|
|
||||||
|
@mock.patch('openstack_dashboard.api.nova.extension_supported',
|
||||||
|
mock.Mock(return_value=False))
|
||||||
|
def test_panel_not_available(self):
|
||||||
|
self.patchers['aggregates'].stop()
|
||||||
|
res = self.client.get(reverse('horizon:admin:overview:index'))
|
||||||
|
self.assertNotIn('Host Aggregates', res.content)
|
||||||
|
|
||||||
@test.create_stubs({api.nova: ('aggregate_details_list',
|
@test.create_stubs({api.nova: ('aggregate_details_list',
|
||||||
'availability_zone_list',), })
|
'availability_zone_list',), })
|
||||||
def test_index(self):
|
def test_index(self):
|
||||||
|
@ -37,6 +37,7 @@ import glanceclient
|
|||||||
from heatclient import client as heat_client
|
from heatclient import client as heat_client
|
||||||
import httplib2
|
import httplib2
|
||||||
from keystoneclient.v2_0 import client as keystone_client
|
from keystoneclient.v2_0 import client as keystone_client
|
||||||
|
import mock
|
||||||
import mox
|
import mox
|
||||||
from neutronclient.v2_0 import client as neutron_client
|
from neutronclient.v2_0 import client as neutron_client
|
||||||
from novaclient.v1_1 import client as nova_client
|
from novaclient.v1_1 import client as nova_client
|
||||||
@ -149,6 +150,12 @@ class TestCase(horizon_helpers.TestCase):
|
|||||||
self.request.session['token'] = self.token.id
|
self.request.session['token'] = self.token.id
|
||||||
middleware.HorizonMiddleware().process_request(self.request)
|
middleware.HorizonMiddleware().process_request(self.request)
|
||||||
AuthenticationMiddleware().process_request(self.request)
|
AuthenticationMiddleware().process_request(self.request)
|
||||||
|
self.patchers = {}
|
||||||
|
self.patchers['aggregates'] = mock.patch(
|
||||||
|
'openstack_dashboard.dashboards.admin'
|
||||||
|
'.aggregates.panel.Aggregates.can_access',
|
||||||
|
mock.Mock(return_value=True))
|
||||||
|
self.patchers['aggregates'].start()
|
||||||
os.environ["HORIZON_TEST_RUN"] = "True"
|
os.environ["HORIZON_TEST_RUN"] = "True"
|
||||||
|
|
||||||
def tearDown(self):
|
def tearDown(self):
|
||||||
@ -156,6 +163,7 @@ class TestCase(horizon_helpers.TestCase):
|
|||||||
httplib2.Http._conn_request = self._real_conn_request
|
httplib2.Http._conn_request = self._real_conn_request
|
||||||
context_processors.openstack = self._real_context_processor
|
context_processors.openstack = self._real_context_processor
|
||||||
utils.get_user = self._real_get_user
|
utils.get_user = self._real_get_user
|
||||||
|
mock.patch.stopall()
|
||||||
self.mox.VerifyAll()
|
self.mox.VerifyAll()
|
||||||
del os.environ["HORIZON_TEST_RUN"]
|
del os.environ["HORIZON_TEST_RUN"]
|
||||||
|
|
||||||
@ -396,11 +404,18 @@ class SeleniumTestCase(horizon_helpers.SeleniumTestCase):
|
|||||||
tenant_id=self.tenant.id,
|
tenant_id=self.tenant.id,
|
||||||
service_catalog=self.service_catalog,
|
service_catalog=self.service_catalog,
|
||||||
authorized_tenants=self.tenants.list())
|
authorized_tenants=self.tenants.list())
|
||||||
|
self.patchers = {}
|
||||||
|
self.patchers['aggregates'] = mock.patch(
|
||||||
|
'openstack_dashboard.dashboards.admin'
|
||||||
|
'.aggregates.panel.Aggregates.can_access',
|
||||||
|
mock.Mock(return_value=True))
|
||||||
|
self.patchers['aggregates'].start()
|
||||||
os.environ["HORIZON_TEST_RUN"] = "True"
|
os.environ["HORIZON_TEST_RUN"] = "True"
|
||||||
|
|
||||||
def tearDown(self):
|
def tearDown(self):
|
||||||
self.mox.UnsetStubs()
|
self.mox.UnsetStubs()
|
||||||
utils.get_user = self._real_get_user
|
utils.get_user = self._real_get_user
|
||||||
|
mock.patch.stopall()
|
||||||
self.mox.VerifyAll()
|
self.mox.VerifyAll()
|
||||||
del os.environ["HORIZON_TEST_RUN"]
|
del os.environ["HORIZON_TEST_RUN"]
|
||||||
|
|
||||||
|
@ -11,6 +11,7 @@ hacking>=0.9.2,<0.10
|
|||||||
#
|
#
|
||||||
coverage>=3.6
|
coverage>=3.6
|
||||||
django-nose
|
django-nose
|
||||||
|
mock>=1.0
|
||||||
mox>=0.5.3
|
mox>=0.5.3
|
||||||
nodeenv>=0.9.4 # BSD License
|
nodeenv>=0.9.4 # BSD License
|
||||||
nose
|
nose
|
||||||
|
Loading…
x
Reference in New Issue
Block a user