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

« back to all changes in this revision

Viewing changes to nova/db/sqlalchemy/migrate_repo/versions/140_drop_unused_postgresql_volume_sequences.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 (c) 2012 Red Hat, Inc.
 
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 MetaData
 
19
 
 
20
 
 
21
def upgrade(migrate_engine):
 
22
    meta = MetaData()
 
23
    meta.bind = migrate_engine
 
24
 
 
25
    # NOTE(dprince): Remove unused snapshots/volumes sequences.
 
26
    # These are leftovers from the ID --> UUID conversion for these tables
 
27
    # that occurred in Folsom.
 
28
    if migrate_engine.name == "postgresql":
 
29
        base_query = """SELECT COUNT(*) FROM pg_class c
 
30
                     WHERE c.relkind = 'S'
 
31
                     AND relname = '%s';"""
 
32
        result = migrate_engine.execute(base_query % "snapshots_id_seq")
 
33
        if result.scalar() > 0:
 
34
            sql = "DROP SEQUENCE snapshots_id_seq CASCADE;"
 
35
            migrate_engine.execute(sql)
 
36
 
 
37
        result = migrate_engine.execute(base_query % "volumes_id_seq")
 
38
        if result.scalar() > 0:
 
39
            sql = "DROP SEQUENCE volumes_id_seq CASCADE;"
 
40
            migrate_engine.execute(sql)
 
41
 
 
42
 
 
43
def downgrade(migrate_engine):
 
44
    meta = MetaData()
 
45
    meta.bind = migrate_engine
 
46
 
 
47
    if migrate_engine.name == "postgresql":
 
48
        sql = """CREATE SEQUENCE snapshots_id_seq START WITH 1 INCREMENT BY 1
 
49
              NO MINVALUE NO MAXVALUE CACHE 1;
 
50
              ALTER SEQUENCE snapshots_id_seq OWNED BY snapshots.id;
 
51
              SELECT pg_catalog.setval('snapshots_id_seq', 1, false);
 
52
              ALTER TABLE ONLY snapshots ALTER COLUMN id SET DEFAULT
 
53
              nextval('snapshots_id_seq'::regclass);"""
 
54
 
 
55
        sql += """CREATE SEQUENCE volumes_id_seq START WITH 1 INCREMENT BY 1
 
56
               NO MINVALUE NO MAXVALUE CACHE 1;
 
57
               ALTER SEQUENCE volumes_id_seq OWNED BY volumes.id;
 
58
               SELECT pg_catalog.setval('volumes_id_seq', 1, false);
 
59
               ALTER TABLE ONLY volumes ALTER COLUMN id SET DEFAULT
 
60
               nextval('volumes_id_seq'::regclass);"""
 
61
        migrate_engine.execute(sql)