Merge "Hide the "Host Aggregates" admin panel if not enabled"

This commit is contained in:
Jenkins 2014-10-22 17:05:38 +00:00 committed by Gerrit Code Review
commit 6cf2b0658d
4 changed files with 33 additions and 0 deletions

View File

@ -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)

View File

@ -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):

View File

@ -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"]

View File

@ -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