~ubuntu-branches/ubuntu/raring/nova/raring-proposed

« back to all changes in this revision

Viewing changes to nova/db/sqlalchemy/migrate_repo/versions/095_change_fk_instance_id_to_uuid.py

  • Committer: Package Import Robot
  • Author(s): Chuck Short, Adam Gandelman, Chuck Short
  • Date: 2012-11-23 09:04:58 UTC
  • mfrom: (1.1.66)
  • Revision ID: package-import@ubuntu.com-20121123090458-91565o7aev1i1h71
Tags: 2013.1~g1-0ubuntu1
[ Adam Gandelman ]
* debian/control: Ensure novaclient is upgraded with nova,
  require python-keystoneclient >= 1:2.9.0. (LP: #1073289)
* debian/patches/{ubuntu/*, rbd-security.patch}: Dropped, applied
  upstream.
* debian/control: Add python-testtools to Build-Depends.

[ Chuck Short ]
* New upstream version.
* Refreshed debian/patches/avoid_setuptools_git_dependency.patch.
* debian/rules: FTBFS if missing binaries.
* debian/nova-scheudler.install: Add missing rabbit-queues and
  nova-rpc-zmq-receiver.
* Remove nova-volume since it doesnt exist anymore, transition to cinder-*.
* debian/rules: install apport hook in the right place.
* debian/patches/ubuntu-show-tests.patch: Display test failures.
* debian/control: Add depends on genisoimage
* debian/control: Suggest guestmount.
* debian/control: Suggest websockify. (LP: #1076442)
* debian/nova.conf: Disable nova-volume service.
* debian/control: Depend on xen-system-* rather than the hypervisor.
* debian/control, debian/mans/nova-conductor.8, debian/nova-conductor.init,
  debian/nova-conductor.install, debian/nova-conductor.logrotate
  debian/nova-conductor.manpages, debian/nova-conductor.postrm
  debian/nova-conductor.upstart.in: Add nova-conductor service.
* debian/control: Add python-fixtures as a build deps.

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
 
# Copyright 2012 SolidFire Inc
5
 
# All Rights Reserved.
6
 
#
7
 
#    Licensed under the Apache License, Version 2.0 (the "License"); you may
8
 
#    not use this file except in compliance with the License. You may obtain
9
 
#    a copy of the License at
10
 
#
11
 
#         http://www.apache.org/licenses/LICENSE-2.0
12
 
#
13
 
#    Unless required by applicable law or agreed to in writing, software
14
 
#    distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
15
 
#    WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
16
 
#    License for the specific language governing permissions and limitations
17
 
#    under the License.
18
 
 
19
 
from migrate import ForeignKeyConstraint
20
 
from sqlalchemy import MetaData, Integer, String, Table
21
 
from sqlalchemy import select, Column
22
 
 
23
 
from nova.openstack.common import log as logging
24
 
 
25
 
 
26
 
LOG = logging.getLogger(__name__)
27
 
 
28
 
 
29
 
def upgrade(migrate_engine):
30
 
    meta = MetaData()
31
 
    meta.bind = migrate_engine
32
 
 
33
 
    instances = Table('instances', meta, autoload=True)
34
 
    volumes = Table('volumes', meta, autoload=True)
35
 
    instance_uuid_column = Column('instance_uuid', String(36))
36
 
 
37
 
    instance_uuid_column.create(volumes)
38
 
    try:
39
 
        volumes.update().values(
40
 
            instance_uuid=select(
41
 
                [instances.c.uuid],
42
 
                instances.c.id == volumes.c.instance_id)
43
 
                ).execute()
44
 
    except Exception:
45
 
        instance_uuid_column.drop()
46
 
 
47
 
    fkeys = list(volumes.c.instance_id.foreign_keys)
48
 
    if fkeys:
49
 
        try:
50
 
            fk_name = fkeys[0].constraint.name
51
 
            ForeignKeyConstraint(
52
 
                columns=[volumes.c.instance_id],
53
 
                refcolumns=[instances.c.id],
54
 
                name=fk_name).drop()
55
 
 
56
 
        except Exception:
57
 
            LOG.error(_("foreign key could not be dropped"))
58
 
            raise
59
 
 
60
 
    volumes.c.instance_id.drop()
61
 
 
62
 
 
63
 
def downgrade(migrate_engine):
64
 
    meta = MetaData()
65
 
    meta.bind = migrate_engine
66
 
 
67
 
    instances = Table('instances', meta, autoload=True)
68
 
    volumes = Table('volumes', meta, autoload=True)
69
 
    instance_id_column = Column('instance_id', Integer)
70
 
 
71
 
    instance_id_column.create(volumes)
72
 
    try:
73
 
        volumes.update().values(
74
 
            instance_id=select(
75
 
                [instances.c.id],
76
 
                instances.c.uuid == volumes.c.instance_uuid)
77
 
                ).execute()
78
 
    except Exception:
79
 
        instance_id_column.drop()
80
 
 
81
 
    fkeys = list(volumes.c.instance_id.foreign_keys)
82
 
    if fkeys:
83
 
        try:
84
 
            fk_name = fkeys[0].constraint.name
85
 
            ForeignKeyConstraint(
86
 
                columns=[volumes.c.instance_id],
87
 
                refcolumns=[instances.c.id],
88
 
                name=fk_name).create()
89
 
 
90
 
        except Exception:
91
 
            LOG.error(_("foreign key could not be created"))
92
 
            raise
93
 
 
94
 
    volumes.c.instance_uuid.drop()