Make VNFD/VNF/VIM Name Mandatory in Tacker API's
Change-Id: I389d62e40d473c5149a18601f898e47b981b4b1d Partial-Bug: #1474966
This commit is contained in:
parent
4c74e89790
commit
a8395daace
releasenotes/notes
tacker
db
migration/alembic_migrations/versions
nfvo
vm
extensions
tests/functional/vnfm
@ -0,0 +1,4 @@
|
|||||||
|
---
|
||||||
|
features:
|
||||||
|
- Made VNFD/VNF/VIM names mandatory in tacker.
|
||||||
|
|
@ -0,0 +1,41 @@
|
|||||||
|
# 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.
|
||||||
|
#
|
||||||
|
|
||||||
|
"""make VNFD/VNF/VIM name mandatory
|
||||||
|
|
||||||
|
Revision ID: 5f88e86b35c7
|
||||||
|
Revises: 354de64ba129
|
||||||
|
Create Date: 2016-06-14 11:16:16.303343
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
# revision identifiers, used by Alembic.
|
||||||
|
revision = '5f88e86b35c7'
|
||||||
|
down_revision = '354de64ba129'
|
||||||
|
|
||||||
|
from alembic import op
|
||||||
|
from sqlalchemy.dialects import mysql
|
||||||
|
|
||||||
|
|
||||||
|
def upgrade(active_plugins=None, options=None):
|
||||||
|
op.alter_column('devices', 'name',
|
||||||
|
existing_type=mysql.VARCHAR(length=255),
|
||||||
|
nullable=False)
|
||||||
|
op.alter_column('devicetemplates', 'name',
|
||||||
|
existing_type=mysql.VARCHAR(length=255),
|
||||||
|
nullable=False)
|
||||||
|
op.alter_column('vims', 'name',
|
||||||
|
existing_type=mysql.VARCHAR(length=255),
|
||||||
|
nullable=False)
|
@ -1 +1 @@
|
|||||||
354de64ba129
|
5f88e86b35c7
|
@ -38,7 +38,7 @@ VIM_AUTH_ATTRIBUTES = ('auth_url', 'vim_project', 'password', 'auth_cred')
|
|||||||
|
|
||||||
class Vim(model_base.BASE, models_v1.HasId, models_v1.HasTenant):
|
class Vim(model_base.BASE, models_v1.HasId, models_v1.HasTenant):
|
||||||
type = sa.Column(sa.String(64), nullable=False)
|
type = sa.Column(sa.String(64), nullable=False)
|
||||||
name = sa.Column(sa.String(255), nullable=True)
|
name = sa.Column(sa.String(255), nullable=False)
|
||||||
description = sa.Column(sa.Text, nullable=True)
|
description = sa.Column(sa.Text, nullable=True)
|
||||||
placement_attr = sa.Column(types.Json, nullable=True)
|
placement_attr = sa.Column(types.Json, nullable=True)
|
||||||
shared = sa.Column(sa.Boolean, default=True, server_default=sql.true(
|
shared = sa.Column(sa.Boolean, default=True, server_default=sql.true(
|
||||||
|
@ -46,7 +46,7 @@ class DeviceTemplate(model_base.BASE, models_v1.HasId, models_v1.HasTenant):
|
|||||||
"""Represents template to create hosting device."""
|
"""Represents template to create hosting device."""
|
||||||
|
|
||||||
# Descriptive name
|
# Descriptive name
|
||||||
name = sa.Column(sa.String(255))
|
name = sa.Column(sa.String(255), nullable=False)
|
||||||
description = sa.Column(sa.Text)
|
description = sa.Column(sa.Text)
|
||||||
|
|
||||||
# service type that this service vm provides.
|
# service type that this service vm provides.
|
||||||
@ -98,7 +98,7 @@ class Device(model_base.BASE, models_v1.HasId, models_v1.HasTenant):
|
|||||||
template_id = sa.Column(types.Uuid, sa.ForeignKey('devicetemplates.id'))
|
template_id = sa.Column(types.Uuid, sa.ForeignKey('devicetemplates.id'))
|
||||||
template = orm.relationship('DeviceTemplate')
|
template = orm.relationship('DeviceTemplate')
|
||||||
|
|
||||||
name = sa.Column(sa.String(255), nullable=True)
|
name = sa.Column(sa.String(255), nullable=False)
|
||||||
description = sa.Column(sa.Text, nullable=True)
|
description = sa.Column(sa.Text, nullable=True)
|
||||||
|
|
||||||
# sufficient information to uniquely identify hosting device.
|
# sufficient information to uniquely identify hosting device.
|
||||||
|
@ -112,7 +112,6 @@ RESOURCE_ATTRIBUTE_MAP = {
|
|||||||
'allow_put': True,
|
'allow_put': True,
|
||||||
'validate': {'type:string': None},
|
'validate': {'type:string': None},
|
||||||
'is_visible': True,
|
'is_visible': True,
|
||||||
'default': '',
|
|
||||||
},
|
},
|
||||||
'description': {
|
'description': {
|
||||||
'allow_post': True,
|
'allow_post': True,
|
||||||
|
@ -184,7 +184,6 @@ RESOURCE_ATTRIBUTE_MAP = {
|
|||||||
'allow_put': True,
|
'allow_put': True,
|
||||||
'validate': {'type:string': None},
|
'validate': {'type:string': None},
|
||||||
'is_visible': True,
|
'is_visible': True,
|
||||||
'default': '',
|
|
||||||
},
|
},
|
||||||
'description': {
|
'description': {
|
||||||
'allow_post': True,
|
'allow_post': True,
|
||||||
@ -258,7 +257,6 @@ RESOURCE_ATTRIBUTE_MAP = {
|
|||||||
'allow_put': True,
|
'allow_put': True,
|
||||||
'validate': {'type:string': None},
|
'validate': {'type:string': None},
|
||||||
'is_visible': True,
|
'is_visible': True,
|
||||||
'default': '',
|
|
||||||
},
|
},
|
||||||
'description': {
|
'description': {
|
||||||
'allow_post': True,
|
'allow_post': True,
|
||||||
|
@ -27,8 +27,10 @@ class VnfTestToscaCreate(base.BaseTackerTest):
|
|||||||
def test_create_delete_vnf_tosca_no_monitoring(self):
|
def test_create_delete_vnf_tosca_no_monitoring(self):
|
||||||
data = dict()
|
data = dict()
|
||||||
data['tosca'] = read_file('sample-tosca-vnfd.yaml')
|
data['tosca'] = read_file('sample-tosca-vnfd.yaml')
|
||||||
|
vnfd_name = 'test_tosca_vnf_with_cirros_no_monitoring'
|
||||||
toscal = data['tosca']
|
toscal = data['tosca']
|
||||||
tosca_arg = {'vnfd': {'attributes': {'vnfd': toscal}}}
|
tosca_arg = {'vnfd': {'name': vnfd_name,
|
||||||
|
'attributes': {'vnfd': toscal}}}
|
||||||
|
|
||||||
# Create vnfd with tosca template
|
# Create vnfd with tosca template
|
||||||
vnfd_instance = self.client.create_vnfd(body=tosca_arg)
|
vnfd_instance = self.client.create_vnfd(body=tosca_arg)
|
||||||
|
@ -31,7 +31,9 @@ class VnfTestToscaMultipleVDU(base.BaseTackerTest):
|
|||||||
input_yaml = read_file('sample-tosca-vnfd-multi-vdu.yaml')
|
input_yaml = read_file('sample-tosca-vnfd-multi-vdu.yaml')
|
||||||
data['tosca'] = input_yaml
|
data['tosca'] = input_yaml
|
||||||
toscal = data['tosca']
|
toscal = data['tosca']
|
||||||
tosca_arg = {'vnfd': {'attributes': {'vnfd': toscal}}}
|
vnfd_name = 'sample-tosca-vnfd-multi-vdu'
|
||||||
|
tosca_arg = {'vnfd': {'name': vnfd_name,
|
||||||
|
'attributes': {'vnfd': toscal}}}
|
||||||
|
|
||||||
# Create vnfd with tosca template
|
# Create vnfd with tosca template
|
||||||
vnfd_instance = self.client.create_vnfd(body=tosca_arg)
|
vnfd_instance = self.client.create_vnfd(body=tosca_arg)
|
||||||
|
@ -25,7 +25,9 @@ class VnfdTestCreate(base.BaseTackerTest):
|
|||||||
data = dict()
|
data = dict()
|
||||||
data['tosca'] = read_file(tosca_vnfd_file)
|
data['tosca'] = read_file(tosca_vnfd_file)
|
||||||
toscal = data['tosca']
|
toscal = data['tosca']
|
||||||
tosca_arg = {'vnfd': {'attributes': {'vnfd': toscal}}}
|
vnfd_name = 'sample-tosca-vnfd'
|
||||||
|
tosca_arg = {'vnfd': {'name': vnfd_name,
|
||||||
|
'attributes': {'vnfd': toscal}}}
|
||||||
vnfd_instance = self.client.create_vnfd(body=tosca_arg)
|
vnfd_instance = self.client.create_vnfd(body=tosca_arg)
|
||||||
self.assertIsNotNone(vnfd_instance)
|
self.assertIsNotNone(vnfd_instance)
|
||||||
|
|
||||||
|
@ -26,8 +26,10 @@ class VnfTestCreate(base.BaseTackerTest):
|
|||||||
def _test_create_delete_vnf(self, vnf_name, vim_id=None):
|
def _test_create_delete_vnf(self, vnf_name, vim_id=None):
|
||||||
data = dict()
|
data = dict()
|
||||||
data['tosca'] = read_file('sample_cirros_vnf_no_monitoring.yaml')
|
data['tosca'] = read_file('sample_cirros_vnf_no_monitoring.yaml')
|
||||||
|
vnfd_name = 'sample_cirros_vnf_no_monitoring'
|
||||||
toscal = data['tosca']
|
toscal = data['tosca']
|
||||||
tosca_arg = {'vnfd': {'attributes': {'vnfd': toscal}}}
|
tosca_arg = {'vnfd': {'name': vnfd_name,
|
||||||
|
'attributes': {'vnfd': toscal}}}
|
||||||
|
|
||||||
# Create vnfd with tosca template
|
# Create vnfd with tosca template
|
||||||
vnfd_instance = self.client.create_vnfd(body=tosca_arg)
|
vnfd_instance = self.client.create_vnfd(body=tosca_arg)
|
||||||
|
@ -23,7 +23,8 @@ class VnfTestPingMonitor(base.BaseTackerTest):
|
|||||||
data = dict()
|
data = dict()
|
||||||
data['tosca'] = read_file(vnfd_file)
|
data['tosca'] = read_file(vnfd_file)
|
||||||
toscal = data['tosca']
|
toscal = data['tosca']
|
||||||
tosca_arg = {'vnfd': {'attributes': {'vnfd': toscal}}}
|
tosca_arg = {'vnfd': {'name': vnf_name,
|
||||||
|
'attributes': {'vnfd': toscal}}}
|
||||||
|
|
||||||
# Create vnfd with tosca template
|
# Create vnfd with tosca template
|
||||||
vnfd_instance = self.client.create_vnfd(body=tosca_arg)
|
vnfd_instance = self.client.create_vnfd(body=tosca_arg)
|
||||||
|
@ -29,7 +29,9 @@ class VnfTestMultipleVDU(base.BaseTackerTest):
|
|||||||
input_yaml = read_file('sample-vnfd-multi-vdu.yaml')
|
input_yaml = read_file('sample-vnfd-multi-vdu.yaml')
|
||||||
data['tosca'] = input_yaml
|
data['tosca'] = input_yaml
|
||||||
toscal = data['tosca']
|
toscal = data['tosca']
|
||||||
tosca_arg = {'vnfd': {'attributes': {'vnfd': toscal}}}
|
vnfd_name = 'sample-vnfd-multi-vdu'
|
||||||
|
tosca_arg = {'vnfd': {'name': vnfd_name,
|
||||||
|
'attributes': {'vnfd': toscal}}}
|
||||||
|
|
||||||
# Create vnfd with tosca template
|
# Create vnfd with tosca template
|
||||||
vnfd_instance = self.client.create_vnfd(body=tosca_arg)
|
vnfd_instance = self.client.create_vnfd(body=tosca_arg)
|
||||||
|
@ -25,7 +25,9 @@ class VnfdTestCreate(base.BaseTackerTest):
|
|||||||
data = dict()
|
data = dict()
|
||||||
data['tosca'] = read_file(vnfd_file)
|
data['tosca'] = read_file(vnfd_file)
|
||||||
toscal = data['tosca']
|
toscal = data['tosca']
|
||||||
tosca_arg = {'vnfd': {'attributes': {'vnfd': toscal}}}
|
vnfd_name = 'sample_cirros_vnf'
|
||||||
|
tosca_arg = {'vnfd': {'name': vnfd_name,
|
||||||
|
'attributes': {'vnfd': toscal}}}
|
||||||
vnfd_instance = self.client.create_vnfd(body=tosca_arg)
|
vnfd_instance = self.client.create_vnfd(body=tosca_arg)
|
||||||
self.assertIsNotNone(vnfd_instance)
|
self.assertIsNotNone(vnfd_instance)
|
||||||
|
|
||||||
|
@ -23,8 +23,10 @@ class VnfmTestParam(base.BaseTackerTest):
|
|||||||
def _test_vnfd_create(self, vnfd_file):
|
def _test_vnfd_create(self, vnfd_file):
|
||||||
yaml_input = dict()
|
yaml_input = dict()
|
||||||
yaml_input['tosca'] = read_file(vnfd_file)
|
yaml_input['tosca'] = read_file(vnfd_file)
|
||||||
|
vnfd_name = 'sample_cirros_vnf'
|
||||||
toscal = yaml_input['tosca']
|
toscal = yaml_input['tosca']
|
||||||
req_dict = {'vnfd': {'attributes': {'vnfd': toscal}}}
|
req_dict = {'vnfd': {'name': vnfd_name,
|
||||||
|
'attributes': {'vnfd': toscal}}}
|
||||||
|
|
||||||
# Create vnfd
|
# Create vnfd
|
||||||
vnfd_instance = self.client.create_vnfd(body=req_dict)
|
vnfd_instance = self.client.create_vnfd(body=req_dict)
|
||||||
|
Loading…
Reference in New Issue
Block a user