1
# vim: tabstop=4 shiftwidth=4 softtabstop=4
3
# Copyright 2012 OpenStack LLC.
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
10
# http://www.apache.org/licenses/LICENSE-2.0
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
18
from sqlalchemy import Index, MetaData, Table
19
from sqlalchemy.exc import IntegrityError
22
def upgrade(migrate_engine):
24
meta.bind = migrate_engine
26
t = Table('iscsi_targets', meta, autoload=True)
28
# Based on iscsi_target_count_by_host
29
# from: nova/db/sqlalchemy/api.py
30
i = Index('iscsi_targets_host_idx', t.c.host)
32
i.create(migrate_engine)
33
except IntegrityError:
36
# Based on volume_allocate_iscsi_target
37
# from: nova/db/sqlalchemy/api.py
38
i = Index('iscsi_targets_host_volume_id_deleted_idx',
39
t.c.host, t.c.volume_id, t.c.deleted)
41
i.create(migrate_engine)
42
except IntegrityError:
46
def downgrade(migrate_engine):
48
meta.bind = migrate_engine
50
t = Table('iscsi_targets', meta, autoload=True)
52
i = Index('iscsi_targets_host_idx', t.c.host)
53
i.drop(migrate_engine)
55
i = Index('iscsi_targets_host_volume_id_deleted_idx',
56
t.c.host, t.c.volume_id, t.c.deleted)
57
i.drop(migrate_engine)