Fix processing related to required properties

In the current UT testcase and yaml, there are several cases where
the required property of policy is insufficient or the definition
part is incorrect.
In addition, there is a bug in the code that has the translation
logic under 'translator/hot/tosca/'.
This patch fixes these translation logic codes, testcase and yaml.

Among the fixed yaml files, the following has a line feed code of CRLF,
so it has been modified to LF.

* translator/tests/data/autoscaling/tosca_cluster_autoscaling.yaml
* translator/tests/data/custom_types/senlin_cluster_policies.yaml
* translator/tests/data/nfv/test_tosca_nfv_autoscaling_with_params.yaml

In addition, NOTE description is added for
'translator/hot/tosca/tosca_policies_monitoring.py',
which is one of the translation logic codes.

Closes-Bug: #1918360
Change-Id: Ib9dec61007db5d354eaca86000ab3bcf6744a838
This commit is contained in:
Hiroo Kitamura 2021-03-10 11:04:09 +09:00
parent 7109d4cd52
commit 2c94431c0d
13 changed files with 294 additions and 215 deletions

View File

@ -37,8 +37,8 @@ class AutoscalingTest(TestCase):
policy_name = list(policies[0].keys())[0]
for policy in policies:
tpl = policy[policy_name]
targets = tpl["targets"]
properties = tpl["properties"]
targets = properties["targets"]
try:
nodetemplate = NodeTemplate(name, nodetemplates)
toscacompute = ToscaCompute(nodetemplate)
@ -82,7 +82,6 @@ class AutoscalingTest(TestCase):
- asg:
type: tosca.policies.Scaling
description: Simple node autoscaling
targets: [my_server_1]
triggers:
resize_compute:
description: trigger
@ -94,6 +93,7 @@ class AutoscalingTest(TestCase):
resource_type: instance
comparison_operator: gt
properties:
targets: [my_server_1]
min_instances: 2
max_instances: 10
default_instances: 3
@ -126,8 +126,8 @@ class AutoscalingTest(TestCase):
policies:
- SP1:
type: tosca.policies.Scaling
targets: [VDU1]
properties:
targets: [VDU1]
increment: 1
cooldown: 120
min_instances: 1

View File

@ -66,7 +66,7 @@ class ToscaClusterAutoscaling(HotResource):
hot_resources = []
hot_type = 'OS::Aodh::GnocchiAggregationByResourcesAlarm'
trigger_receivers = defaultdict(list)
for node in self.policy.targets:
for node in self.policy.properties['targets']:
for trigger in self.policy.entity_tpl['triggers']:
for action in self.policy.\
entity_tpl['triggers'][trigger]['action']:
@ -137,7 +137,7 @@ class ToscaClusterAutoscaling(HotResource):
remove_resources.append(resource)
elif resource.type == 'OS::Neutron::Net':
remove_resources.append(resource)
elif resource.name in self.policy.targets and \
elif resource.name in self.policy.properties['targets'] and \
resource.type != 'OS::Senlin::Policy':
props = {}
del resource.properties['user_data_format']
@ -155,11 +155,11 @@ class ToscaClusterAutoscaling(HotResource):
resources.remove(remove_resource)
for index, resource in enumerate(resources):
if resource.name in self.policy.targets:
if resource.name in self.policy.properties['targets']:
resource.properties['properties']['networks'] = \
networks[resource.name]
for node in self.policy.targets:
for node in self.policy.properties['targets']:
props = {}
props["profile"] = {'get_resource': '%s' % node}
temp = self.policy.entity_tpl["properties"]
@ -181,7 +181,7 @@ class ToscaClusterAutoscaling(HotResource):
entity_tpl['triggers'][trigger]['action']:
scale_type = self.policy.\
entity_tpl['triggers'][trigger]['action'][action]['type']
for node in self.policy.targets:
for node in self.policy.properties['targets']:
target_cluster_nodes.\
append({"get_resource": "%s_cluster" % node})
cluster_scale_type = SCALE_TYPE[scale_type]

View File

@ -28,6 +28,12 @@ ALARM_STATISTIC = {'mean': 'mean', 'median': 'median', 'summary': 'sum',
class ToscaMonitoring(HotResource):
'''Translate TOSCA node type tosca.policies.Monitoring'''
# NOTE: This file implements extended conversion logic other than
# the section defined at 'tosca.policies.Monitoring' in
# TOSCA_definition_1_0.yaml. Therefore, it is necessary to define
# and use toscatype that inherits this toscatype with 'derived_from'.
# This is because validation fails due to an error that an undefined
# key exists when validating using tosca-parser.
toscatype = 'tosca.policies.Monitoring'
def __init__(self, policy, csar_dir=None):

View File

@ -72,23 +72,23 @@ class ToscaAutoscaling(HotResource):
delete_res_names = []
scale_res = []
for index, resource in enumerate(resources):
if resource.name in self.policy.targets and \
resource.type != 'OS::Heat::AutoScalingGroup':
if resource.type != 'OS::Heat::AutoScalingGroup':
temp = self.policy.entity_tpl["properties"]
props = {}
res = {}
res["min_size"] = temp["min_instances"]
res["max_size"] = temp["max_instances"]
res["desired_capacity"] = temp["default_instances"]
res["cooldown"] = temp["cooldown"]
props['type'] = resource.type
props['properties'] = resource.properties
res['resource'] = {'type': self.policy.name + '_res.yaml'}
scaling_resources = \
HotResource(resource,
type='OS::Heat::AutoScalingGroup',
name=self.policy.name + '_group',
properties=res)
if resource.name in temp.get("targets"):
props = {}
res = {}
res["min_size"] = temp["min_instances"]
res["max_size"] = temp["max_instances"]
res["desired_capacity"] = temp["default_instances"]
res["cooldown"] = temp["cooldown"]
props['type'] = resource.type
props['properties'] = resource.properties
res['resource'] = {'type': self.policy.name + '_res.yaml'}
scaling_resources = \
HotResource(resource,
type='OS::Heat::AutoScalingGroup',
name=self.policy.name + '_group',
properties=res)
if resource.type not in SCALING_RESOURCES:
delete_res_names.append(resource.name)

View File

@ -3,6 +3,11 @@ tosca_definitions_version: tosca_simple_yaml_1_0
description: >
Template for deploying servers based on policies.
imports:
- ../custom_types/custom_monitoring.yaml
- ../nfv/tacker_defs.yaml
- ../nfv/tacker_nfv_defs.yaml
topology_template:
node_templates:
my_server_1:
@ -22,22 +27,27 @@ topology_template:
version: 6.5
policies:
- asg:
type: tosca.policies.Scaling
type: tosca.policies.tacker.Scaling
description: Simple node autoscaling
targets: [my_server_1]
triggers:
resize_compute:
description: trigger
condition:
constraint: utilization greater_than 50%
granularity: 60
evaluations: 1
aggregation_method: mean
resource_type: instance
comparison_operator: gt
properties:
targets: [my_server_1]
min_instances: 2
max_instances: 10
default_instances: 3
increment: 1
cooldown: 60
- cpu_monitoring:
type: tosca.policies.Monitoring.Custom
description: Simple node monitoring
triggers:
high_cpu_usage:
description: trigger
metric: cpu_util
condition:
constraint: utilization greater_than 60%
threshold: 60
granularity: 600
evaluations: 1
aggregation_method: mean
comparison_operator: gt

View File

@ -5,6 +5,8 @@ description: >
imports:
- ../custom_types/senlin_cluster_policies.yaml
- ../nfv/tacker_defs.yaml
- ../nfv/tacker_nfv_defs.yaml
topology_template:
node_templates:
@ -38,7 +40,13 @@ topology_template:
- cluster_scaling:
type: tosca.policies.Scaling.Cluster
description: Cluster node autoscaling
targets: [my_server_1]
properties:
targets: [my_server_1]
min_instances: 2
max_instances: 10
default_instances: 3
increment: 1
cooldown: 60
triggers:
scale_out:
description: trigger
@ -57,8 +65,3 @@ topology_template:
scale_out:
type: SCALE_OUT
implementation: Senlin.webhook
properties:
min_instances: 2
max_instances: 10
default_instances: 3
increment: 1

View File

@ -0,0 +1,31 @@
tosca_definitions_version: tosca_simple_yaml_1_0
description: >
The TOSCA Policy Type definition that is used to expand
the monitoring policy.
policy_types:
tosca.policies.Monitoring.Custom:
derived_from: tosca.policies.Monitoring
description: The TOSCA Policy Type definition that is used to expand
the monitoring policy.
triggers:
resize_compute:
event_type:
type: map
entry_schema:
type: string
required: true
metrics:
type: string
required: true
condition:
type: map
entry_schema:
type: string
required: false
action:
type: map
entry_schema:
type: string
required: true

View File

@ -4,8 +4,32 @@ description: >
The TOSCA Policy Type definition that is used to govern
Senlin Policy of TOSCA nodes or groups of nodes
imports:
- ../nfv/tacker_defs.yaml
- ../nfv/tacker_nfv_defs.yaml
policy_types:
tosca.policies.Scaling.Cluster:
derived_from: tosca.policies.Scaling
derived_from: tosca.policies.tacker.Scaling
description: The TOSCA Policy Type definition that is used to govern
scaling of TOSCA nodes or groups of nodes.
triggers:
resize_compute:
event_type:
type: map
entry_schema:
type: string
required: true
metrics:
type: string
required: true
condition:
type: map
entry_schema:
type: string
required: false
action:
type: map
entry_schema:
type: string
required: true

View File

@ -30,14 +30,15 @@ resources:
adjustment_type: change_in_capacity
scaling_adjustment: -1
cooldown: 60
asg_alarm:
high_cpu_usage:
type: OS::Aodh::GnocchiAggregationByResourcesAlarm
properties:
metric: cpu_util
description: Simple node autoscaling
granularity: 60
description: utilization greater_than 60%
evaluation_periods: 1
granularity: 600
aggregation_method: mean
threshold: 1
threshold: 60
resource_type: instance
comparison_operator: gt
outputs: {}

View File

@ -3,6 +3,11 @@ tosca_definitions_version: tosca_simple_yaml_1_0
description: >
Template for deploying servers based on policies.
imports:
- ../custom_types/custom_monitoring.yaml
- ../nfv/tacker_defs.yaml
- ../nfv/tacker_nfv_defs.yaml
topology_template:
node_templates:
my_server_1:
@ -22,10 +27,10 @@ topology_template:
version: 6.5
policies:
- asg:
type: tosca.policies.Scaling
type: tosca.policies.tacker.Scaling
description: Simple node autoscaling
targets: [my_server_1]
properties:
targets: [my_server_1]
min_instances: 2
max_instances: 10
default_instances: 3
@ -33,9 +38,8 @@ topology_template:
cooldown: 60
- cpu_monitoring:
type: tosca.policies.Monitoring
type: tosca.policies.Monitoring.Custom
description: Simple node monitoring
targets: [my_server_1]
triggers:
high_cpu_usage:
description: trigger

View File

@ -58,8 +58,8 @@ topology_template:
policies:
- SP1:
type: tosca.policies.tacker.Scaling
targets: [VDU1, VDU2]
properties:
targets: [VDU1, VDU2]
increment: 1
cooldown: 120
min_instances: 1

View File

@ -49,8 +49,8 @@ topology_template:
policies:
- SP:
type: tosca.policies.tacker.Scaling
targets: [VDU1]
properties:
targets: [VDU1]
increment: 1
cooldown: 120
min_instances: 1

View File

@ -57,4 +57,4 @@ topology_template:
min_instances: 0
max_instances: 3
default_instances: 0
targets: [VDU1]
targets: [VDU1]