Don't use sqlachemy Metadata as global var

In up>down>up mode migrations are failing due to using of common MetaData.
It should be declared separatly for both of migration methods.

Change-Id: I594c649def9a269033463558ba2aa9313f817ee5
Related-Bug: #1240898
This commit is contained in:
Mehdi Abaakouk 2013-10-22 16:49:52 +02:00
parent 7ba4986af1
commit 613887344d
11 changed files with 156 additions and 188 deletions

View File

@ -23,7 +23,9 @@ from sqlalchemy import String
from sqlalchemy import Table
from sqlalchemy import UniqueConstraint
meta = MetaData()
def upgrade(migrate_engine):
meta = MetaData(bind=migrate_engine)
meter = Table(
'meter', meta,
@ -92,17 +94,14 @@ source = Table(
mysql_charset='utf8',
)
tables = [meter, project, resource, user, source, sourceassoc]
def upgrade(migrate_engine):
meta.bind = migrate_engine
for i in sorted(tables):
i.create()
def downgrade(migrate_engine):
meta.bind = migrate_engine
for i in sorted(tables, reverse=True):
i.drop()
meta = MetaData(bind=migrate_engine)
for name in ['source', 'sourceassoc', 'project',
'user', 'resource', 'meter']:
t = Table(name, meta, autoload=True)
t.drop()

View File

@ -20,18 +20,15 @@ from sqlalchemy import MetaData
from sqlalchemy import Table
meta = MetaData()
def upgrade(migrate_engine):
meta.bind = migrate_engine
meta = MetaData(bind=migrate_engine)
meter = Table('meter', meta, autoload=True)
duration = Column('counter_duration', Integer)
meter.drop_column(duration)
def downgrade(migrate_engine):
meta.bind = migrate_engine
meta = MetaData(bind=migrate_engine)
meter = Table('meter', meta, autoload=True)
duration = Column('counter_duration', Integer)
meter.create_column(duration)

View File

@ -19,18 +19,16 @@ from sqlalchemy import MetaData
from sqlalchemy import String
from sqlalchemy import Table
meta = MetaData()
def upgrade(migrate_engine):
meta.bind = migrate_engine
meta = MetaData(bind=migrate_engine)
meter = Table('meter', meta, autoload=True)
unit = Column('counter_unit', String(255))
meter.create_column(unit)
def downgrade(migrate_engine):
meta.bind = migrate_engine
meta = MetaData(bind=migrate_engine)
meter = Table('meter', meta, autoload=True)
unit = Column('counter_unit', String(255))
meter.drop_column(unit)

View File

@ -20,11 +20,9 @@ from sqlalchemy import MetaData, Table, Column, DateTime
from ceilometer.openstack.common import timeutils
meta = MetaData()
def upgrade(migrate_engine):
meta.bind = migrate_engine
meta = MetaData(bind=migrate_engine)
resource = Table('resource', meta, autoload=True)
timestamp = Column('timestamp', DateTime)
resource.drop_column(timestamp)
@ -33,7 +31,7 @@ def upgrade(migrate_engine):
def downgrade(migrate_engine):
meta.bind = migrate_engine
meta = MetaData(bind=migrate_engine)
resource = Table('resource', meta, autoload=True)
timestamp = Column('timestamp', DateTime)
resource.create_column(timestamp)

View File

@ -21,16 +21,13 @@ from sqlalchemy import MetaData
from sqlalchemy import Table
meta = MetaData()
def upgrade(migrate_engine):
meta.bind = migrate_engine
meta = MetaData(bind=migrate_engine)
meter = Table('meter', meta, autoload=True)
meter.c.counter_volume.alter(type=Float(53))
def downgrade(migrate_engine):
meta.bind = migrate_engine
meta = MetaData(bind=migrate_engine)
meter = Table('meter', meta, autoload=True)
meter.c.counter_volume.alter(type=Integer)

View File

@ -21,8 +21,9 @@
from sqlalchemy import MetaData, Table, Column, Text
from sqlalchemy import Boolean, Integer, String, DateTime, Float
meta = MetaData()
def upgrade(migrate_engine):
meta = MetaData(bind=migrate_engine)
alarm = Table(
'alarm', meta,
Column('id', String(255), primary_key=True, index=True),
@ -46,13 +47,10 @@ alarm = Table(
Column('matching_metadata', Text()),
mysql_engine='InnoDB',
mysql_charset='utf8')
def upgrade(migrate_engine):
meta.bind = migrate_engine
alarm.create()
def downgrade(migrate_engine):
meta.bind = migrate_engine
meta = MetaData(bind=migrate_engine)
alarm = Table('alarm', meta, autoload=True)
alarm.drop()

View File

@ -21,8 +21,8 @@ from sqlalchemy import String
from sqlalchemy import Table
meta = MetaData()
def upgrade(migrate_engine):
meta = MetaData(bind=migrate_engine)
unique_name = Table(
'unique_name', meta,
@ -31,7 +31,7 @@ unique_name = Table(
mysql_engine='InnoDB',
mysql_charset='utf8',
)
unique_name.create()
event = Table(
'event', meta,
@ -41,34 +41,28 @@ event = Table(
mysql_engine='InnoDB',
mysql_charset='utf8',
)
event.create()
trait = Table(
'trait', meta,
Column('id', Integer, primary_key=True),
Column('name_id', Integer, ForeignKey('unique_name.id')),
Column('t_type', Integer, index=True),
Column('t_string', String(32), nullable=True, default=None, index=True),
Column('t_string', String(32), nullable=True, default=None,
index=True),
Column('t_float', Float, nullable=True, default=None, index=True),
Column('t_int', Integer, nullable=True, default=None, index=True),
Column('t_datetime', Float(asdecimal=True), nullable=True, default=None,
index=True),
Column('t_datetime', Float(asdecimal=True), nullable=True,
default=None, index=True),
Column('event_id', Integer, ForeignKey('event.id')),
mysql_engine='InnoDB',
mysql_charset='utf8',
)
tables = [unique_name, event, trait]
def upgrade(migrate_engine):
meta.bind = migrate_engine
for i in tables:
i.create()
trait.create()
def downgrade(migrate_engine):
meta.bind = migrate_engine
for i in reversed(tables):
i.drop()
meta = MetaData(bind=migrate_engine)
for name in ['trait', 'event', 'unique_name']:
t = Table(name, meta, autoload=True)
t.drop()

View File

@ -16,11 +16,9 @@ from sqlalchemy import MetaData
from sqlalchemy import Table
from sqlalchemy import VARCHAR
meta = MetaData()
def upgrade(migrate_engine):
meta.bind = migrate_engine
meta = MetaData(bind=migrate_engine)
name = Table('unique_name', meta, autoload=True)
name.c.key.alter(type=VARCHAR(length=255))
trait = Table('trait', meta, autoload=True)
@ -28,7 +26,7 @@ def upgrade(migrate_engine):
def downgrade(migrate_engine):
meta.bind = migrate_engine
meta = MetaData(bind=migrate_engine)
name = Table('unique_name', meta, autoload=True)
name.c.key.alter(type=VARCHAR(length=32))
trait = Table('trait', meta, autoload=True)

View File

@ -13,22 +13,17 @@
# License for the specific language governing permissions and limitations
# under the License.
from sqlalchemy import MetaData
from sqlalchemy import Index
from ceilometer.storage.sqlalchemy.models import Meter
meta = MetaData()
def upgrade(migrate_engine):
meta.bind = migrate_engine
index = Index('idx_meter_rid_cname', Meter.resource_id,
Meter.counter_name)
index.create(bind=migrate_engine)
def downgrade(migrate_engine):
meta.bind = migrate_engine
index = Index('idx_meter_rid_cname', Meter.resource_id,
Meter.counter_name)
index.drop(bind=migrate_engine)

View File

@ -23,16 +23,13 @@ from sqlalchemy import MetaData
from sqlalchemy import Table
meta = MetaData()
def upgrade(migrate_engine):
meta.bind = migrate_engine
meta = MetaData(bind=migrate_engine)
resource = Table('resource', meta, autoload=True)
resource.c.resource_metadata.alter(type=Text)
def downgrade(migrate_engine):
meta.bind = migrate_engine
meta = MetaData(bind=migrate_engine)
resource = Table('resource', meta, autoload=True)
resource.c.resource_metadata.alter(type=String(5000))

View File

@ -23,16 +23,13 @@ from sqlalchemy import MetaData
from sqlalchemy import Table
meta = MetaData()
def upgrade(migrate_engine):
meta.bind = migrate_engine
meta = MetaData(bind=migrate_engine)
alm_hist = Table('alarm_history', meta, autoload=True)
alm_hist.c.detail.alter(type=Text)
def downgrade(migrate_engine):
meta.bind = migrate_engine
meta = MetaData(bind=migrate_engine)
alm_hist = Table('alarm_history', meta, autoload=True)
alm_hist.c.detail.alter(type=String(255))