Merge "Correct db and model inconsistent"
This commit is contained in:
commit
98b7894d64
@ -39,9 +39,11 @@ def upgrade():
|
||||
sa.Column('resources', sa.Text(), nullable=True),
|
||||
sa.Column('resource_traits', sa.Text(), nullable=True),
|
||||
sa.Column('resource_aggregates', sa.Text(), nullable=True),
|
||||
sa.Column('is_public', sa.Boolean(), nullable=False),
|
||||
sa.Column('disabled', sa.Boolean(), nullable=False),
|
||||
sa.Column('is_public', sa.Boolean(), nullable=True),
|
||||
sa.Column('disabled', sa.Boolean(), nullable=True),
|
||||
sa.PrimaryKeyConstraint('id'),
|
||||
sa.UniqueConstraint('uuid', name='uniq_flavors0uuid'),
|
||||
sa.UniqueConstraint('name', name='uniq_flavors0name'),
|
||||
mysql_ENGINE='InnoDB',
|
||||
mysql_DEFAULT_CHARSET='UTF8'
|
||||
)
|
||||
@ -55,6 +57,8 @@ def upgrade():
|
||||
sa.ForeignKeyConstraint(['flavor_id'],
|
||||
['flavors.id']),
|
||||
sa.PrimaryKeyConstraint('id'),
|
||||
sa.UniqueConstraint('flavor_id', 'project_id',
|
||||
name='uniq_flavor_projects0flavor_id0project_id'),
|
||||
mysql_ENGINE='InnoDB',
|
||||
mysql_DEFAULT_CHARSET='UTF8'
|
||||
)
|
||||
@ -62,11 +66,11 @@ def upgrade():
|
||||
'servers',
|
||||
sa.Column('created_at', sa.DateTime(), nullable=True),
|
||||
sa.Column('updated_at', sa.DateTime(), nullable=True),
|
||||
sa.Column('uuid', sa.String(length=36), nullable=True),
|
||||
sa.Column('uuid', sa.String(length=36), nullable=False),
|
||||
sa.Column('id', sa.Integer(), nullable=False),
|
||||
sa.Column('user_id', sa.String(length=36), nullable=True),
|
||||
sa.Column('project_id', sa.String(length=36), nullable=True),
|
||||
sa.Column('name', sa.String(length=255), nullable=True),
|
||||
sa.Column('name', sa.String(length=255), nullable=False),
|
||||
sa.Column('description', sa.String(length=255), nullable=True),
|
||||
sa.Column('status', sa.String(length=255), nullable=True),
|
||||
sa.Column('power_state', sa.String(length=15), nullable=True),
|
||||
@ -83,28 +87,26 @@ def upgrade():
|
||||
sa.Column('key_name', sa.String(length=255), nullable=True),
|
||||
sa.PrimaryKeyConstraint('id'),
|
||||
sa.UniqueConstraint('uuid', name='uniq_servers0uuid'),
|
||||
sa.Index('servers_project_id_idx', 'project_id'),
|
||||
mysql_ENGINE='InnoDB',
|
||||
mysql_DEFAULT_CHARSET='UTF8'
|
||||
)
|
||||
op.create_index('servers_project_id_idx', 'servers', ['project_id'],
|
||||
unique=False)
|
||||
op.create_table(
|
||||
'server_nics',
|
||||
sa.Column('created_at', sa.DateTime(), nullable=True),
|
||||
sa.Column('updated_at', sa.DateTime(), nullable=True),
|
||||
sa.Column('server_uuid', sa.String(length=36), nullable=False),
|
||||
sa.Column('server_uuid', sa.String(length=36),
|
||||
sa.ForeignKey('servers.uuid'), nullable=True),
|
||||
sa.Column('port_id', sa.String(length=36), nullable=False),
|
||||
sa.Column('mac_address', sa.String(length=36), nullable=True),
|
||||
sa.Column('mac_address', sa.String(length=36), nullable=False),
|
||||
sa.Column('network_id', sa.String(length=36), nullable=True),
|
||||
sa.Column('floating_ip', sa.String(length=64), nullable=True),
|
||||
sa.Column('fixed_ips', sa.Text(), nullable=True),
|
||||
sa.ForeignKeyConstraint(['server_uuid'], ['servers.uuid'], ),
|
||||
sa.PrimaryKeyConstraint('port_id'),
|
||||
sa.Index('server_nics_server_uuid_idx', 'server_uuid'),
|
||||
mysql_ENGINE='InnoDB',
|
||||
mysql_DEFAULT_CHARSET='UTF8'
|
||||
)
|
||||
op.create_index('server_nics_server_uuid_idx', 'server_nics',
|
||||
['server_uuid'], unique=False)
|
||||
op.create_table(
|
||||
'server_faults',
|
||||
sa.Column('id', sa.Integer(), nullable=False),
|
||||
@ -116,18 +118,17 @@ def upgrade():
|
||||
sa.Column('detail', sa.Text(), nullable=True),
|
||||
sa.ForeignKeyConstraint(['server_uuid'], ['servers.uuid']),
|
||||
sa.PrimaryKeyConstraint('id'),
|
||||
sa.Index('server_faults_server_uuid_idx', 'server_uuid'),
|
||||
mysql_ENGINE='InnoDB',
|
||||
mysql_DEFAULT_CHARSET='UTF8'
|
||||
)
|
||||
op.create_index('server_faults_server_uuid_idx', 'server_faults',
|
||||
['server_uuid'], unique=False)
|
||||
op.create_table(
|
||||
'quotas',
|
||||
sa.Column('created_at', sa.DateTime(), nullable=True),
|
||||
sa.Column('updated_at', sa.DateTime(), nullable=True),
|
||||
sa.Column('id', sa.Integer(), nullable=False),
|
||||
sa.Column('project_id', sa.String(length=36), nullable=True),
|
||||
sa.Column('resource_name', sa.String(length=255), nullable=True),
|
||||
sa.Column('project_id', sa.String(length=36), nullable=False),
|
||||
sa.Column('resource_name', sa.String(length=255), nullable=False),
|
||||
sa.Column('hard_limit', sa.Integer(), nullable=True),
|
||||
sa.Column('allocated', sa.Integer(), nullable=True),
|
||||
sa.PrimaryKeyConstraint('id'),
|
||||
@ -148,43 +149,41 @@ def upgrade():
|
||||
sa.Column('until_refresh', sa.Integer(), nullable=True),
|
||||
sa.PrimaryKeyConstraint('id'),
|
||||
sa.UniqueConstraint('resource_name', 'project_id',
|
||||
name='uniq_quotas_usages0resource_name'),
|
||||
name='uniq_quota_usages0resource_name'),
|
||||
sa.Index('quota_usage_project_id_idx', 'project_id'),
|
||||
mysql_ENGINE='InnoDB',
|
||||
mysql_DEFAULT_CHARSET='UTF8'
|
||||
)
|
||||
op.create_index('quota_usage_project_id_idx', 'quota_usages',
|
||||
['project_id'], unique=False)
|
||||
op.create_table(
|
||||
'reservations',
|
||||
sa.Column('created_at', sa.DateTime(), nullable=True),
|
||||
sa.Column('updated_at', sa.DateTime(), nullable=True),
|
||||
sa.Column('id', sa.Integer(), nullable=False),
|
||||
sa.Column('uuid', sa.String(length=36), nullable=True),
|
||||
sa.Column('uuid', sa.String(length=36), nullable=False),
|
||||
sa.Column('usage_id', sa.Integer(), nullable=True),
|
||||
sa.Column('allocated_id', sa.Integer(), nullable=True),
|
||||
sa.Column('project_id', sa.String(length=36), nullable=True),
|
||||
sa.Column('resource_name', sa.String(length=255), nullable=True),
|
||||
sa.Column('delta', sa.Integer(), nullable=True),
|
||||
sa.Column('expire', sa.DateTime(), nullable=True),
|
||||
sa.Column('expire', sa.DateTime(), nullable=False),
|
||||
sa.ForeignKeyConstraint(['usage_id'],
|
||||
['quota_usages.id']),
|
||||
sa.ForeignKeyConstraint(['allocated_id'],
|
||||
['quotas.id']),
|
||||
sa.PrimaryKeyConstraint('id'),
|
||||
sa.Index('reservations_project_id_idx', 'project_id'),
|
||||
sa.UniqueConstraint('uuid', name='uniq_reservation0uuid'),
|
||||
mysql_ENGINE='InnoDB',
|
||||
mysql_DEFAULT_CHARSET='UTF8'
|
||||
)
|
||||
op.create_index('reservations_project_id_idx', 'reservations',
|
||||
['project_id'], unique=False)
|
||||
op.create_table(
|
||||
'key_pairs',
|
||||
sa.Column('created_at', sa.DateTime(), nullable=True),
|
||||
sa.Column('updated_at', sa.DateTime(), nullable=True),
|
||||
sa.Column('id', sa.Integer(), primary_key=True, nullable=False),
|
||||
sa.Column('name', sa.String(length=255), nullable=False),
|
||||
sa.Column('user_id', sa.String(length=255), nullable=True),
|
||||
sa.Column('project_id', sa.String(length=36), nullable=True),
|
||||
sa.Column('user_id', sa.String(length=255), nullable=False),
|
||||
sa.Column('project_id', sa.String(length=36), nullable=False),
|
||||
sa.Column('fingerprint', sa.String(255)),
|
||||
sa.Column('public_key', sa.Text()),
|
||||
sa.Column('type', sa.Enum('ssh', 'x509'), nullable=False,
|
||||
@ -216,18 +215,18 @@ def upgrade():
|
||||
sa.PrimaryKeyConstraint('id'),
|
||||
sa.ForeignKeyConstraint(['aggregate_id'],
|
||||
['aggregates.id']),
|
||||
sa.UniqueConstraint('aggregate_id', 'key',
|
||||
name='uniq_aggregate_metadata0aggregate_id0key'),
|
||||
sa.Index('aggregate_metadata_key_idx', 'key'),
|
||||
mysql_ENGINE='InnoDB',
|
||||
mysql_DEFAULT_CHARSET='UTF8'
|
||||
)
|
||||
op.create_index('aggregate_metadata_key_idx', 'aggregate_metadata',
|
||||
['key'], unique=False)
|
||||
|
||||
op.create_table(
|
||||
'server_groups',
|
||||
sa.Column('created_at', sa.DateTime(), nullable=True),
|
||||
sa.Column('updated_at', sa.DateTime(), nullable=True),
|
||||
sa.Column('id', sa.Integer(), primary_key=True, nullable=False),
|
||||
sa.Column('uuid', sa.String(length=36), nullable=True),
|
||||
sa.Column('uuid', sa.String(length=36), nullable=False),
|
||||
sa.Column('name', sa.String(length=255), nullable=False),
|
||||
sa.Column('user_id', sa.String(length=255), nullable=True),
|
||||
sa.Column('project_id', sa.String(length=255), nullable=True),
|
||||
@ -242,7 +241,8 @@ def upgrade():
|
||||
sa.Column('updated_at', sa.DateTime(), nullable=True),
|
||||
sa.Column('id', sa.Integer(), primary_key=True, nullable=False),
|
||||
sa.Column('policy', sa.String(length=36), nullable=True),
|
||||
sa.Column('group_id', sa.String(length=255), nullable=False),
|
||||
sa.Column('group_id', sa.Integer, sa.ForeignKey('server_groups.id'),
|
||||
nullable=False),
|
||||
sa.Index('server_group_policy_policy_idx', 'policy'),
|
||||
sa.PrimaryKeyConstraint('id'),
|
||||
mysql_engine='InnoDB',
|
||||
|
@ -1042,14 +1042,13 @@ class Connection(api.Connection):
|
||||
group = query.first()
|
||||
if not group:
|
||||
raise exception.ServerGroupNotFound(group_uuid=group_uuid)
|
||||
group_id = group.id
|
||||
with _session_for_write():
|
||||
query.delete()
|
||||
# Delete policies and members
|
||||
instance_models = [models.ServerGroupPolicy,
|
||||
models.ServerGroupMember]
|
||||
for model in instance_models:
|
||||
model_query(context, model).filter_by(group_id=group_id).delete()
|
||||
model_query(context, model).filter_by(group_id=group.id).delete()
|
||||
with _session_for_write():
|
||||
query.delete()
|
||||
|
||||
def server_group_get_all(self, context, project_id=None):
|
||||
"""Get all groups."""
|
||||
|
@ -103,7 +103,8 @@ class ServerNic(Base):
|
||||
Index('server_nics_server_uuid_idx', 'server_uuid'),
|
||||
table_args()
|
||||
)
|
||||
server_uuid = Column(String(36), ForeignKey('servers.uuid'))
|
||||
server_uuid = Column(String(36), ForeignKey('servers.uuid'),
|
||||
nullable=True)
|
||||
port_id = Column(String(36), primary_key=True)
|
||||
mac_address = Column(String(32), nullable=False)
|
||||
network_id = Column(String(36), nullable=True)
|
||||
@ -175,7 +176,7 @@ class FlavorProjects(Base):
|
||||
)
|
||||
id = Column(Integer, primary_key=True)
|
||||
flavor_id = Column(Integer, ForeignKey('flavors.id'),
|
||||
nullable=True)
|
||||
nullable=False)
|
||||
project_id = Column(String(36), nullable=True)
|
||||
flavors = orm.relationship(
|
||||
Flavors,
|
||||
@ -207,13 +208,13 @@ class QuotaUsage(Base):
|
||||
__tablename__ = 'quota_usages'
|
||||
__table_args__ = (
|
||||
schema.UniqueConstraint('resource_name', 'project_id',
|
||||
name='uniq_quotas0resource_name'),
|
||||
name='uniq_quota_usages0resource_name'),
|
||||
Index('quota_usage_project_id_idx', 'project_id'),
|
||||
table_args()
|
||||
)
|
||||
|
||||
id = Column(Integer, primary_key=True)
|
||||
project_id = Column(String(255), index=True)
|
||||
project_id = Column(String(255))
|
||||
resource_name = Column(String(255))
|
||||
in_use = Column(Integer)
|
||||
reserved = Column(Integer)
|
||||
@ -238,7 +239,7 @@ class Reservation(Base):
|
||||
uuid = Column(String(36), nullable=False)
|
||||
usage_id = Column(Integer, ForeignKey('quota_usages.id'), nullable=True)
|
||||
allocated_id = Column(Integer, ForeignKey('quotas.id'), nullable=True)
|
||||
project_id = Column(String(255), index=True)
|
||||
project_id = Column(String(255))
|
||||
resource_name = Column(String(255))
|
||||
delta = Column(Integer)
|
||||
expire = Column(DateTime, nullable=False)
|
||||
@ -295,7 +296,6 @@ class Aggregate(Base):
|
||||
|
||||
__tablename__ = 'aggregates'
|
||||
__table_args__ = (
|
||||
Index('aggregate_uuid_idx', 'uuid'),
|
||||
table_args()
|
||||
)
|
||||
id = Column(Integer, primary_key=True)
|
||||
@ -356,7 +356,7 @@ class ServerGroup(Base):
|
||||
user_id = Column(String(255))
|
||||
project_id = Column(String(255))
|
||||
uuid = Column(String(36), nullable=False)
|
||||
name = Column(String(255))
|
||||
name = Column(String(255), nullable=False)
|
||||
_policies = orm.relationship(
|
||||
ServerGroupPolicy,
|
||||
primaryjoin='ServerGroup.id == ServerGroupPolicy.group_id')
|
||||
|
@ -21,6 +21,7 @@ from mogan.db import api as db_api
|
||||
|
||||
|
||||
def get_test_server(**kw):
|
||||
server_uuid = uuidutils.generate_uuid()
|
||||
fake_server_nics = [{
|
||||
'port_id': uuidutils.generate_uuid(),
|
||||
'network_id': 'bf942f63-c284-4eb8-925b-c2fa1a89ed33',
|
||||
@ -40,7 +41,7 @@ def get_test_server(**kw):
|
||||
|
||||
return {
|
||||
'id': kw.get('id', 123),
|
||||
'uuid': kw.get('uuid', uuidutils.generate_uuid()),
|
||||
'uuid': kw.get('uuid', server_uuid),
|
||||
'name': kw.get('name', 'test'),
|
||||
'description': kw.get('description', 'test'),
|
||||
'project_id': kw.get('project_id',
|
||||
|
Loading…
Reference in New Issue
Block a user