Device refactor Part1: Rename device db name
This patch changes the table name into single format. Later we will change all the table names into single format in tacker. Next patches will refactor plugin codes. Change-Id: I7052bc7557998b087f8e32a5d6823feaa55d5e40 Partial-bug: #1589018
This commit is contained in:
parent
fe273366d5
commit
282a099e23
@ -72,3 +72,24 @@ def modify_foreign_keys_constraint(table_names):
|
|||||||
for table in table_names:
|
for table in table_names:
|
||||||
fk_constraints = inspector.get_foreign_keys(table)
|
fk_constraints = inspector.get_foreign_keys(table)
|
||||||
create_foreign_key_constraint(table, fk_constraints)
|
create_foreign_key_constraint(table, fk_constraints)
|
||||||
|
|
||||||
|
|
||||||
|
def modify_foreign_keys_constraint_with_col_change(
|
||||||
|
table_name, old_local_col, new_local_col, existing_type,
|
||||||
|
nullable=False):
|
||||||
|
inspector = reflection.Inspector.from_engine(op.get_bind())
|
||||||
|
fk_constraints = inspector.get_foreign_keys(table_name)
|
||||||
|
for fk in fk_constraints:
|
||||||
|
if old_local_col in fk['constrained_columns']:
|
||||||
|
drop_foreign_key_constraint(table_name, [fk])
|
||||||
|
op.alter_column(table_name, old_local_col,
|
||||||
|
new_column_name=new_local_col,
|
||||||
|
existing_type=existing_type,
|
||||||
|
nullable=nullable)
|
||||||
|
fk_constraints = inspector.get_foreign_keys(table_name)
|
||||||
|
for fk in fk_constraints:
|
||||||
|
for i in range(len(fk['constrained_columns'])):
|
||||||
|
if old_local_col == fk['constrained_columns'][i]:
|
||||||
|
fk['constrained_columns'][i] = new_local_col
|
||||||
|
create_foreign_key_constraint(table_name, [fk])
|
||||||
|
break
|
||||||
|
@ -0,0 +1,52 @@
|
|||||||
|
# Copyright 2016 OpenStack Foundation
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
#
|
||||||
|
|
||||||
|
"""rename device db tables
|
||||||
|
|
||||||
|
Revision ID: 22f5385a3d50
|
||||||
|
Revises: 22f5385a3d4f
|
||||||
|
Create Date: 2016-08-01 15:47:51.161749
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
# revision identifiers, used by Alembic.
|
||||||
|
revision = '22f5385a3d50'
|
||||||
|
down_revision = '22f5385a3d4f'
|
||||||
|
|
||||||
|
from alembic import op
|
||||||
|
import sqlalchemy as sa
|
||||||
|
|
||||||
|
from tacker.db import migration
|
||||||
|
|
||||||
|
|
||||||
|
def upgrade(active_plugins=None, options=None):
|
||||||
|
# commands auto generated by Alembic - please adjust! #
|
||||||
|
op.rename_table('devicetemplates', 'vnfd')
|
||||||
|
op.rename_table('devicetemplateattributes', 'vnfd_attribute')
|
||||||
|
op.rename_table('devices', 'vnf')
|
||||||
|
op.rename_table('deviceattributes', 'vnf_attribute')
|
||||||
|
migration.modify_foreign_keys_constraint_with_col_change(
|
||||||
|
'vnfd_attribute', 'template_id', 'vnfd_id',
|
||||||
|
sa.String(length=36))
|
||||||
|
migration.modify_foreign_keys_constraint_with_col_change(
|
||||||
|
'servicetypes', 'template_id', 'vnfd_id',
|
||||||
|
sa.String(length=36))
|
||||||
|
migration.modify_foreign_keys_constraint_with_col_change(
|
||||||
|
'vnf', 'template_id', 'vnfd_id',
|
||||||
|
sa.String(length=36))
|
||||||
|
migration.modify_foreign_keys_constraint_with_col_change(
|
||||||
|
'vnf_attribute', 'device_id', 'vnf_id',
|
||||||
|
sa.String(length=36))
|
||||||
|
# end Alembic commands #
|
@ -1 +1 @@
|
|||||||
22f5385a3d4f
|
22f5385a3d50
|
||||||
|
@ -131,7 +131,7 @@ class NfvoPluginDb(nfvo.NFVOPluginBase, db_base.CommonDbMixin):
|
|||||||
|
|
||||||
def is_vim_still_in_use(self, context, vim_id):
|
def is_vim_still_in_use(self, context, vim_id):
|
||||||
with context.session.begin(subtransactions=True):
|
with context.session.begin(subtransactions=True):
|
||||||
devices_db = context.session.query(vm_db.Device).filter_by(
|
devices_db = context.session.query(vm_db.VNF).filter_by(
|
||||||
vim_id=vim_id).first()
|
vim_id=vim_id).first()
|
||||||
if devices_db is not None:
|
if devices_db is not None:
|
||||||
raise nfvo.VimInUseException(vim_id=vim_id)
|
raise nfvo.VimInUseException(vim_id=vim_id)
|
||||||
|
@ -42,9 +42,10 @@ CREATE_STATES = (constants.PENDING_CREATE, constants.DEAD)
|
|||||||
###########################################################################
|
###########################################################################
|
||||||
# db tables
|
# db tables
|
||||||
|
|
||||||
class DeviceTemplate(model_base.BASE, models_v1.HasId, models_v1.HasTenant):
|
class VNFD(model_base.BASE, models_v1.HasId, models_v1.HasTenant):
|
||||||
"""Represents template to create hosting device."""
|
"""Represents VNFD to create VNF."""
|
||||||
|
|
||||||
|
__tablename__ = 'vnfd'
|
||||||
# Descriptive name
|
# Descriptive name
|
||||||
name = sa.Column(sa.String(255), nullable=False)
|
name = sa.Column(sa.String(255), nullable=False)
|
||||||
description = sa.Column(sa.Text)
|
description = sa.Column(sa.Text)
|
||||||
@ -61,7 +62,7 @@ class DeviceTemplate(model_base.BASE, models_v1.HasId, models_v1.HasTenant):
|
|||||||
mgmt_driver = sa.Column(sa.String(255))
|
mgmt_driver = sa.Column(sa.String(255))
|
||||||
|
|
||||||
# (key, value) pair to spin up
|
# (key, value) pair to spin up
|
||||||
attributes = orm.relationship('DeviceTemplateAttribute',
|
attributes = orm.relationship('VNFDAttribute',
|
||||||
backref='template')
|
backref='template')
|
||||||
|
|
||||||
|
|
||||||
@ -71,32 +72,36 @@ class ServiceType(model_base.BASE, models_v1.HasId, models_v1.HasTenant):
|
|||||||
Since a device may provide many services, This is one-to-many
|
Since a device may provide many services, This is one-to-many
|
||||||
relationship.
|
relationship.
|
||||||
"""
|
"""
|
||||||
template_id = sa.Column(types.Uuid, sa.ForeignKey('devicetemplates.id'),
|
vnfd_id = sa.Column(types.Uuid, sa.ForeignKey('vnfd.id'),
|
||||||
nullable=False)
|
nullable=False)
|
||||||
service_type = sa.Column(sa.String(64), nullable=False)
|
service_type = sa.Column(sa.String(64), nullable=False)
|
||||||
|
|
||||||
|
|
||||||
class DeviceTemplateAttribute(model_base.BASE, models_v1.HasId):
|
class VNFDAttribute(model_base.BASE, models_v1.HasId):
|
||||||
"""Represents attributes necessary for spinning up VM in (key, value) pair
|
"""Represents attributes necessary for spinning up VM in (key, value) pair
|
||||||
|
|
||||||
key value pair is adopted for being agnostic to actuall manager of VMs
|
key value pair is adopted for being agnostic to actuall manager of VMs
|
||||||
like nova, heat or others. e.g. image-id, flavor-id for Nova.
|
like nova, heat or others. e.g. image-id, flavor-id for Nova.
|
||||||
The interpretation is up to actual driver of hosting device.
|
The interpretation is up to actual driver of hosting device.
|
||||||
"""
|
"""
|
||||||
template_id = sa.Column(types.Uuid, sa.ForeignKey('devicetemplates.id'),
|
|
||||||
|
__tablename__ = 'vnfd_attribute'
|
||||||
|
vnfd_id = sa.Column(types.Uuid, sa.ForeignKey('vnfd.id'),
|
||||||
nullable=False)
|
nullable=False)
|
||||||
key = sa.Column(sa.String(255), nullable=False)
|
key = sa.Column(sa.String(255), nullable=False)
|
||||||
value = sa.Column(sa.TEXT(65535), nullable=True)
|
value = sa.Column(sa.TEXT(65535), nullable=True)
|
||||||
|
|
||||||
|
|
||||||
class Device(model_base.BASE, models_v1.HasId, models_v1.HasTenant):
|
class VNF(model_base.BASE, models_v1.HasId, models_v1.HasTenant):
|
||||||
"""Represents devices that hosts services.
|
"""Represents devices that hosts services.
|
||||||
|
|
||||||
Here the term, 'VM', is intentionally avoided because it can be
|
Here the term, 'VM', is intentionally avoided because it can be
|
||||||
VM or other container.
|
VM or other container.
|
||||||
"""
|
"""
|
||||||
template_id = sa.Column(types.Uuid, sa.ForeignKey('devicetemplates.id'))
|
|
||||||
template = orm.relationship('DeviceTemplate')
|
__tablename__ = 'vnf'
|
||||||
|
vnfd_id = sa.Column(types.Uuid, sa.ForeignKey('vnfd.id'))
|
||||||
|
vnfd = orm.relationship('VNFD')
|
||||||
|
|
||||||
name = sa.Column(sa.String(255), nullable=False)
|
name = sa.Column(sa.String(255), nullable=False)
|
||||||
description = sa.Column(sa.Text, nullable=True)
|
description = sa.Column(sa.Text, nullable=True)
|
||||||
@ -109,7 +114,7 @@ class Device(model_base.BASE, models_v1.HasId, models_v1.HasTenant):
|
|||||||
# opaque string.
|
# opaque string.
|
||||||
# e.g. (driver, mgmt_url) = (ssh, ip address), ...
|
# e.g. (driver, mgmt_url) = (ssh, ip address), ...
|
||||||
mgmt_url = sa.Column(sa.String(255), nullable=True)
|
mgmt_url = sa.Column(sa.String(255), nullable=True)
|
||||||
attributes = orm.relationship("DeviceAttribute", backref="device")
|
attributes = orm.relationship("VNFAttribute", backref="device")
|
||||||
|
|
||||||
status = sa.Column(sa.String(64), nullable=False)
|
status = sa.Column(sa.String(64), nullable=False)
|
||||||
vim_id = sa.Column(types.Uuid, sa.ForeignKey('vims.id'), nullable=False)
|
vim_id = sa.Column(types.Uuid, sa.ForeignKey('vims.id'), nullable=False)
|
||||||
@ -118,14 +123,16 @@ class Device(model_base.BASE, models_v1.HasId, models_v1.HasTenant):
|
|||||||
error_reason = sa.Column(sa.Text, nullable=True)
|
error_reason = sa.Column(sa.Text, nullable=True)
|
||||||
|
|
||||||
|
|
||||||
class DeviceAttribute(model_base.BASE, models_v1.HasId):
|
class VNFAttribute(model_base.BASE, models_v1.HasId):
|
||||||
"""Represents kwargs necessary for spinning up VM in (key, value) pair.
|
"""Represents kwargs necessary for spinning up VM in (key, value) pair.
|
||||||
|
|
||||||
key value pair is adopted for being agnostic to actuall manager of VMs
|
key value pair is adopted for being agnostic to actuall manager of VMs
|
||||||
like nova, heat or others. e.g. image-id, flavor-id for Nova.
|
like nova, heat or others. e.g. image-id, flavor-id for Nova.
|
||||||
The interpretation is up to actual driver of hosting device.
|
The interpretation is up to actual driver of hosting device.
|
||||||
"""
|
"""
|
||||||
device_id = sa.Column(types.Uuid, sa.ForeignKey('devices.id'),
|
|
||||||
|
__tablename__ = 'vnf_attribute'
|
||||||
|
vnf_id = sa.Column(types.Uuid, sa.ForeignKey('vnf.id'),
|
||||||
nullable=False)
|
nullable=False)
|
||||||
key = sa.Column(sa.String(255), nullable=False)
|
key = sa.Column(sa.String(255), nullable=False)
|
||||||
# json encoded value. example
|
# json encoded value. example
|
||||||
@ -150,11 +157,11 @@ class VNFMPluginDb(vnfm.VNFMPluginBase, db_base.CommonDbMixin):
|
|||||||
try:
|
try:
|
||||||
return self._get_by_id(context, model, id)
|
return self._get_by_id(context, model, id)
|
||||||
except orm_exc.NoResultFound:
|
except orm_exc.NoResultFound:
|
||||||
if issubclass(model, DeviceTemplate):
|
if issubclass(model, VNFD):
|
||||||
raise vnfm.DeviceTemplateNotFound(device_template_id=id)
|
raise vnfm.DeviceTemplateNotFound(device_template_id=id)
|
||||||
elif issubclass(model, ServiceType):
|
elif issubclass(model, ServiceType):
|
||||||
raise vnfm.ServiceTypeNotFound(service_type_id=id)
|
raise vnfm.ServiceTypeNotFound(service_type_id=id)
|
||||||
if issubclass(model, Device):
|
if issubclass(model, VNF):
|
||||||
raise vnfm.DeviceNotFound(device_id=id)
|
raise vnfm.DeviceNotFound(device_id=id)
|
||||||
else:
|
else:
|
||||||
raise
|
raise
|
||||||
@ -186,11 +193,11 @@ class VNFMPluginDb(vnfm.VNFMPluginBase, db_base.CommonDbMixin):
|
|||||||
LOG.debug(_('device_db attributes %s'), device_db.attributes)
|
LOG.debug(_('device_db attributes %s'), device_db.attributes)
|
||||||
res = {
|
res = {
|
||||||
'device_template':
|
'device_template':
|
||||||
self._make_template_dict(device_db.template),
|
self._make_template_dict(device_db.vnfd),
|
||||||
'attributes': self._make_dev_attrs_dict(device_db.attributes),
|
'attributes': self._make_dev_attrs_dict(device_db.attributes),
|
||||||
}
|
}
|
||||||
key_list = ('id', 'tenant_id', 'name', 'description', 'instance_id',
|
key_list = ('id', 'tenant_id', 'name', 'description', 'instance_id',
|
||||||
'vim_id', 'placement_attr', 'template_id', 'status',
|
'vim_id', 'placement_attr', 'vnfd_id', 'status',
|
||||||
'mgmt_url', 'error_reason')
|
'mgmt_url', 'error_reason')
|
||||||
res.update((key, device_db[key]) for key in key_list)
|
res.update((key, device_db[key]) for key in key_list)
|
||||||
return self._fields(res, fields)
|
return self._fields(res, fields)
|
||||||
@ -227,7 +234,7 @@ class VNFMPluginDb(vnfm.VNFMPluginBase, db_base.CommonDbMixin):
|
|||||||
|
|
||||||
with context.session.begin(subtransactions=True):
|
with context.session.begin(subtransactions=True):
|
||||||
template_id = str(uuid.uuid4())
|
template_id = str(uuid.uuid4())
|
||||||
template_db = DeviceTemplate(
|
template_db = VNFD(
|
||||||
id=template_id,
|
id=template_id,
|
||||||
tenant_id=tenant_id,
|
tenant_id=tenant_id,
|
||||||
name=template.get('name'),
|
name=template.get('name'),
|
||||||
@ -236,9 +243,9 @@ class VNFMPluginDb(vnfm.VNFMPluginBase, db_base.CommonDbMixin):
|
|||||||
mgmt_driver=mgmt_driver)
|
mgmt_driver=mgmt_driver)
|
||||||
context.session.add(template_db)
|
context.session.add(template_db)
|
||||||
for (key, value) in template.get('attributes', {}).items():
|
for (key, value) in template.get('attributes', {}).items():
|
||||||
attribute_db = DeviceTemplateAttribute(
|
attribute_db = VNFDAttribute(
|
||||||
id=str(uuid.uuid4()),
|
id=str(uuid.uuid4()),
|
||||||
template_id=template_id,
|
vnfd_id=template_id,
|
||||||
key=key,
|
key=key,
|
||||||
value=value)
|
value=value)
|
||||||
context.session.add(attribute_db)
|
context.session.add(attribute_db)
|
||||||
@ -247,7 +254,7 @@ class VNFMPluginDb(vnfm.VNFMPluginBase, db_base.CommonDbMixin):
|
|||||||
service_type_db = ServiceType(
|
service_type_db = ServiceType(
|
||||||
id=str(uuid.uuid4()),
|
id=str(uuid.uuid4()),
|
||||||
tenant_id=tenant_id,
|
tenant_id=tenant_id,
|
||||||
template_id=template_id,
|
vnfd_id=template_id,
|
||||||
service_type=service_type)
|
service_type=service_type)
|
||||||
context.session.add(service_type_db)
|
context.session.add(service_type_db)
|
||||||
|
|
||||||
@ -259,7 +266,7 @@ class VNFMPluginDb(vnfm.VNFMPluginBase, db_base.CommonDbMixin):
|
|||||||
def update_device_template(self, context, device_template_id,
|
def update_device_template(self, context, device_template_id,
|
||||||
device_template):
|
device_template):
|
||||||
with context.session.begin(subtransactions=True):
|
with context.session.begin(subtransactions=True):
|
||||||
template_db = self._get_resource(context, DeviceTemplate,
|
template_db = self._get_resource(context, VNFD,
|
||||||
device_template_id)
|
device_template_id)
|
||||||
template_db.update(device_template['device_template'])
|
template_db.update(device_template['device_template'])
|
||||||
return self._make_template_dict(template_db)
|
return self._make_template_dict(template_db)
|
||||||
@ -268,27 +275,27 @@ class VNFMPluginDb(vnfm.VNFMPluginBase, db_base.CommonDbMixin):
|
|||||||
with context.session.begin(subtransactions=True):
|
with context.session.begin(subtransactions=True):
|
||||||
# TODO(yamahata): race. prevent from newly inserting hosting device
|
# TODO(yamahata): race. prevent from newly inserting hosting device
|
||||||
# that refers to this template
|
# that refers to this template
|
||||||
devices_db = context.session.query(Device).filter_by(
|
devices_db = context.session.query(VNF).filter_by(
|
||||||
template_id=device_template_id).first()
|
vnfd_id=device_template_id).first()
|
||||||
if devices_db is not None:
|
if devices_db is not None:
|
||||||
raise vnfm.DeviceTemplateInUse(
|
raise vnfm.DeviceTemplateInUse(
|
||||||
device_template_id=device_template_id)
|
device_template_id=device_template_id)
|
||||||
|
|
||||||
context.session.query(ServiceType).filter_by(
|
context.session.query(ServiceType).filter_by(
|
||||||
template_id=device_template_id).delete()
|
vnfd_id=device_template_id).delete()
|
||||||
context.session.query(DeviceTemplateAttribute).filter_by(
|
context.session.query(VNFDAttribute).filter_by(
|
||||||
template_id=device_template_id).delete()
|
vnfd_id=device_template_id).delete()
|
||||||
template_db = self._get_resource(context, DeviceTemplate,
|
template_db = self._get_resource(context, VNFD,
|
||||||
device_template_id)
|
device_template_id)
|
||||||
context.session.delete(template_db)
|
context.session.delete(template_db)
|
||||||
|
|
||||||
def get_device_template(self, context, device_template_id, fields=None):
|
def get_device_template(self, context, device_template_id, fields=None):
|
||||||
template_db = self._get_resource(context, DeviceTemplate,
|
template_db = self._get_resource(context, VNFD,
|
||||||
device_template_id)
|
device_template_id)
|
||||||
return self._make_template_dict(template_db)
|
return self._make_template_dict(template_db)
|
||||||
|
|
||||||
def get_device_templates(self, context, filters, fields=None):
|
def get_device_templates(self, context, filters, fields=None):
|
||||||
return self._get_collection(context, DeviceTemplate,
|
return self._get_collection(context, VNFD,
|
||||||
self._make_template_dict,
|
self._make_template_dict,
|
||||||
filters=filters, fields=fields)
|
filters=filters, fields=fields)
|
||||||
|
|
||||||
@ -298,19 +305,19 @@ class VNFMPluginDb(vnfm.VNFMPluginBase, db_base.CommonDbMixin):
|
|||||||
LOG.debug(_('required_attributes %s'), required_attributes)
|
LOG.debug(_('required_attributes %s'), required_attributes)
|
||||||
with context.session.begin(subtransactions=True):
|
with context.session.begin(subtransactions=True):
|
||||||
query = (
|
query = (
|
||||||
context.session.query(DeviceTemplate).
|
context.session.query(VNFD).
|
||||||
filter(
|
filter(
|
||||||
sa.exists().
|
sa.exists().
|
||||||
where(sa.and_(
|
where(sa.and_(
|
||||||
DeviceTemplate.id == ServiceType.template_id,
|
VNFD.id == ServiceType.vnfd_id,
|
||||||
ServiceType.service_type == service_type))))
|
ServiceType.service_type == service_type))))
|
||||||
for key in required_attributes:
|
for key in required_attributes:
|
||||||
query = query.filter(
|
query = query.filter(
|
||||||
sa.exists().
|
sa.exists().
|
||||||
where(sa.and_(
|
where(sa.and_(
|
||||||
DeviceTemplate.id ==
|
VNFD.id ==
|
||||||
DeviceTemplateAttribute.template_id,
|
VNFDAttribute.vnfd_id,
|
||||||
DeviceTemplateAttribute.key == key)))
|
VNFDAttribute.key == key)))
|
||||||
LOG.debug(_('statements %s'), query)
|
LOG.debug(_('statements %s'), query)
|
||||||
template_db = query.first()
|
template_db = query.first()
|
||||||
if template_db:
|
if template_db:
|
||||||
@ -318,14 +325,14 @@ class VNFMPluginDb(vnfm.VNFMPluginBase, db_base.CommonDbMixin):
|
|||||||
|
|
||||||
def _device_attribute_update_or_create(
|
def _device_attribute_update_or_create(
|
||||||
self, context, device_id, key, value):
|
self, context, device_id, key, value):
|
||||||
arg = (self._model_query(context, DeviceAttribute).
|
arg = (self._model_query(context, VNFAttribute).
|
||||||
filter(DeviceAttribute.device_id == device_id).
|
filter(VNFAttribute.vnf_id == device_id).
|
||||||
filter(DeviceAttribute.key == key).first())
|
filter(VNFAttribute.key == key).first())
|
||||||
if arg:
|
if arg:
|
||||||
arg.value = value
|
arg.value = value
|
||||||
else:
|
else:
|
||||||
arg = DeviceAttribute(
|
arg = VNFAttribute(
|
||||||
id=str(uuid.uuid4()), device_id=device_id,
|
id=str(uuid.uuid4()), vnf_id=device_id,
|
||||||
key=key, value=value)
|
key=key, value=value)
|
||||||
context.session.add(arg)
|
context.session.add(arg)
|
||||||
|
|
||||||
@ -340,22 +347,22 @@ class VNFMPluginDb(vnfm.VNFMPluginBase, db_base.CommonDbMixin):
|
|||||||
vim_id = device.get('vim_id')
|
vim_id = device.get('vim_id')
|
||||||
placement_attr = device.get('placement_attr', {})
|
placement_attr = device.get('placement_attr', {})
|
||||||
with context.session.begin(subtransactions=True):
|
with context.session.begin(subtransactions=True):
|
||||||
template_db = self._get_resource(context, DeviceTemplate,
|
template_db = self._get_resource(context, VNFD,
|
||||||
template_id)
|
template_id)
|
||||||
device_db = Device(id=device_id,
|
device_db = VNF(id=device_id,
|
||||||
tenant_id=tenant_id,
|
tenant_id=tenant_id,
|
||||||
name=name,
|
name=name,
|
||||||
description=template_db.description,
|
description=template_db.description,
|
||||||
instance_id=None,
|
instance_id=None,
|
||||||
template_id=template_id,
|
vnfd_id=template_id,
|
||||||
vim_id=vim_id,
|
vim_id=vim_id,
|
||||||
placement_attr=placement_attr,
|
placement_attr=placement_attr,
|
||||||
status=constants.PENDING_CREATE,
|
status=constants.PENDING_CREATE,
|
||||||
error_reason=None)
|
error_reason=None)
|
||||||
context.session.add(device_db)
|
context.session.add(device_db)
|
||||||
for key, value in attributes.items():
|
for key, value in attributes.items():
|
||||||
arg = DeviceAttribute(
|
arg = VNFAttribute(
|
||||||
id=str(uuid.uuid4()), device_id=device_id,
|
id=str(uuid.uuid4()), vnf_id=device_id,
|
||||||
key=key, value=value)
|
key=key, value=value)
|
||||||
context.session.add(arg)
|
context.session.add(arg)
|
||||||
|
|
||||||
@ -367,9 +374,9 @@ class VNFMPluginDb(vnfm.VNFMPluginBase, db_base.CommonDbMixin):
|
|||||||
mgmt_url, device_dict):
|
mgmt_url, device_dict):
|
||||||
LOG.debug(_('device_dict %s'), device_dict)
|
LOG.debug(_('device_dict %s'), device_dict)
|
||||||
with context.session.begin(subtransactions=True):
|
with context.session.begin(subtransactions=True):
|
||||||
query = (self._model_query(context, Device).
|
query = (self._model_query(context, VNF).
|
||||||
filter(Device.id == device_id).
|
filter(VNF.id == device_id).
|
||||||
filter(Device.status.in_(CREATE_STATES)).
|
filter(VNF.status.in_(CREATE_STATES)).
|
||||||
one())
|
one())
|
||||||
query.update({'instance_id': instance_id, 'mgmt_url': mgmt_url})
|
query.update({'instance_id': instance_id, 'mgmt_url': mgmt_url})
|
||||||
if instance_id is None or device_dict['status'] == constants.ERROR:
|
if instance_id is None or device_dict['status'] == constants.ERROR:
|
||||||
@ -383,17 +390,17 @@ class VNFMPluginDb(vnfm.VNFMPluginBase, db_base.CommonDbMixin):
|
|||||||
|
|
||||||
def _create_device_status(self, context, device_id, new_status):
|
def _create_device_status(self, context, device_id, new_status):
|
||||||
with context.session.begin(subtransactions=True):
|
with context.session.begin(subtransactions=True):
|
||||||
query = (self._model_query(context, Device).
|
query = (self._model_query(context, VNF).
|
||||||
filter(Device.id == device_id).
|
filter(VNF.id == device_id).
|
||||||
filter(Device.status.in_(CREATE_STATES)).one())
|
filter(VNF.status.in_(CREATE_STATES)).one())
|
||||||
query.update({'status': new_status})
|
query.update({'status': new_status})
|
||||||
|
|
||||||
def _get_device_db(self, context, device_id, current_statuses, new_status):
|
def _get_device_db(self, context, device_id, current_statuses, new_status):
|
||||||
try:
|
try:
|
||||||
device_db = (
|
device_db = (
|
||||||
self._model_query(context, Device).
|
self._model_query(context, VNF).
|
||||||
filter(Device.id == device_id).
|
filter(VNF.id == device_id).
|
||||||
filter(Device.status.in_(current_statuses)).
|
filter(VNF.status.in_(current_statuses)).
|
||||||
with_lockmode('update').one())
|
with_lockmode('update').one())
|
||||||
except orm_exc.NoResultFound:
|
except orm_exc.NoResultFound:
|
||||||
raise vnfm.DeviceNotFound(device_id=device_id)
|
raise vnfm.DeviceNotFound(device_id=device_id)
|
||||||
@ -424,15 +431,15 @@ class VNFMPluginDb(vnfm.VNFMPluginBase, db_base.CommonDbMixin):
|
|||||||
def _update_device_post(self, context, device_id, new_status,
|
def _update_device_post(self, context, device_id, new_status,
|
||||||
new_device_dict=None):
|
new_device_dict=None):
|
||||||
with context.session.begin(subtransactions=True):
|
with context.session.begin(subtransactions=True):
|
||||||
(self._model_query(context, Device).
|
(self._model_query(context, VNF).
|
||||||
filter(Device.id == device_id).
|
filter(VNF.id == device_id).
|
||||||
filter(Device.status == constants.PENDING_UPDATE).
|
filter(VNF.status == constants.PENDING_UPDATE).
|
||||||
update({'status': new_status}))
|
update({'status': new_status}))
|
||||||
|
|
||||||
dev_attrs = new_device_dict.get('attributes', {})
|
dev_attrs = new_device_dict.get('attributes', {})
|
||||||
(context.session.query(DeviceAttribute).
|
(context.session.query(VNFAttribute).
|
||||||
filter(DeviceAttribute.device_id == device_id).
|
filter(VNFAttribute.vnf_id == device_id).
|
||||||
filter(~DeviceAttribute.key.in_(dev_attrs.keys())).
|
filter(~VNFAttribute.key.in_(dev_attrs.keys())).
|
||||||
delete(synchronize_session='fetch'))
|
delete(synchronize_session='fetch'))
|
||||||
|
|
||||||
for (key, value) in dev_attrs.items():
|
for (key, value) in dev_attrs.items():
|
||||||
@ -451,14 +458,14 @@ class VNFMPluginDb(vnfm.VNFMPluginBase, db_base.CommonDbMixin):
|
|||||||
def _delete_device_post(self, context, device_id, error):
|
def _delete_device_post(self, context, device_id, error):
|
||||||
with context.session.begin(subtransactions=True):
|
with context.session.begin(subtransactions=True):
|
||||||
query = (
|
query = (
|
||||||
self._model_query(context, Device).
|
self._model_query(context, VNF).
|
||||||
filter(Device.id == device_id).
|
filter(VNF.id == device_id).
|
||||||
filter(Device.status == constants.PENDING_DELETE))
|
filter(VNF.status == constants.PENDING_DELETE))
|
||||||
if error:
|
if error:
|
||||||
query.update({'status': constants.ERROR})
|
query.update({'status': constants.ERROR})
|
||||||
else:
|
else:
|
||||||
(self._model_query(context, DeviceAttribute).
|
(self._model_query(context, VNFAttribute).
|
||||||
filter(DeviceAttribute.device_id == device_id).delete())
|
filter(VNFAttribute.vnf_id == device_id).delete())
|
||||||
query.delete()
|
query.delete()
|
||||||
|
|
||||||
# reference implementation. needs to be overrided by subclass
|
# reference implementation. needs to be overrided by subclass
|
||||||
@ -493,17 +500,17 @@ class VNFMPluginDb(vnfm.VNFMPluginBase, db_base.CommonDbMixin):
|
|||||||
self._delete_device_post(context, device_id, False)
|
self._delete_device_post(context, device_id, False)
|
||||||
|
|
||||||
def get_device(self, context, device_id, fields=None):
|
def get_device(self, context, device_id, fields=None):
|
||||||
device_db = self._get_resource(context, Device, device_id)
|
device_db = self._get_resource(context, VNF, device_id)
|
||||||
return self._make_device_dict(device_db, fields)
|
return self._make_device_dict(device_db, fields)
|
||||||
|
|
||||||
def get_devices(self, context, filters=None, fields=None):
|
def get_devices(self, context, filters=None, fields=None):
|
||||||
return self._get_collection(context, Device, self._make_device_dict,
|
return self._get_collection(context, VNF, self._make_device_dict,
|
||||||
filters=filters, fields=fields)
|
filters=filters, fields=fields)
|
||||||
|
|
||||||
def set_device_error_status_reason(self, context, device_id, new_reason):
|
def set_device_error_status_reason(self, context, device_id, new_reason):
|
||||||
with context.session.begin(subtransactions=True):
|
with context.session.begin(subtransactions=True):
|
||||||
(self._model_query(context, Device).
|
(self._model_query(context, VNF).
|
||||||
filter(Device.id == device_id).
|
filter(VNF.id == device_id).
|
||||||
update({'error_reason': new_reason}))
|
update({'error_reason': new_reason}))
|
||||||
|
|
||||||
def _mark_device_status(self, device_id, exclude_status, new_status):
|
def _mark_device_status(self, device_id, exclude_status, new_status):
|
||||||
@ -511,9 +518,9 @@ class VNFMPluginDb(vnfm.VNFMPluginBase, db_base.CommonDbMixin):
|
|||||||
with context.session.begin(subtransactions=True):
|
with context.session.begin(subtransactions=True):
|
||||||
try:
|
try:
|
||||||
device_db = (
|
device_db = (
|
||||||
self._model_query(context, Device).
|
self._model_query(context, VNF).
|
||||||
filter(Device.id == device_id).
|
filter(VNF.id == device_id).
|
||||||
filter(~Device.status.in_(exclude_status)).
|
filter(~VNF.status.in_(exclude_status)).
|
||||||
with_lockmode('update').one())
|
with_lockmode('update').one())
|
||||||
except orm_exc.NoResultFound:
|
except orm_exc.NoResultFound:
|
||||||
LOG.warning(_('no device found %s'), device_id)
|
LOG.warning(_('no device found %s'), device_id)
|
||||||
|
@ -97,7 +97,7 @@ class TestVNFMPlugin(db_base.SqlTestCase):
|
|||||||
|
|
||||||
def _insert_dummy_device_template(self):
|
def _insert_dummy_device_template(self):
|
||||||
session = self.context.session
|
session = self.context.session
|
||||||
device_template = vm_db.DeviceTemplate(
|
device_template = vm_db.VNFD(
|
||||||
id='eb094833-995e-49f0-a047-dfb56aaf7c4e',
|
id='eb094833-995e-49f0-a047-dfb56aaf7c4e',
|
||||||
tenant_id='ad7ebc56538745a08ef7c5e97f8bd437',
|
tenant_id='ad7ebc56538745a08ef7c5e97f8bd437',
|
||||||
name='fake_template',
|
name='fake_template',
|
||||||
@ -110,13 +110,13 @@ class TestVNFMPlugin(db_base.SqlTestCase):
|
|||||||
|
|
||||||
def _insert_dummy_device(self):
|
def _insert_dummy_device(self):
|
||||||
session = self.context.session
|
session = self.context.session
|
||||||
device_db = vm_db.Device(
|
device_db = vm_db.VNF(
|
||||||
id='6261579e-d6f3-49ad-8bc3-a9cb974778ff',
|
id='6261579e-d6f3-49ad-8bc3-a9cb974778ff',
|
||||||
tenant_id='ad7ebc56538745a08ef7c5e97f8bd437',
|
tenant_id='ad7ebc56538745a08ef7c5e97f8bd437',
|
||||||
name='fake_device',
|
name='fake_device',
|
||||||
description='fake_device_description',
|
description='fake_device_description',
|
||||||
instance_id='da85ea1a-4ec4-4201-bbb2-8d9249eca7ec',
|
instance_id='da85ea1a-4ec4-4201-bbb2-8d9249eca7ec',
|
||||||
template_id='eb094833-995e-49f0-a047-dfb56aaf7c4e',
|
vnfd_id='eb094833-995e-49f0-a047-dfb56aaf7c4e',
|
||||||
vim_id='6261579e-d6f3-49ad-8bc3-a9cb974778ff',
|
vim_id='6261579e-d6f3-49ad-8bc3-a9cb974778ff',
|
||||||
placement_attr={'region': 'RegionOne'},
|
placement_attr={'region': 'RegionOne'},
|
||||||
status='ACTIVE')
|
status='ACTIVE')
|
||||||
|
@ -543,7 +543,7 @@ class VNFMPlugin(vm_db.VNFMPluginDb, VNFMMgmtMixin):
|
|||||||
vnf_attributes['template_id'] = vnf_attributes.pop('vnfd_id')
|
vnf_attributes['template_id'] = vnf_attributes.pop('vnfd_id')
|
||||||
vnf_dict = self.create_device(context, vnf)
|
vnf_dict = self.create_device(context, vnf)
|
||||||
vnf_response = copy.deepcopy(vnf_dict)
|
vnf_response = copy.deepcopy(vnf_dict)
|
||||||
vnf_response['vnfd_id'] = vnf_response.pop('template_id')
|
vnf_response['vnfd_id'] = vnf_response.pop('vnfd_id')
|
||||||
return vnf_response
|
return vnf_response
|
||||||
|
|
||||||
def update_vnf(
|
def update_vnf(
|
||||||
|
Loading…
x
Reference in New Issue
Block a user