aboutsummaryrefslogtreecommitdiffstats
path: root/ice_validator/tests/test_heat_template_structure.py
diff options
context:
space:
mode:
authorstark, steven <ss820f@att.com>2018-09-14 07:55:49 -0700
committerstark, steven <ss820f@att.com>2018-09-14 07:55:49 -0700
commit60d5ad7d00eadd6395eca186e6fa76a43df3c6cf (patch)
tree95d83d0a70a948707ead37800bc547da7f5861b2 /ice_validator/tests/test_heat_template_structure.py
parent31d5da59b39d38760cc519a2c5e5b70357b539e8 (diff)
[VVP] udpating scripts for casablanca 2
adding scripts updates adding docrators for sections 5.2.6 - end closes out VVP 80 Change-Id: Iecac476949aa3ae3982f8c77671869583eb313d6 Issue-ID: VVP-80 Signed-off-by: stark, steven <ss820f@att.com>
Diffstat (limited to 'ice_validator/tests/test_heat_template_structure.py')
-rw-r--r--ice_validator/tests/test_heat_template_structure.py97
1 files changed, 53 insertions, 44 deletions
diff --git a/ice_validator/tests/test_heat_template_structure.py b/ice_validator/tests/test_heat_template_structure.py
index 1e0b8c8..32b448e 100644
--- a/ice_validator/tests/test_heat_template_structure.py
+++ b/ice_validator/tests/test_heat_template_structure.py
@@ -1,8 +1,8 @@
# -*- coding: utf8 -*-
-# ============LICENSE_START=======================================================
+# ============LICENSE_START====================================================
# org.onap.vvp/validation-scripts
# ===================================================================
-# Copyright © 2018 AT&T Intellectual Property. All rights reserved.
+# Copyright © 2017 AT&T Intellectual Property. All rights reserved.
# ===================================================================
#
# Unless otherwise specified, all software contained herein is licensed
@@ -37,76 +37,84 @@
#
# ECOMP is a trademark and service mark of AT&T Intellectual Property.
#
+
+"""Test heat template structure
+"""
+
+from tests import cached_yaml as yaml
from .helpers import validates
-import yaml
+
+VERSION = '1.2.0'
+
+# pylint: disable=invalid-name
-def test_heat_template_structure(yaml_file):
+@validates('R-27078')
+def test_heat_template_structure_contains_heat_template_version(yaml_file):
'''
- Check that all heat templates only have the allowed sections
+ Check that all heat templates have the required sections
'''
- key_values = ["heat_template_version", "description",
- "parameter_groups", "parameters", "resources",
- "outputs", "conditions"]
+ required_key_values = ["heat_template_version"]
with open(yaml_file) as fh:
yml = yaml.load(fh)
- assert all([k in key_values for k in yml])
+ assert all([k in yml for k in required_key_values]), (
+ "{} doesn't contain the {} section, but it is required"
+ .format(yaml_file, required_key_values[0]))
-@validates('R-27078', 'R-39402', 'R-35414')
-def test_heat_template_structure_contains_required_sections(yaml_file):
+@validates('R-39402')
+def test_heat_template_structure_contains_description(yaml_file):
'''
Check that all heat templates have the required sections
'''
- required_key_values = ["heat_template_version", "description",
- "parameters", "resources"]
+ required_key_values = ["description"]
with open(yaml_file) as fh:
yml = yaml.load(fh)
- assert all([k in yml for k in required_key_values])
+ assert all([k in yml for k in required_key_values]), (
+ "{} doesn't contain the {} section, but it is required"
+ .format(yaml_file, required_key_values[0]))
-def test_heat_template_structure_sections_have_the_right_format(yaml_file):
+@validates('R-35414')
+def test_heat_template_structure_contains_parameters(yaml_file):
'''
- Check that all heat templates have sections of the right format.
- Do note that it only tests for dicts or not dicts currently.
+ Check that all heat templates have the required sections
'''
- key_values = ["heat_template_version", "description",
- "parameter_groups", "parameters", "resources",
- "outputs", "conditions"]
- key_values_not_dicts = ["heat_template_version", "description"]
+ required_key_values = ["parameters"]
with open(yaml_file) as fh:
yml = yaml.load(fh)
+ assert all([k in yml for k in required_key_values]), (
+ "{} doesn't contain the {} section, but it is required"
+ .format(yaml_file, required_key_values[0]))
+
- is_dict = 0
- should_be_dict = 0
- is_not_dict = 0
- should_not_be_dict = 0
- for key_value in key_values:
- if key_value in yml:
- if isinstance(yml[key_value], dict):
- is_dict += 1
- if key_value not in key_values_not_dicts:
- should_be_dict += 1
- elif not isinstance(yml[key_value], list):
- is_not_dict += 1
- if key_value in key_values_not_dicts:
- should_not_be_dict += 1
- assert (is_dict == should_be_dict and
- is_not_dict == should_not_be_dict)
+@validates('R-23664')
+def test_heat_template_structure_contains_resources(heat_template):
+ '''
+ Check that all heat templates have the required sections
+ '''
+ required_key_values = ["resources"]
+
+ with open(heat_template) as fh:
+ yml = yaml.load(fh)
+ assert all([k in yml for k in required_key_values]), (
+ "{} doesn't contain the {} section, but it is required"
+ .format(heat_template, required_key_values[0]))
@validates('R-11441')
def test_parameter_type(yaml_file):
- types = [
- 'string',
- 'number',
- 'json',
- 'comma_delimited_list',
- 'boolean',
- ]
+ '''A VNF's Heat Orchestration Template's parameter type **MUST**
+ be one of the following values:
+ '''
+ types = ['string',
+ 'number',
+ 'json',
+ 'comma_delimited_list',
+ 'boolean']
with open(yaml_file) as fh:
yml = yaml.load(fh)
for key, param in yml.get('parameters', {}).items():
@@ -121,3 +129,4 @@ def test_parameter_type(yaml_file):
yaml_file,
key,
typ)
+