Permit using latest python-cinderclient

Fix a number of unit tests so that they will work with the latest
cinderclient, which will be released by the end of Kilo.

The problem was that several horizon unit tests made calls into
python-cinderclient that should have been stubbed out (but were not).
These calls silently did nothing in the released python-cinderclient due
to a "feature" where certain GET functions would return an empty list
when the auth url was an empty string, instead of returning an auth
failure.  Recent changes in the python-cinderclient authorization
functions closed this hole, which then revealed problems in the horizon
unit tests:
1) several tests were lacking stubs to cinder calls, and
2) the auth url in test of cinderclient v2 was empty due to a missing
   dictionary entry in test_data/keystone_data.py

Change-Id: I33967a924f4e47009fdc1613248afd1bd377f34f
Closes-Bug: 1423425
Co-Authored-By: Richard Hagarty <richard.hagarty@hp.com>
This commit is contained in:
Gary W. Smith 2015-03-03 11:19:17 -08:00
parent e26232633d
commit dca7117fdf
7 changed files with 67 additions and 4 deletions

View File

@ -180,13 +180,20 @@ class AggregatesViewTests(test.BaseAdminViewTests):
@mock.patch('openstack_dashboard.api.nova.extension_supported', @mock.patch('openstack_dashboard.api.nova.extension_supported',
mock.Mock(return_value=False)) mock.Mock(return_value=False))
@test.create_stubs({api.nova: ('aggregate_details_list',
'availability_zone_list',),
api.cinder: ('tenant_absolute_limits',)})
def test_panel_not_available(self): def test_panel_not_available(self):
api.cinder.tenant_absolute_limits(IsA(http.HttpRequest)). \
MultipleTimes().AndReturn(self.cinder_limits['absolute'])
self.mox.ReplayAll()
self.patchers['aggregates'].stop() self.patchers['aggregates'].stop()
res = self.client.get(reverse('horizon:admin:overview:index')) res = self.client.get(reverse('horizon:admin:overview:index'))
self.assertNotIn('Host Aggregates', res.content) 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):
api.nova.aggregate_details_list(IsA(http.HttpRequest)) \ api.nova.aggregate_details_list(IsA(http.HttpRequest)) \
.AndReturn(self.aggregates.list()) .AndReturn(self.aggregates.list())

View File

@ -64,6 +64,7 @@ class SystemInfoViewTests(test.BaseAdminViewTests):
services_tab._tables['services'].data, services_tab._tables['services'].data,
['<Service: compute>', ['<Service: compute>',
'<Service: volume>', '<Service: volume>',
'<Service: volumev2>',
'<Service: image>', '<Service: image>',
'<Service: identity (native backend)>', '<Service: identity (native backend)>',
'<Service: object-store>', '<Service: object-store>',

View File

@ -25,11 +25,14 @@ from openstack_dashboard.test import helpers as test
class VolumeTests(test.BaseAdminViewTests): class VolumeTests(test.BaseAdminViewTests):
@test.create_stubs({api.nova: ('server_list',), @test.create_stubs({api.nova: ('server_list',),
cinder: ('volume_list',), cinder: ('volume_list',
'volume_snapshot_list'),
keystone: ('tenant_list',)}) keystone: ('tenant_list',)})
def test_index(self): def test_index(self):
cinder.volume_list(IsA(http.HttpRequest), search_opts={ cinder.volume_list(IsA(http.HttpRequest), search_opts={
'all_tenants': True}).AndReturn(self.cinder_volumes.list()) 'all_tenants': True}).AndReturn(self.cinder_volumes.list())
cinder.volume_snapshot_list(IsA(http.HttpRequest), search_opts={
'all_tenants': True}).AndReturn([])
api.nova.server_list(IsA(http.HttpRequest), search_opts={ api.nova.server_list(IsA(http.HttpRequest), search_opts={
'all_tenants': True}) \ 'all_tenants': True}) \
.AndReturn([self.servers.list(), False]) .AndReturn([self.servers.list(), False])

View File

@ -65,6 +65,7 @@ class QosSpecsTests(test.BaseAdminViewTests):
self.assertMessageCount(success=1) self.assertMessageCount(success=1)
@test.create_stubs({api.cinder: ('volume_type_list_with_qos_associations', @test.create_stubs({api.cinder: ('volume_type_list_with_qos_associations',
'volume_encryption_type_list',
'qos_spec_list', 'qos_spec_list',
'qos_spec_delete',)}) 'qos_spec_delete',)})
def test_delete_qos_spec(self): def test_delete_qos_spec(self):
@ -74,6 +75,8 @@ class QosSpecsTests(test.BaseAdminViewTests):
api.cinder.volume_type_list_with_qos_associations( api.cinder.volume_type_list_with_qos_associations(
IsA(http.HttpRequest)).\ IsA(http.HttpRequest)).\
AndReturn(self.volume_types.list()) AndReturn(self.volume_types.list())
api.cinder.volume_encryption_type_list(IsA(http.HttpRequest))\
.AndReturn(self.cinder_volume_encryption_types.list()[0:1])
api.cinder.qos_spec_list(IsA(http.HttpRequest)).\ api.cinder.qos_spec_list(IsA(http.HttpRequest)).\
AndReturn(self.cinder_qos_specs.list()) AndReturn(self.cinder_qos_specs.list())
api.cinder.qos_spec_delete(IsA(http.HttpRequest), api.cinder.qos_spec_delete(IsA(http.HttpRequest),

View File

@ -82,10 +82,17 @@ class DataProcessingNodeGroupTests(test.TestCase):
@test.create_stubs({api.sahara: ('nodegroup_template_get', @test.create_stubs({api.sahara: ('nodegroup_template_get',
'plugin_get_version_details'), 'plugin_get_version_details'),
api.network: ('floating_ip_pools_list', api.network: ('floating_ip_pools_list',
'security_group_list')}) 'security_group_list'),
api.cinder: ('extension_supported',
'availability_zone_list')})
def test_copy(self): def test_copy(self):
ngt = self.nodegroup_templates.first() ngt = self.nodegroup_templates.first()
configs = self.plugins_configs.first() configs = self.plugins_configs.first()
api.cinder.extension_supported(IsA(http.HttpRequest),
'AvailabilityZones') \
.AndReturn(True)
api.cinder.availability_zone_list(IsA(http.HttpRequest))\
.AndReturn(self.availability_zones.list())
api.sahara.nodegroup_template_get(IsA(http.HttpRequest), api.sahara.nodegroup_template_get(IsA(http.HttpRequest),
ngt.id) \ ngt.id) \
.AndReturn(ngt) .AndReturn(ngt)
@ -114,7 +121,9 @@ class DataProcessingNodeGroupTests(test.TestCase):
'plugin_get_version_details'), 'plugin_get_version_details'),
api.network: ('floating_ip_pools_list', api.network: ('floating_ip_pools_list',
'security_group_list'), 'security_group_list'),
api.nova: ('flavor_list',)}) api.nova: ('flavor_list',),
api.cinder: ('extension_supported',
'availability_zone_list')})
def test_create(self): def test_create(self):
flavor = self.flavors.first() flavor = self.flavors.first()
ngt = self.nodegroup_templates.first() ngt = self.nodegroup_templates.first()
@ -123,6 +132,11 @@ class DataProcessingNodeGroupTests(test.TestCase):
self.mox.StubOutWithMock( self.mox.StubOutWithMock(
workflow_helpers, 'parse_configs_from_context') workflow_helpers, 'parse_configs_from_context')
api.cinder.extension_supported(IsA(http.HttpRequest),
'AvailabilityZones') \
.AndReturn(True)
api.cinder.availability_zone_list(IsA(http.HttpRequest))\
.AndReturn(self.availability_zones.list())
api.nova.flavor_list(IsA(http.HttpRequest)).AndReturn([flavor]) api.nova.flavor_list(IsA(http.HttpRequest)).AndReturn([flavor])
api.sahara.plugin_get_version_details(IsA(http.HttpRequest), api.sahara.plugin_get_version_details(IsA(http.HttpRequest),
ngt.plugin_name, ngt.plugin_name,

View File

@ -805,6 +805,7 @@ class VolumeViewTests(test.TestCase):
@test.create_stubs({cinder: ('tenant_absolute_limits', @test.create_stubs({cinder: ('tenant_absolute_limits',
'volume_list', 'volume_list',
'volume_snapshot_list',
'volume_backup_supported', 'volume_backup_supported',
'volume_delete',), 'volume_delete',),
api.nova: ('server_list',)}) api.nova: ('server_list',)})
@ -818,11 +819,17 @@ class VolumeViewTests(test.TestCase):
MultipleTimes().AndReturn(True) MultipleTimes().AndReturn(True)
cinder.volume_list(IsA(http.HttpRequest), search_opts=None).\ cinder.volume_list(IsA(http.HttpRequest), search_opts=None).\
AndReturn(volumes) AndReturn(volumes)
cinder.volume_snapshot_list(IsA(http.HttpRequest),
search_opts=None).\
AndReturn([])
cinder.volume_delete(IsA(http.HttpRequest), volume.id) cinder.volume_delete(IsA(http.HttpRequest), volume.id)
api.nova.server_list(IsA(http.HttpRequest), search_opts=None).\ api.nova.server_list(IsA(http.HttpRequest), search_opts=None).\
AndReturn([self.servers.list(), False]) AndReturn([self.servers.list(), False])
cinder.volume_list(IsA(http.HttpRequest), search_opts=None).\ cinder.volume_list(IsA(http.HttpRequest), search_opts=None).\
AndReturn(volumes) AndReturn(volumes)
cinder.volume_snapshot_list(IsA(http.HttpRequest),
search_opts=None).\
AndReturn([])
api.nova.server_list(IsA(http.HttpRequest), search_opts=None).\ api.nova.server_list(IsA(http.HttpRequest), search_opts=None).\
AndReturn([self.servers.list(), False]) AndReturn([self.servers.list(), False])
cinder.tenant_absolute_limits(IsA(http.HttpRequest)).MultipleTimes().\ cinder.tenant_absolute_limits(IsA(http.HttpRequest)).MultipleTimes().\
@ -996,6 +1003,7 @@ class VolumeViewTests(test.TestCase):
@test.create_stubs({cinder: ('tenant_absolute_limits', @test.create_stubs({cinder: ('tenant_absolute_limits',
'volume_list', 'volume_list',
'volume_snapshot_list',
'volume_backup_supported',), 'volume_backup_supported',),
api.nova: ('server_list',)}) api.nova: ('server_list',)})
def test_create_button_disabled_when_quota_exceeded(self): def test_create_button_disabled_when_quota_exceeded(self):
@ -1007,6 +1015,9 @@ class VolumeViewTests(test.TestCase):
MultipleTimes().AndReturn(True) MultipleTimes().AndReturn(True)
cinder.volume_list(IsA(http.HttpRequest), search_opts=None)\ cinder.volume_list(IsA(http.HttpRequest), search_opts=None)\
.AndReturn(volumes) .AndReturn(volumes)
cinder.volume_snapshot_list(IsA(http.HttpRequest),
search_opts=None).\
AndReturn([])
api.nova.server_list(IsA(http.HttpRequest), search_opts=None)\ api.nova.server_list(IsA(http.HttpRequest), search_opts=None)\
.AndReturn([self.servers.list(), False]) .AndReturn([self.servers.list(), False])
cinder.tenant_absolute_limits(IsA(http.HttpRequest))\ cinder.tenant_absolute_limits(IsA(http.HttpRequest))\
@ -1431,6 +1442,7 @@ class VolumeViewTests(test.TestCase):
self._test_encryption(True) self._test_encryption(True)
@test.create_stubs({cinder: ('volume_list', @test.create_stubs({cinder: ('volume_list',
'volume_snapshot_list',
'volume_backup_supported', 'volume_backup_supported',
'tenant_absolute_limits'), 'tenant_absolute_limits'),
api.nova: ('server_list',)}) api.nova: ('server_list',)})
@ -1444,6 +1456,9 @@ class VolumeViewTests(test.TestCase):
.MultipleTimes('backup_supported').AndReturn(False) .MultipleTimes('backup_supported').AndReturn(False)
cinder.volume_list(IsA(http.HttpRequest), search_opts=None)\ cinder.volume_list(IsA(http.HttpRequest), search_opts=None)\
.AndReturn(self.volumes.list()) .AndReturn(self.volumes.list())
cinder.volume_snapshot_list(IsA(http.HttpRequest),
search_opts=None).\
AndReturn(self.cinder_volume_snapshots.list())
api.nova.server_list(IsA(http.HttpRequest), search_opts=None)\ api.nova.server_list(IsA(http.HttpRequest), search_opts=None)\
.AndReturn([self.servers.list(), False]) .AndReturn([self.servers.list(), False])
cinder.tenant_absolute_limits(IsA(http.HttpRequest))\ cinder.tenant_absolute_limits(IsA(http.HttpRequest))\
@ -1492,6 +1507,7 @@ class VolumeViewTests(test.TestCase):
@test.create_stubs({cinder: ('volume_backup_supported', @test.create_stubs({cinder: ('volume_backup_supported',
'volume_list', 'volume_list',
'volume_snapshot_list',
'tenant_absolute_limits'), 'tenant_absolute_limits'),
api.nova: ('server_list',)}) api.nova: ('server_list',)})
def test_create_transfer_availability(self): def test_create_transfer_availability(self):
@ -1501,6 +1517,9 @@ class VolumeViewTests(test.TestCase):
.MultipleTimes().AndReturn(False) .MultipleTimes().AndReturn(False)
cinder.volume_list(IsA(http.HttpRequest), search_opts=None)\ cinder.volume_list(IsA(http.HttpRequest), search_opts=None)\
.AndReturn(self.volumes.list()) .AndReturn(self.volumes.list())
cinder.volume_snapshot_list(IsA(http.HttpRequest),
search_opts=None).\
AndReturn([])
api.nova.server_list(IsA(http.HttpRequest), search_opts=None)\ api.nova.server_list(IsA(http.HttpRequest), search_opts=None)\
.AndReturn([self.servers.list(), False]) .AndReturn([self.servers.list(), False])
cinder.tenant_absolute_limits(IsA(http.HttpRequest))\ cinder.tenant_absolute_limits(IsA(http.HttpRequest))\
@ -1540,6 +1559,7 @@ class VolumeViewTests(test.TestCase):
@test.create_stubs({cinder: ('volume_backup_supported', @test.create_stubs({cinder: ('volume_backup_supported',
'volume_list', 'volume_list',
'volume_snapshot_list',
'transfer_delete', 'transfer_delete',
'tenant_absolute_limits'), 'tenant_absolute_limits'),
api.nova: ('server_list',)}) api.nova: ('server_list',)})
@ -1560,6 +1580,9 @@ class VolumeViewTests(test.TestCase):
.MultipleTimes().AndReturn(False) .MultipleTimes().AndReturn(False)
cinder.volume_list(IsA(http.HttpRequest), search_opts=None)\ cinder.volume_list(IsA(http.HttpRequest), search_opts=None)\
.AndReturn(volumes) .AndReturn(volumes)
cinder.volume_snapshot_list(IsA(http.HttpRequest),
search_opts=None).\
AndReturn([])
cinder.transfer_delete(IsA(http.HttpRequest), transfer.id) cinder.transfer_delete(IsA(http.HttpRequest), transfer.id)
api.nova.server_list(IsA(http.HttpRequest), search_opts=None).\ api.nova.server_list(IsA(http.HttpRequest), search_opts=None).\
AndReturn([self.servers.list(), False]) AndReturn([self.servers.list(), False])

View File

@ -60,6 +60,18 @@ SERVICE_CATALOG = [
"adminURL": "http://admin.nova.example.com:8776/v1", "adminURL": "http://admin.nova.example.com:8776/v1",
"internalURL": "http://int.nova.example.com:8776/v1", "internalURL": "http://int.nova.example.com:8776/v1",
"publicURL": "http://public.nova.example.com:8776/v1"}]}, "publicURL": "http://public.nova.example.com:8776/v1"}]},
{"type": "volumev2",
"name": "cinderv2",
"endpoints_links": [],
"endpoints": [
{"region": "RegionOne",
"adminURL": "http://admin.nova.example.com:8776/v2",
"internalURL": "http://int.nova.example.com:8776/v2",
"publicURL": "http://public.nova.example.com:8776/v2"},
{"region": "RegionTwo",
"adminURL": "http://admin.nova.example.com:8776/v2",
"internalURL": "http://int.nova.example.com:8776/v2",
"publicURL": "http://public.nova.example.com:8776/v2"}]},
{"type": "image", {"type": "image",
"name": "glance", "name": "glance",
"endpoints_links": [], "endpoints_links": [],