Merge "Refactor quota related unit tests"
This commit is contained in:
@@ -351,19 +351,13 @@ class FloatingIpViewTests(test.TestCase):
|
|||||||
)
|
)
|
||||||
|
|
||||||
@test.create_mocks({api.neutron: ('floating_ip_pools_list',
|
@test.create_mocks({api.neutron: ('floating_ip_pools_list',
|
||||||
'tenant_floating_ip_list',
|
'is_extension_supported'),
|
||||||
'is_extension_supported',
|
quotas: ('tenant_quota_usages',)})
|
||||||
'is_router_enabled',
|
|
||||||
'tenant_quota_get'),
|
|
||||||
api.base: ('is_service_enabled',)})
|
|
||||||
@test.update_settings(OPENSTACK_NEUTRON_NETWORK={'enable_quotas': True})
|
@test.update_settings(OPENSTACK_NEUTRON_NETWORK={'enable_quotas': True})
|
||||||
def test_correct_quotas_displayed(self):
|
def test_correct_quotas_displayed(self):
|
||||||
self.mock_is_service_enabled.return_value = True
|
|
||||||
self.mock_is_extension_supported.side_effect = [False, True, False]
|
self.mock_is_extension_supported.side_effect = [False, True, False]
|
||||||
self.mock_is_router_enabled.return_value = True
|
self.mock_tenant_quota_usages.return_value = \
|
||||||
self.mock_tenant_quota_get.return_value = self.neutron_quotas.first()
|
self.neutron_quota_usages.first()
|
||||||
self.mock_tenant_floating_ip_list.return_value = \
|
|
||||||
self.floating_ips.list()
|
|
||||||
self.mock_floating_ip_pools_list.return_value = self.pools.list()
|
self.mock_floating_ip_pools_list.return_value = self.pools.list()
|
||||||
|
|
||||||
url = reverse('%s:allocate' % NAMESPACE)
|
url = reverse('%s:allocate' % NAMESPACE)
|
||||||
@@ -371,19 +365,9 @@ class FloatingIpViewTests(test.TestCase):
|
|||||||
self.assertEqual(res.context['usages']['floatingip']['quota'],
|
self.assertEqual(res.context['usages']['floatingip']['quota'],
|
||||||
self.neutron_quotas.first().get('floatingip').limit)
|
self.neutron_quotas.first().get('floatingip').limit)
|
||||||
|
|
||||||
self.mock_is_service_enabled.assert_called_once_with(
|
self.mock_is_extension_supported.assert_called_once_with(
|
||||||
test.IsHttpRequest(), 'network')
|
test.IsHttpRequest(), 'dns-integration')
|
||||||
self.assertEqual(3, self.mock_is_extension_supported.call_count)
|
self.mock_tenant_quota_usages.assert_called_once_with(
|
||||||
self.mock_is_extension_supported.assert_has_calls([
|
test.IsHttpRequest(), targets=('floatingip',))
|
||||||
mock.call(test.IsHttpRequest(), 'dns-integration'),
|
|
||||||
mock.call(test.IsHttpRequest(), 'quotas'),
|
|
||||||
mock.call(test.IsHttpRequest(), 'quota_details'),
|
|
||||||
])
|
|
||||||
self.mock_is_router_enabled.assert_called_once_with(
|
|
||||||
test.IsHttpRequest())
|
|
||||||
self.mock_tenant_quota_get.assert_called_once_with(
|
|
||||||
test.IsHttpRequest(), self.tenant.id)
|
|
||||||
self.mock_tenant_floating_ip_list.assert_called_once_with(
|
|
||||||
test.IsHttpRequest())
|
|
||||||
self.mock_floating_ip_pools_list.assert_called_once_with(
|
self.mock_floating_ip_pools_list.assert_called_once_with(
|
||||||
test.IsHttpRequest())
|
test.IsHttpRequest())
|
||||||
|
@@ -461,13 +461,13 @@ class QuotaTests(test.APITestCase):
|
|||||||
# quotas._get_tenant_network_usages)
|
# quotas._get_tenant_network_usages)
|
||||||
@test.create_mocks({api.base: ('is_service_enabled',),
|
@test.create_mocks({api.base: ('is_service_enabled',),
|
||||||
cinder: ('is_volume_service_enabled',),
|
cinder: ('is_volume_service_enabled',),
|
||||||
api.neutron: ('floating_ip_supported',
|
api.neutron: ('is_extension_supported',
|
||||||
'is_extension_supported',
|
|
||||||
'is_quotas_extension_supported',
|
'is_quotas_extension_supported',
|
||||||
'tenant_quota_detail_get')})
|
'tenant_quota_detail_get')})
|
||||||
def test_tenant_quota_usages_non_legacy(self):
|
def test_tenant_quota_usages_non_legacy(self):
|
||||||
self._mock_service_enabled(network_enabled=True)
|
self._mock_service_enabled(network_enabled=True)
|
||||||
self.mock_is_extension_supported.return_value = True
|
self.mock_is_extension_supported.return_value = True
|
||||||
|
self.mock_is_quotas_extension_supported.return_value = True
|
||||||
|
|
||||||
test_data = [
|
test_data = [
|
||||||
("network", self.networks.list(), 10),
|
("network", self.networks.list(), 10),
|
||||||
@@ -510,6 +510,39 @@ class QuotaTests(test.APITestCase):
|
|||||||
self.assertAvailableQuotasEqual(expected, quota_usages.usages,
|
self.assertAvailableQuotasEqual(expected, quota_usages.usages,
|
||||||
msg=msg)
|
msg=msg)
|
||||||
|
|
||||||
|
self.assert_mock_multiple_calls_with_same_arguments(
|
||||||
|
self.mock_is_service_enabled, len(test_data),
|
||||||
|
mock.call(test.IsHttpRequest(), 'network'))
|
||||||
|
# NOTE: is_volume_service_enabled() needs to be mocked
|
||||||
|
# as _mock_service_enabled() requires it, but it is never called here.
|
||||||
|
self.mock_is_volume_service_enabled.assert_not_called()
|
||||||
|
self.mock_is_extension_supported.assert_has_calls([
|
||||||
|
# network
|
||||||
|
mock.call(test.IsHttpRequest(), 'quota_details'),
|
||||||
|
# subnet
|
||||||
|
mock.call(test.IsHttpRequest(), 'quota_details'),
|
||||||
|
# port
|
||||||
|
mock.call(test.IsHttpRequest(), 'quota_details'),
|
||||||
|
# router
|
||||||
|
mock.call(test.IsHttpRequest(), 'router'),
|
||||||
|
mock.call(test.IsHttpRequest(), 'quota_details'),
|
||||||
|
# floating IP
|
||||||
|
mock.call(test.IsHttpRequest(), 'quota_details'),
|
||||||
|
# security group
|
||||||
|
mock.call(test.IsHttpRequest(), 'security-group'),
|
||||||
|
mock.call(test.IsHttpRequest(), 'quota_details'),
|
||||||
|
# security group rule
|
||||||
|
mock.call(test.IsHttpRequest(), 'security-group'),
|
||||||
|
mock.call(test.IsHttpRequest(), 'quota_details'),
|
||||||
|
])
|
||||||
|
self.assertEqual(10, self.mock_is_extension_supported.call_count)
|
||||||
|
self.assert_mock_multiple_calls_with_same_arguments(
|
||||||
|
self.mock_is_quotas_extension_supported, len(test_data),
|
||||||
|
mock.call(test.IsHttpRequest()))
|
||||||
|
self.assert_mock_multiple_calls_with_same_arguments(
|
||||||
|
self.mock_tenant_quota_detail_get, len(test_data),
|
||||||
|
mock.call(test.IsHttpRequest(), self.request.user.tenant_id))
|
||||||
|
|
||||||
@test.create_mocks({api.base: ('is_service_enabled',),
|
@test.create_mocks({api.base: ('is_service_enabled',),
|
||||||
cinder: ('is_volume_service_enabled',),
|
cinder: ('is_volume_service_enabled',),
|
||||||
api.neutron: ('floating_ip_supported',
|
api.neutron: ('floating_ip_supported',
|
||||||
|
Reference in New Issue
Block a user