ZhiQiang Fan | 39f9722 | 2013-09-20 04:49:44 +0800 | [diff] [blame] | 1 | # Copyright 2012 OpenStack Foundation |
Rohit Karajgi | 07599c5 | 2012-11-02 05:35:16 -0700 | [diff] [blame] | 2 | # All Rights Reserved. |
| 3 | # |
| 4 | # Licensed under the Apache License, Version 2.0 (the "License"); you may |
| 5 | # not use this file except in compliance with the License. You may obtain |
| 6 | # a copy of the License at |
| 7 | # |
| 8 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | # |
| 10 | # Unless required by applicable law or agreed to in writing, software |
| 11 | # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| 12 | # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| 13 | # License for the specific language governing permissions and limitations |
| 14 | # under the License. |
| 15 | |
Matt Riedemann | 848805f | 2014-06-16 13:23:51 -0700 | [diff] [blame] | 16 | import six |
| 17 | from testtools import matchers |
| 18 | |
Sean Dague | 1937d09 | 2013-05-17 16:36:38 -0400 | [diff] [blame] | 19 | from tempest.api.compute import base |
Matt Riedemann | 848805f | 2014-06-16 13:23:51 -0700 | [diff] [blame] | 20 | from tempest.common import tempest_fixtures as fixtures |
Masayuki Igawa | 259c113 | 2013-10-31 17:48:44 +0900 | [diff] [blame] | 21 | from tempest.common.utils import data_utils |
Matt Riedemann | 848805f | 2014-06-16 13:23:51 -0700 | [diff] [blame] | 22 | from tempest.openstack.common import log as logging |
Haiwei Xu | c367d91 | 2014-01-14 19:51:10 +0900 | [diff] [blame] | 23 | from tempest import test |
Sean Dague | 86bd842 | 2013-12-20 09:56:44 -0500 | [diff] [blame] | 24 | |
Matt Riedemann | 848805f | 2014-06-16 13:23:51 -0700 | [diff] [blame] | 25 | LOG = logging.getLogger(__name__) |
| 26 | |
Rohit Karajgi | 07599c5 | 2012-11-02 05:35:16 -0700 | [diff] [blame] | 27 | |
ivan-zhu | f2b0050 | 2013-10-18 10:06:52 +0800 | [diff] [blame] | 28 | class QuotasAdminTestJSON(base.BaseV2ComputeAdminTest): |
Attila Fazekas | 430dae3 | 2013-10-17 15:19:32 +0200 | [diff] [blame] | 29 | force_tenant_isolation = True |
Rohit Karajgi | 07599c5 | 2012-11-02 05:35:16 -0700 | [diff] [blame] | 30 | |
Matt Riedemann | 848805f | 2014-06-16 13:23:51 -0700 | [diff] [blame] | 31 | def setUp(self): |
| 32 | # NOTE(mriedem): Avoid conflicts with os-quota-class-sets tests. |
| 33 | self.useFixture(fixtures.LockFixture('compute_quotas')) |
| 34 | super(QuotasAdminTestJSON, self).setUp() |
| 35 | |
Rohit Karajgi | 07599c5 | 2012-11-02 05:35:16 -0700 | [diff] [blame] | 36 | @classmethod |
Andrea Frittoli | 50bb80d | 2014-09-15 12:34:27 +0100 | [diff] [blame] | 37 | def resource_setup(cls): |
| 38 | super(QuotasAdminTestJSON, cls).resource_setup() |
Attila Fazekas | 4ba3658 | 2013-02-12 08:26:17 +0100 | [diff] [blame] | 39 | cls.adm_client = cls.os_adm.quotas_client |
Attila Fazekas | 4ba3658 | 2013-02-12 08:26:17 +0100 | [diff] [blame] | 40 | |
Attila Fazekas | f7f34f9 | 2013-08-01 17:01:44 +0200 | [diff] [blame] | 41 | # NOTE(afazekas): these test cases should always create and use a new |
Attila Fazekas | 4ba3658 | 2013-02-12 08:26:17 +0100 | [diff] [blame] | 42 | # tenant most of them should be skipped if we can't do that |
Andrea Frittoli | 9612e81 | 2014-03-13 10:57:26 +0000 | [diff] [blame] | 43 | cls.demo_tenant_id = cls.quotas_client.tenant_id |
Rohit Karajgi | 07599c5 | 2012-11-02 05:35:16 -0700 | [diff] [blame] | 44 | |
Attila Fazekas | d9aef1e | 2013-07-13 17:33:45 +0200 | [diff] [blame] | 45 | cls.default_quota_set = set(('injected_file_content_bytes', |
| 46 | 'metadata_items', 'injected_files', |
| 47 | 'ram', 'floating_ips', |
| 48 | 'fixed_ips', 'key_pairs', |
| 49 | 'injected_file_path_bytes', |
| 50 | 'instances', 'security_group_rules', |
| 51 | 'cores', 'security_groups')) |
Rohit Karajgi | 07599c5 | 2012-11-02 05:35:16 -0700 | [diff] [blame] | 52 | |
Haiwei Xu | c367d91 | 2014-01-14 19:51:10 +0900 | [diff] [blame] | 53 | @test.attr(type='smoke') |
Rohit Karajgi | 07599c5 | 2012-11-02 05:35:16 -0700 | [diff] [blame] | 54 | def test_get_default_quotas(self): |
Sean Dague | 4dd2c0b | 2013-01-03 17:50:28 -0500 | [diff] [blame] | 55 | # Admin can get the default resource quota set for a tenant |
Attila Fazekas | d9aef1e | 2013-07-13 17:33:45 +0200 | [diff] [blame] | 56 | expected_quota_set = self.default_quota_set | set(['id']) |
David Kranz | 3e4c28b | 2015-02-09 12:35:18 -0500 | [diff] [blame] | 57 | quota_set = self.adm_client.get_default_quota_set( |
Leo Toyoda | 87a52b7 | 2013-04-09 10:34:40 +0900 | [diff] [blame] | 58 | self.demo_tenant_id) |
Attila Fazekas | d9aef1e | 2013-07-13 17:33:45 +0200 | [diff] [blame] | 59 | self.assertEqual(quota_set['id'], self.demo_tenant_id) |
Phil Day | 5f61539 | 2014-09-10 12:10:16 +0000 | [diff] [blame] | 60 | for quota in expected_quota_set: |
| 61 | self.assertIn(quota, quota_set.keys()) |
Rohit Karajgi | 07599c5 | 2012-11-02 05:35:16 -0700 | [diff] [blame] | 62 | |
Haiwei Xu | c367d91 | 2014-01-14 19:51:10 +0900 | [diff] [blame] | 63 | @test.attr(type='gate') |
Rohit Karajgi | 07599c5 | 2012-11-02 05:35:16 -0700 | [diff] [blame] | 64 | def test_update_all_quota_resources_for_tenant(self): |
Sean Dague | 4dd2c0b | 2013-01-03 17:50:28 -0500 | [diff] [blame] | 65 | # Admin can update all the resource quota limits for a tenant |
David Kranz | 3e4c28b | 2015-02-09 12:35:18 -0500 | [diff] [blame] | 66 | default_quota_set = self.adm_client.get_default_quota_set( |
gengjh | 01ba9cc | 2013-06-15 10:14:48 +0800 | [diff] [blame] | 67 | self.demo_tenant_id) |
| 68 | new_quota_set = {'injected_file_content_bytes': 20480, |
Rohit Karajgi | 07599c5 | 2012-11-02 05:35:16 -0700 | [diff] [blame] | 69 | 'metadata_items': 256, 'injected_files': 10, |
Michael Still | 9ac5bd0 | 2013-03-15 04:32:46 +1100 | [diff] [blame] | 70 | 'ram': 10240, 'floating_ips': 20, 'fixed_ips': 10, |
| 71 | 'key_pairs': 200, 'injected_file_path_bytes': 512, |
| 72 | 'instances': 20, 'security_group_rules': 20, |
| 73 | 'cores': 2, 'security_groups': 20} |
Matt Riedemann | bc8dbd3 | 2013-08-02 14:02:12 -0700 | [diff] [blame] | 74 | # Update limits for all quota resources |
David Kranz | 3e4c28b | 2015-02-09 12:35:18 -0500 | [diff] [blame] | 75 | quota_set = self.adm_client.update_quota_set( |
Matt Riedemann | bc8dbd3 | 2013-08-02 14:02:12 -0700 | [diff] [blame] | 76 | self.demo_tenant_id, |
gengjh | 01ba9cc | 2013-06-15 10:14:48 +0800 | [diff] [blame] | 77 | force=True, |
Matt Riedemann | bc8dbd3 | 2013-08-02 14:02:12 -0700 | [diff] [blame] | 78 | **new_quota_set) |
gengjh | 01ba9cc | 2013-06-15 10:14:48 +0800 | [diff] [blame] | 79 | |
| 80 | default_quota_set.pop('id') |
Phil Day | 5f61539 | 2014-09-10 12:10:16 +0000 | [diff] [blame] | 81 | # NOTE(PhilDay) The following is safe as we're not updating these |
| 82 | # two quota values yet. Once the Nova change to add these is merged |
| 83 | # and the client updated to support them this can be removed |
| 84 | if 'server_groups' in default_quota_set: |
| 85 | default_quota_set.pop('server_groups') |
| 86 | if 'server_group_members' in default_quota_set: |
| 87 | default_quota_set.pop('server_group_members') |
Matt Riedemann | bc8dbd3 | 2013-08-02 14:02:12 -0700 | [diff] [blame] | 88 | self.addCleanup(self.adm_client.update_quota_set, |
gengjh | 01ba9cc | 2013-06-15 10:14:48 +0800 | [diff] [blame] | 89 | self.demo_tenant_id, **default_quota_set) |
Phil Day | 5f61539 | 2014-09-10 12:10:16 +0000 | [diff] [blame] | 90 | for quota in new_quota_set: |
| 91 | self.assertIn(quota, quota_set.keys()) |
Rohit Karajgi | 07599c5 | 2012-11-02 05:35:16 -0700 | [diff] [blame] | 92 | |
Attila Fazekas | f7f34f9 | 2013-08-01 17:01:44 +0200 | [diff] [blame] | 93 | # TODO(afazekas): merge these test cases |
Haiwei Xu | c367d91 | 2014-01-14 19:51:10 +0900 | [diff] [blame] | 94 | @test.attr(type='gate') |
Rohit Karajgi | 07599c5 | 2012-11-02 05:35:16 -0700 | [diff] [blame] | 95 | def test_get_updated_quotas(self): |
Zhi Kun Liu | 27e154f | 2014-03-24 03:51:12 -0500 | [diff] [blame] | 96 | # Verify that GET shows the updated quota set of tenant |
Masayuki Igawa | 259c113 | 2013-10-31 17:48:44 +0900 | [diff] [blame] | 97 | tenant_name = data_utils.rand_name('cpu_quota_tenant_') |
Attila Fazekas | d9aef1e | 2013-07-13 17:33:45 +0200 | [diff] [blame] | 98 | tenant_desc = tenant_name + '-desc' |
| 99 | identity_client = self.os_adm.identity_client |
David Kranz | b7afa92 | 2014-12-30 10:56:26 -0500 | [diff] [blame] | 100 | tenant = identity_client.create_tenant(name=tenant_name, |
| 101 | description=tenant_desc) |
Attila Fazekas | d9aef1e | 2013-07-13 17:33:45 +0200 | [diff] [blame] | 102 | tenant_id = tenant['id'] |
Zhi Kun Liu | 27e154f | 2014-03-24 03:51:12 -0500 | [diff] [blame] | 103 | self.addCleanup(identity_client.delete_tenant, tenant_id) |
Rohit Karajgi | 07599c5 | 2012-11-02 05:35:16 -0700 | [diff] [blame] | 104 | |
Zhi Kun Liu | 27e154f | 2014-03-24 03:51:12 -0500 | [diff] [blame] | 105 | self.adm_client.update_quota_set(tenant_id, ram='5120') |
David Kranz | 3e4c28b | 2015-02-09 12:35:18 -0500 | [diff] [blame] | 106 | quota_set = self.adm_client.get_quota_set(tenant_id) |
Zhi Kun Liu | 27e154f | 2014-03-24 03:51:12 -0500 | [diff] [blame] | 107 | self.assertEqual(5120, quota_set['ram']) |
| 108 | |
| 109 | # Verify that GET shows the updated quota set of user |
| 110 | user_name = data_utils.rand_name('cpu_quota_user_') |
| 111 | password = data_utils.rand_name('password-') |
| 112 | email = user_name + '@testmail.tm' |
David Kranz | b7afa92 | 2014-12-30 10:56:26 -0500 | [diff] [blame] | 113 | user = identity_client.create_user(name=user_name, |
| 114 | password=password, |
| 115 | tenant_id=tenant_id, |
| 116 | email=email) |
Zhi Kun Liu | 27e154f | 2014-03-24 03:51:12 -0500 | [diff] [blame] | 117 | user_id = user['id'] |
| 118 | self.addCleanup(identity_client.delete_user, user_id) |
| 119 | |
| 120 | self.adm_client.update_quota_set(tenant_id, |
| 121 | user_id=user_id, |
| 122 | ram='2048') |
David Kranz | 3e4c28b | 2015-02-09 12:35:18 -0500 | [diff] [blame] | 123 | quota_set = self.adm_client.get_quota_set(tenant_id, |
| 124 | user_id=user_id) |
Zhi Kun Liu | 27e154f | 2014-03-24 03:51:12 -0500 | [diff] [blame] | 125 | self.assertEqual(2048, quota_set['ram']) |
Attila Fazekas | d9aef1e | 2013-07-13 17:33:45 +0200 | [diff] [blame] | 126 | |
Yuiko Takada | 2209cf5 | 2014-02-27 12:03:49 +0000 | [diff] [blame] | 127 | @test.attr(type='gate') |
| 128 | def test_delete_quota(self): |
| 129 | # Admin can delete the resource quota set for a tenant |
| 130 | tenant_name = data_utils.rand_name('ram_quota_tenant_') |
| 131 | tenant_desc = tenant_name + '-desc' |
| 132 | identity_client = self.os_adm.identity_client |
David Kranz | b7afa92 | 2014-12-30 10:56:26 -0500 | [diff] [blame] | 133 | tenant = identity_client.create_tenant(name=tenant_name, |
| 134 | description=tenant_desc) |
Yuiko Takada | 2209cf5 | 2014-02-27 12:03:49 +0000 | [diff] [blame] | 135 | tenant_id = tenant['id'] |
| 136 | self.addCleanup(identity_client.delete_tenant, tenant_id) |
David Kranz | 3e4c28b | 2015-02-09 12:35:18 -0500 | [diff] [blame] | 137 | quota_set_default = self.adm_client.get_quota_set(tenant_id) |
Yuiko Takada | 2209cf5 | 2014-02-27 12:03:49 +0000 | [diff] [blame] | 138 | ram_default = quota_set_default['ram'] |
| 139 | |
David Kranz | 3e4c28b | 2015-02-09 12:35:18 -0500 | [diff] [blame] | 140 | self.adm_client.update_quota_set(tenant_id, ram='5120') |
Yuiko Takada | 2209cf5 | 2014-02-27 12:03:49 +0000 | [diff] [blame] | 141 | |
David Kranz | 3e4c28b | 2015-02-09 12:35:18 -0500 | [diff] [blame] | 142 | self.adm_client.delete_quota_set(tenant_id) |
Yuiko Takada | 2209cf5 | 2014-02-27 12:03:49 +0000 | [diff] [blame] | 143 | |
David Kranz | 3e4c28b | 2015-02-09 12:35:18 -0500 | [diff] [blame] | 144 | quota_set_new = self.adm_client.get_quota_set(tenant_id) |
Yuiko Takada | 2209cf5 | 2014-02-27 12:03:49 +0000 | [diff] [blame] | 145 | self.assertEqual(ram_default, quota_set_new['ram']) |
| 146 | |
rajalakshmi-ganesan | 1982c3c | 2013-01-10 14:56:45 +0530 | [diff] [blame] | 147 | |
Matt Riedemann | 848805f | 2014-06-16 13:23:51 -0700 | [diff] [blame] | 148 | class QuotaClassesAdminTestJSON(base.BaseV2ComputeAdminTest): |
| 149 | """Tests the os-quota-class-sets API to update default quotas. |
| 150 | """ |
| 151 | |
| 152 | def setUp(self): |
| 153 | # All test cases in this class need to externally lock on doing |
| 154 | # anything with default quota values. |
| 155 | self.useFixture(fixtures.LockFixture('compute_quotas')) |
| 156 | super(QuotaClassesAdminTestJSON, self).setUp() |
| 157 | |
| 158 | @classmethod |
Andrea Frittoli | 50bb80d | 2014-09-15 12:34:27 +0100 | [diff] [blame] | 159 | def resource_setup(cls): |
| 160 | super(QuotaClassesAdminTestJSON, cls).resource_setup() |
Matt Riedemann | 848805f | 2014-06-16 13:23:51 -0700 | [diff] [blame] | 161 | cls.adm_client = cls.os_adm.quota_classes_client |
| 162 | |
| 163 | def _restore_default_quotas(self, original_defaults): |
| 164 | LOG.debug("restoring quota class defaults") |
David Kranz | 3e4c28b | 2015-02-09 12:35:18 -0500 | [diff] [blame] | 165 | self.adm_client.update_quota_class_set( |
Matt Riedemann | 848805f | 2014-06-16 13:23:51 -0700 | [diff] [blame] | 166 | 'default', **original_defaults) |
Matt Riedemann | 848805f | 2014-06-16 13:23:51 -0700 | [diff] [blame] | 167 | |
Sean Dague | e3e9da7 | 2014-07-09 07:11:59 -0400 | [diff] [blame] | 168 | # NOTE(sdague): this test is problematic as it changes |
| 169 | # global state, and possibly needs to be part of a set of |
| 170 | # tests that get run all by themselves at the end under a |
| 171 | # 'danger' flag. |
Matt Riedemann | 848805f | 2014-06-16 13:23:51 -0700 | [diff] [blame] | 172 | def test_update_default_quotas(self): |
| 173 | LOG.debug("get the current 'default' quota class values") |
David Kranz | 3e4c28b | 2015-02-09 12:35:18 -0500 | [diff] [blame] | 174 | body = self.adm_client.get_quota_class_set('default') |
Matt Riedemann | 848805f | 2014-06-16 13:23:51 -0700 | [diff] [blame] | 175 | self.assertIn('id', body) |
| 176 | self.assertEqual('default', body.pop('id')) |
| 177 | # restore the defaults when the test is done |
| 178 | self.addCleanup(self._restore_default_quotas, body.copy()) |
| 179 | # increment all of the values for updating the default quota class |
| 180 | for quota, default in six.iteritems(body): |
Sean Dague | e3e9da7 | 2014-07-09 07:11:59 -0400 | [diff] [blame] | 181 | # NOTE(sdague): we need to increment a lot, otherwise |
| 182 | # there is a real chance that we go from -1 (unlimitted) |
| 183 | # to a very small number which causes issues. |
| 184 | body[quota] = default + 100 |
Matt Riedemann | 848805f | 2014-06-16 13:23:51 -0700 | [diff] [blame] | 185 | LOG.debug("update limits for the default quota class set") |
David Kranz | 3e4c28b | 2015-02-09 12:35:18 -0500 | [diff] [blame] | 186 | update_body = self.adm_client.update_quota_class_set('default', |
| 187 | **body) |
Matt Riedemann | 848805f | 2014-06-16 13:23:51 -0700 | [diff] [blame] | 188 | LOG.debug("assert that the response has all of the changed values") |
| 189 | self.assertThat(update_body.items(), |
| 190 | matchers.ContainsAll(body.items())) |