~ubuntu-branches/ubuntu/saucy/nova/saucy-proposed

« back to all changes in this revision

Viewing changes to nova/db/sqlalchemy/migrate_repo/versions/087_add_uuid_to_bw_usage_cache.py

  • Committer: Package Import Robot
  • Author(s): Chuck Short
  • Date: 2012-05-24 13:12:53 UTC
  • mfrom: (1.1.55)
  • Revision ID: package-import@ubuntu.com-20120524131253-ommql08fg1en06ut
Tags: 2012.2~f1-0ubuntu1
* New upstream release.
* Prepare for quantal:
  - Dropped debian/patches/upstream/0006-Use-project_id-in-ec2.cloud._format_image.patch
  - Dropped debian/patches/upstream/0005-Populate-image-properties-with-project_id-again.patch
  - Dropped debian/patches/upstream/0004-Fixed-bug-962840-added-a-test-case.patch
  - Dropped debian/patches/upstream/0003-Allow-unprivileged-RADOS-users-to-access-rbd-volumes.patch
  - Dropped debian/patches/upstream/0002-Stop-libvirt-test-from-deleting-instances-dir.patch
  - Dropped debian/patches/upstream/0001-fix-bug-where-nova-ignores-glance-host-in-imageref.patch 
  - Dropped debian/patches/0001-fix-useexisting-deprecation-warnings.patch
* debian/control: Add python-keystone as a dependency. (LP: #907197)
* debian/patches/kombu_tests_timeout.patch: Refreshed.
* debian/nova.conf, debian/nova-common.postinst: Convert to new ini
  file configuration
* debian/patches/nova-manage_flagfile_location.patch: Refreshed

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# vim: tabstop=4 shiftwidth=4 softtabstop=4
 
2
 
 
3
# Copyright 2012 OpenStack LLC.
 
4
#
 
5
#    Licensed under the Apache License, Version 2.0 (the "License"); you may
 
6
#    not use this file except in compliance with the License. You may obtain
 
7
#    a copy of the License at
 
8
#
 
9
#         http://www.apache.org/licenses/LICENSE-2.0
 
10
#
 
11
#    Unless required by applicable law or agreed to in writing, software
 
12
#    distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 
13
#    WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 
14
#    License for the specific language governing permissions and limitations
 
15
#    under the License.
 
16
 
 
17
from sqlalchemy import Boolean, Column, DateTime, BigInteger
 
18
from sqlalchemy import MetaData, Integer, String, Table
 
19
 
 
20
from nova import log as logging
 
21
 
 
22
LOG = logging.getLogger(__name__)
 
23
 
 
24
 
 
25
def upgrade(migrate_engine):
 
26
    meta = MetaData()
 
27
    meta.bind = migrate_engine
 
28
 
 
29
    # add column:
 
30
    bw_usage_cache = Table('bw_usage_cache', meta, autoload=True)
 
31
    uuid = Column('uuid', String(36))
 
32
 
 
33
    # clear the cache to get rid of entries with no uuid
 
34
    migrate_engine.execute(bw_usage_cache.delete())
 
35
 
 
36
    bw_usage_cache.create_column(uuid)
 
37
 
 
38
 
 
39
def downgrade(migrate_engine):
 
40
    meta = MetaData()
 
41
    meta.bind = migrate_engine
 
42
 
 
43
    # drop column:
 
44
    bw_usage_cache = Table('bw_usage_cache', meta,
 
45
        Column('created_at', DateTime(timezone=False)),
 
46
        Column('updated_at', DateTime(timezone=False)),
 
47
        Column('deleted_at', DateTime(timezone=False)),
 
48
        Column('deleted', Boolean(create_constraint=True, name=None)),
 
49
        Column('id', Integer(), primary_key=True, nullable=False),
 
50
        Column('mac', String(255)),
 
51
        Column('uuid', String(36)),
 
52
        Column('start_period', DateTime(timezone=False), nullable=False),
 
53
        Column('last_refreshed', DateTime(timezone=False)),
 
54
        Column('bw_in', BigInteger()),
 
55
        Column('bw_out', BigInteger()),
 
56
        useexisting=True)
 
57
 
 
58
    bw_usage_cache.drop_column('uuid')