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

« back to all changes in this revision

Viewing changes to nova/db/sqlalchemy/migrate_repo/versions/036_change_flavor_id_in_migrations.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 2011 OpenStack LLC.
4
 
# All Rights Reserved.
5
 
#
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
9
 
#
10
 
#         http://www.apache.org/licenses/LICENSE-2.0
11
 
#
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
16
 
#    under the License.
17
 
 
18
 
from sqlalchemy import Column, Integer, MetaData, Table
19
 
 
20
 
 
21
 
def upgrade(migrate_engine):
22
 
    meta = MetaData()
23
 
    meta.bind = migrate_engine
24
 
 
25
 
    instance_types = Table('instance_types', meta, autoload=True)
26
 
    migrations = Table('migrations', meta, autoload=True)
27
 
 
28
 
    old_instance_type_id = Column('old_instance_type_id', Integer())
29
 
    new_instance_type_id = Column('new_instance_type_id', Integer())
30
 
    migrations.create_column(old_instance_type_id)
31
 
    migrations.create_column(new_instance_type_id)
32
 
 
33
 
    # Convert flavor_id to instance_type_id
34
 
    itypes = {}
35
 
    for instance_type in migrate_engine.execute(instance_types.select()):
36
 
        itypes[instance_type.id] = instance_type.flavorid
37
 
 
38
 
    for instance_type_id in itypes.keys():
39
 
        migrate_engine.execute(migrations.update()\
40
 
                .where(migrations.c.old_flavor_id == itypes[instance_type_id])\
41
 
                .values(old_instance_type_id=instance_type_id))
42
 
        migrate_engine.execute(migrations.update()\
43
 
                .where(migrations.c.new_flavor_id == itypes[instance_type_id])\
44
 
                .values(new_instance_type_id=instance_type_id))
45
 
 
46
 
    migrations.c.old_flavor_id.drop()
47
 
    migrations.c.new_flavor_id.drop()
48
 
 
49
 
 
50
 
def downgrade(migrate_engine):
51
 
    meta = MetaData()
52
 
    meta.bind = migrate_engine
53
 
 
54
 
    instance_types = Table('instance_types', meta, autoload=True)
55
 
    migrations = Table('migrations', meta, autoload=True)
56
 
 
57
 
    old_flavor_id = Column('old_flavor_id', Integer())
58
 
    new_flavor_id = Column('new_flavor_id', Integer())
59
 
 
60
 
    migrations.create_column(old_flavor_id)
61
 
    migrations.create_column(new_flavor_id)
62
 
 
63
 
    # Convert instance_type_id to flavor_id
64
 
    itypes = {}
65
 
    for instance_type in migrate_engine.execute(instance_types.select()):
66
 
        itypes[instance_type.flavorid] = instance_type.id
67
 
 
68
 
    for instance_type_flavorid in itypes.keys():
69
 
        migrate_engine.execute(migrations.update()\
70
 
                .where(migrations.c.old_instance_type_id ==
71
 
                    itypes[instance_type_flavorid])\
72
 
                .values(old_flavor_id=instance_type_flavorid))
73
 
        migrate_engine.execute(migrations.update()\
74
 
                .where(migrations.c.new_instance_type_id ==
75
 
                    itypes[instance_type_flavorid])\
76
 
                .values(new_flavor_id=instance_type_flavorid))
77
 
 
78
 
    migrations.c.old_instance_type_id.drop()
79
 
    migrations.c.new_instance_type_id.drop()