1
# vim: tabstop=4 shiftwidth=4 softtabstop=4
3
# Copyright 2011 MORITA Kazutaka.
6
# Licensed under the Apache License, Version 2.0 (the "License"); you may
7
# not use this file except in compliance with the License. You may obtain
8
# a copy of the License at
10
# http://www.apache.org/licenses/LICENSE-2.0
12
# Unless required by applicable law or agreed to in writing, software
13
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
14
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
15
# License for the specific language governing permissions and limitations
18
from sqlalchemy import Column, Table, MetaData
19
from sqlalchemy import Integer, BigInteger, DateTime, Boolean, String
21
from nova import log as logging
23
LOG = logging.getLogger(__name__)
26
def upgrade(migrate_engine):
27
# Upgrade operations go here. Don't create your own engine;
28
# bind migrate_engine to your metadata
30
meta.bind = migrate_engine
35
bw_cache = Table('bw_usage_cache', meta,
36
Column('created_at', DateTime(timezone=False)),
37
Column('updated_at', DateTime(timezone=False)),
38
Column('deleted_at', DateTime(timezone=False)),
39
Column('deleted', Boolean(create_constraint=True, name=None)),
40
Column('id', Integer(), primary_key=True, nullable=False),
41
Column('instance_id', Integer(), nullable=False),
42
Column('network_label',
43
String(length=255, convert_unicode=False,
45
unicode_error=None, _warn_on_bytestring=False)),
46
Column('start_period', DateTime(timezone=False), nullable=False),
47
Column('last_refreshed', DateTime(timezone=False)),
48
Column('bw_in', BigInteger()),
49
Column('bw_out', BigInteger()))
53
LOG.info(repr(bw_cache))
54
LOG.exception('Exception while creating table')
55
meta.drop_all(tables=[bw_cache])
59
def downgrade(migrate_engine):
60
# Operations to reverse the above upgrade go here.
62
meta.bind = migrate_engine
63
bw_cache = Table('bw_usage_cache', meta, autoload=True)