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

« back to all changes in this revision

Viewing changes to nova/db/sqlalchemy/migrate_repo/versions/042_add_volume_types_and_extradata.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 (c) 2011 Zadara Storage Inc.
4
 
# Copyright (c) 2011 OpenStack LLC.
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, DateTime, Integer, MetaData, String, Table
19
 
from sqlalchemy import Boolean, ForeignKey
20
 
 
21
 
from nova import log as logging
22
 
 
23
 
LOG = logging.getLogger(__name__)
24
 
 
25
 
 
26
 
def upgrade(migrate_engine):
27
 
    meta = MetaData()
28
 
    meta.bind = migrate_engine
29
 
 
30
 
    volumes = Table('volumes', meta, autoload=True)
31
 
 
32
 
    #
33
 
    # New Tables
34
 
    #
35
 
    volume_types = Table('volume_types', 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('name',
42
 
                  String(length=255, convert_unicode=False,
43
 
                         assert_unicode=None,
44
 
                         unicode_error=None, _warn_on_bytestring=False),
45
 
                  unique=True))
46
 
 
47
 
    volume_type_extra_specs_table = Table('volume_type_extra_specs', meta,
48
 
            Column('created_at', DateTime(timezone=False)),
49
 
            Column('updated_at', DateTime(timezone=False)),
50
 
            Column('deleted_at', DateTime(timezone=False)),
51
 
            Column('deleted', Boolean(create_constraint=True, name=None)),
52
 
            Column('id', Integer(), primary_key=True, nullable=False),
53
 
            Column('volume_type_id',
54
 
                   Integer(),
55
 
                   ForeignKey('volume_types.id'),
56
 
                   nullable=False),
57
 
            Column('key',
58
 
                   String(length=255, convert_unicode=False,
59
 
                          assert_unicode=None,
60
 
                          unicode_error=None, _warn_on_bytestring=False)),
61
 
            Column('value',
62
 
                   String(length=255, convert_unicode=False,
63
 
                          assert_unicode=None,
64
 
                          unicode_error=None, _warn_on_bytestring=False)))
65
 
 
66
 
    volume_metadata_table = Table('volume_metadata', meta,
67
 
            Column('created_at', DateTime(timezone=False)),
68
 
            Column('updated_at', DateTime(timezone=False)),
69
 
            Column('deleted_at', DateTime(timezone=False)),
70
 
            Column('deleted', Boolean(create_constraint=True, name=None)),
71
 
            Column('id', Integer(), primary_key=True, nullable=False),
72
 
            Column('volume_id',
73
 
                   Integer(),
74
 
                   ForeignKey('volumes.id'),
75
 
                   nullable=False),
76
 
            Column('key',
77
 
                   String(length=255, convert_unicode=False,
78
 
                          assert_unicode=None,
79
 
                          unicode_error=None, _warn_on_bytestring=False)),
80
 
            Column('value',
81
 
                   String(length=255, convert_unicode=False,
82
 
                          assert_unicode=None,
83
 
                          unicode_error=None, _warn_on_bytestring=False)))
84
 
 
85
 
    new_tables = (volume_types,
86
 
                  volume_type_extra_specs_table,
87
 
                  volume_metadata_table)
88
 
 
89
 
    for table in new_tables:
90
 
        try:
91
 
            table.create()
92
 
        except Exception:
93
 
            LOG.info(repr(table))
94
 
            LOG.exception('Exception while creating table')
95
 
            raise
96
 
 
97
 
    #
98
 
    # New Columns
99
 
    #
100
 
    volume_type_id = Column('volume_type_id', Integer(), nullable=True)
101
 
    volumes.create_column(volume_type_id)
102
 
 
103
 
 
104
 
def downgrade(migrate_engine):
105
 
    meta = MetaData()
106
 
    meta.bind = migrate_engine
107
 
 
108
 
    volumes = Table('volumes', meta, autoload=True)
109
 
 
110
 
    volumes.drop_column('volume_type_id')
111
 
 
112
 
    volume_types = Table('volume_types', meta, autoload=True)
113
 
    volume_type_extra_specs_table = Table('volume_type_extra_specs',
114
 
                                          meta,
115
 
                                          autoload=True)
116
 
    volume_metadata_table = Table('volume_metadata', meta, autoload=True)
117
 
 
118
 
    # table order matters, don't change
119
 
    for table in (volume_type_extra_specs_table,
120
 
                  volume_types,
121
 
                  volume_metadata_table):
122
 
        table.drop()