1
# Copyright 2013 OpenStack Foundation
3
# Licensed under the Apache License, Version 2.0 (the "License"); you may
4
# not use this file except in compliance with the License. You may obtain
5
# a copy of the License at
7
# http://www.apache.org/licenses/LICENSE-2.0
9
# Unless required by applicable law or agreed to in writing, software
10
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12
# License for the specific language governing permissions and limitations
18
Revision ID: 45680af419f9
20
Create Date: 2013-02-17 13:27:57.999631
24
# revision identifiers, used by Alembic.
25
revision = '45680af419f9'
26
down_revision = '54c2c487e913'
28
# Change to ['*'] if this migration applies to all plugins
30
migration_for_plugins = [
31
'neutron.plugins.nicira.NeutronPlugin.NvpPluginV2',
32
'neutron.plugins.nicira.NeutronServicePlugin.NvpAdvancedPlugin',
33
'neutron.plugins.vmware.plugin.NsxPlugin',
34
'neutron.plugins.vmware.plugin.NsxServicePlugin'
37
from alembic import op
38
import sqlalchemy as sa
41
from neutron.db import migration
43
qosqueues_qos_marking = sa.Enum('untrusted', 'trusted',
44
name='qosqueues_qos_marking')
47
def upgrade(active_plugins=None, options=None):
48
if not migration.should_run(active_plugins, migration_for_plugins):
51
### commands auto generated by Alembic - please adjust! ###
54
sa.Column('tenant_id', sa.String(length=255), nullable=True),
55
sa.Column('id', sa.String(length=36), nullable=False),
56
sa.Column('name', sa.String(length=255), nullable=True),
57
sa.Column('default', sa.Boolean(), nullable=True),
58
sa.Column('min', sa.Integer(), nullable=False),
59
sa.Column('max', sa.Integer(), nullable=True),
60
sa.Column('qos_marking', qosqueues_qos_marking, nullable=True),
61
sa.Column('dscp', sa.Integer(), nullable=True),
62
sa.PrimaryKeyConstraint('id')
65
'networkqueuemappings',
66
sa.Column('network_id', sa.String(length=36), nullable=False),
67
sa.Column('queue_id', sa.String(length=36), nullable=True),
68
sa.ForeignKeyConstraint(['network_id'], ['networks.id'],
70
sa.ForeignKeyConstraint(['queue_id'], ['qosqueues.id'],
72
sa.PrimaryKeyConstraint('network_id')
76
sa.Column('port_id', sa.String(length=36), nullable=False),
77
sa.Column('queue_id', sa.String(length=36), nullable=False),
78
sa.ForeignKeyConstraint(['port_id'], ['ports.id'], ondelete='CASCADE'),
79
sa.ForeignKeyConstraint(['queue_id'], ['qosqueues.id'], ),
80
sa.PrimaryKeyConstraint('port_id', 'queue_id')
82
### end Alembic commands ###
85
def downgrade(active_plugins=None, options=None):
86
if not migration.should_run(active_plugins, migration_for_plugins):
89
### commands auto generated by Alembic - please adjust! ###
90
op.drop_table('portqueuemappings')
91
op.drop_table('networkqueuemappings')
92
op.drop_table('qosqueues')
93
qosqueues_qos_marking.drop(op.get_bind(), checkfirst=False)
94
### end Alembic commands ###