Merge "Fix duplicate entry error in VNF Package upload"
This commit is contained in:
commit
4d11475f3a
tacker
@ -524,6 +524,11 @@ class Conductor(manager.Manager, v2_hook.ConductorV2Hook):
|
|||||||
|
|
||||||
_delete_csar(context, vnf_package)
|
_delete_csar(context, vnf_package)
|
||||||
|
|
||||||
|
# TODO(h-asahina): stop using these Legacy DB
|
||||||
|
if vnf_package.vnfd is not None:
|
||||||
|
objects.VnfdAttribute(context).delete(vnf_package.vnfd.vnfd_id)
|
||||||
|
objects.Vnfd(context).delete(vnf_package.vnfd.vnfd_id)
|
||||||
|
|
||||||
vnf_package.destroy(context)
|
vnf_package.destroy(context)
|
||||||
|
|
||||||
def get_vnf_package_vnfd(self, context, vnf_package):
|
def get_vnf_package_vnfd(self, context, vnf_package):
|
||||||
|
@ -81,7 +81,7 @@ class VnfdAttribute(base.TackerObject, base.TackerObjectDictCompat,
|
|||||||
fields = {
|
fields = {
|
||||||
'id': fields.UUIDField(nullable=False),
|
'id': fields.UUIDField(nullable=False),
|
||||||
'vnfd_id': fields.UUIDField(nullable=False),
|
'vnfd_id': fields.UUIDField(nullable=False),
|
||||||
'key': fields.StringField(nullable=True),
|
'key': fields.StringField(nullable=False),
|
||||||
'value': fields.StringField(nullable=True),
|
'value': fields.StringField(nullable=True),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -41,7 +41,9 @@ from tacker.conductor import conductor_server
|
|||||||
import tacker.conf
|
import tacker.conf
|
||||||
from tacker import context
|
from tacker import context
|
||||||
from tacker import context as t_context
|
from tacker import context as t_context
|
||||||
|
from tacker.db.db_sqlalchemy import api
|
||||||
from tacker.db.db_sqlalchemy import models
|
from tacker.db.db_sqlalchemy import models
|
||||||
|
from tacker.db.vnfm import vnfm_db
|
||||||
from tacker.glance_store import store as glance_store
|
from tacker.glance_store import store as glance_store
|
||||||
from tacker import objects
|
from tacker import objects
|
||||||
from tacker.objects import fields
|
from tacker.objects import fields
|
||||||
@ -240,9 +242,49 @@ class TestConductor(SqlTestCase, unit_base.FixturedTestCase):
|
|||||||
|
|
||||||
@mock.patch.object(glance_store, 'delete_csar')
|
@mock.patch.object(glance_store, 'delete_csar')
|
||||||
def test_delete_vnf_package(self, mock_delete_csar):
|
def test_delete_vnf_package(self, mock_delete_csar):
|
||||||
self.vnf_package.__setattr__('onboarding_state', 'ONBOARDED')
|
self.vnf_package.onboarding_state = 'ONBOARDED'
|
||||||
|
vnfd_id = uuidsentinel.vnfd_id
|
||||||
|
|
||||||
|
# create VnfPackageVnfd
|
||||||
|
vnf_pack_vnfd_data = fake_obj.get_vnf_package_vnfd_data(
|
||||||
|
self.vnf_package.id, vnfd_id)
|
||||||
|
vnf_pack_vnfd = objects.VnfPackageVnfd(
|
||||||
|
self.context, **vnf_pack_vnfd_data)
|
||||||
|
vnf_pack_vnfd.create()
|
||||||
|
self.vnf_package.vnfd = vnf_pack_vnfd
|
||||||
|
|
||||||
|
# create Legacy Vnfd
|
||||||
|
vnfd = objects.Vnfd(self.context)
|
||||||
|
vnfd.id = vnfd_id
|
||||||
|
vnfd.tenant_id = uuidsentinel.tenant_id
|
||||||
|
vnfd.name = 'dummy_name'
|
||||||
|
vnfd.create()
|
||||||
|
|
||||||
|
# create Legacy VnfdAttribute
|
||||||
|
vnfd_attr = objects.VnfdAttribute(self.context)
|
||||||
|
vnfd_attr.id = uuidsentinel.vnfd_attr_id
|
||||||
|
vnfd_attr.vnfd_id = vnfd_id
|
||||||
|
vnfd_attr.key = 'dummy_key'
|
||||||
|
vnfd_attr.create()
|
||||||
|
|
||||||
|
# check Vnfd and VnfdAttribute were created
|
||||||
|
self.assertIsNotNone(
|
||||||
|
api.model_query(self.context, vnfm_db.VNFDAttribute)
|
||||||
|
.filter_by(vnfd_id=vnfd_id).first())
|
||||||
|
self.assertIsNotNone(
|
||||||
|
api.model_query(self.context, vnfm_db.VNFD)
|
||||||
|
.filter_by(id=vnfd_id).first())
|
||||||
|
|
||||||
self.conductor.delete_vnf_package(self.context, self.vnf_package)
|
self.conductor.delete_vnf_package(self.context, self.vnf_package)
|
||||||
|
|
||||||
|
# check Vnfd and VnfdAttribute were deleted
|
||||||
mock_delete_csar.assert_called()
|
mock_delete_csar.assert_called()
|
||||||
|
self.assertIsNone(
|
||||||
|
api.model_query(self.context, vnfm_db.VNFDAttribute)
|
||||||
|
.filter_by(vnfd_id=vnfd_id).first())
|
||||||
|
self.assertIsNone(
|
||||||
|
api.model_query(self.context, vnfm_db.VNFD)
|
||||||
|
.filter_by(id=vnfd_id).first())
|
||||||
|
|
||||||
def test_get_vnf_package_vnfd_with_tosca_meta_file_in_csar(self):
|
def test_get_vnf_package_vnfd_with_tosca_meta_file_in_csar(self):
|
||||||
fake_csar = fakes.create_fake_csar_dir(self.vnf_package.id,
|
fake_csar = fakes.create_fake_csar_dir(self.vnf_package.id,
|
||||||
|
Loading…
Reference in New Issue
Block a user