]> review.fuel-infra Code Review - openstack-build/cinder-build.git/commitdiff
Nested Quota : Create allocated column in cinder.quotas
authorVilobh Meshram <vilobhmm@yahoo-inc.com>
Fri, 19 Jun 2015 17:17:07 +0000 (10:17 -0700)
committerVilobh Meshram <vilobhmm@yahoo-inc.com>
Fri, 19 Jun 2015 17:22:45 +0000 (10:22 -0700)
Create allocated column in cinder.quotas. This allocated
column will be the sum of "hard_limits" values for the
immediate child projects. This will be needed to track
allocated quota to child projects.

Change-Id: Ia80d9a6cdbbc7e86cf9f11979f5e80c53f0fac1f
Implements: bp cinder-nested-quota-driver

cinder/db/sqlalchemy/migrate_repo/versions/048_add_allocated_in_quotas.py [new file with mode: 0644]
cinder/db/sqlalchemy/models.py
cinder/tests/unit/test_migrations.py

diff --git a/cinder/db/sqlalchemy/migrate_repo/versions/048_add_allocated_in_quotas.py b/cinder/db/sqlalchemy/migrate_repo/versions/048_add_allocated_in_quotas.py
new file mode 100644 (file)
index 0000000..3722364
--- /dev/null
@@ -0,0 +1,34 @@
+# Copyright 2015 Yahoo Inc.
+#
+#    Licensed under the Apache License, Version 2.0 (the "License"); you may
+#    not use this file except in compliance with the License. You may obtain
+#    a copy of the License at
+#
+#         http://www.apache.org/licenses/LICENSE-2.0
+#
+#    Unless required by applicable law or agreed to in writing, software
+#    distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
+#    WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
+#    License for the specific language governing permissions and limitations
+#    under the License.
+
+from sqlalchemy import Column, Integer, MetaData, Table
+
+
+def upgrade(migrate_engine):
+    meta = MetaData()
+    meta.bind = migrate_engine
+    quotas = Table('quotas', meta, autoload=True)
+
+    # Add a new column allocated to save allocated quota
+    allocated = Column('allocated', Integer, default=0)
+    quotas.create_column(allocated)
+
+
+def downgrade(migrate_engine):
+    """Remove allocated column from quotas."""
+    meta = MetaData()
+    meta.bind = migrate_engine
+
+    quotas = Table('quotas', meta, autoload=True)
+    quotas.drop_column('allocated')
index 989fd8401b5616f56d034c03ac1ca4988610b46b..ac42008c5fec9d722b7d55a0b9cacf0b02000f00 100644 (file)
@@ -366,6 +366,7 @@ class Quota(BASE, CinderBase):
 
     resource = Column(String(255))
     hard_limit = Column(Integer, nullable=True)
+    allocated = Column(Integer, default=0)
 
 
 class QuotaClass(BASE, CinderBase):
index 7028777a29a5f44375d5c5701227c60837afde55..57aae64829962828354fac18fdfe79e6bc03a005 100644 (file)
@@ -817,6 +817,15 @@ class MigrationsMixin(test_migrations.WalkVersionsMixin):
         services = db_utils.get_table(engine, 'services')
         self.assertNotIn('modified_at', services.c)
 
+    def _check_048(self, engine, data):
+        quotas = db_utils.get_table(engine, 'quotas')
+        self.assertIsInstance(quotas.c.allocated.type,
+                              sqlalchemy.types.INTEGER)
+
+    def _post_downgrade_048(self, engine):
+        quotas = db_utils.get_table(engine, 'quotas')
+        self.assertNotIn('allocated', quotas.c)
+
     def test_walk_versions(self):
         self.walk_versions(True, False)