2 # ============LICENSE_START=======================================================
3 # org.onap.vvp/validation-scripts
4 # ===================================================================
5 # Copyright © 2017 AT&T Intellectual Property. All rights reserved.
6 # ===================================================================
8 # Unless otherwise specified, all software contained herein is licensed
9 # under the Apache License, Version 2.0 (the “License”);
10 # you may not use this software except in compliance with the License.
11 # You may obtain a copy of the License at
13 # http://www.apache.org/licenses/LICENSE-2.0
15 # Unless required by applicable law or agreed to in writing, software
16 # distributed under the License is distributed on an "AS IS" BASIS,
17 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18 # See the License for the specific language governing permissions and
19 # limitations under the License.
23 # Unless otherwise specified, all documentation contained herein is licensed
24 # under the Creative Commons License, Attribution 4.0 Intl. (the “License”);
25 # you may not use this documentation except in compliance with the License.
26 # You may obtain a copy of the License at
28 # https://creativecommons.org/licenses/by/4.0/
30 # Unless required by applicable law or agreed to in writing, documentation
31 # distributed under the License is distributed on an "AS IS" BASIS,
32 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
33 # See the License for the specific language governing permissions and
34 # limitations under the License.
36 # ============LICENSE_END============================================
38 # ECOMP is a trademark and service mark of AT&T Intellectual Property.
40 from .helpers import validates
44 def test_heat_template_structure(yaml_file):
46 Check that all heat templates only have the allowed sections
48 key_values = ["heat_template_version", "description",
49 "parameter_groups", "parameters", "resources",
50 "outputs", "conditions"]
52 with open(yaml_file) as fh:
54 assert all([k in key_values for k in yml])
57 @validates('R-27078', 'R-39402', 'R-35414')
58 def test_heat_template_structure_contains_required_sections(yaml_file):
60 Check that all heat templates have the required sections
62 required_key_values = ["heat_template_version", "description",
63 "parameters", "resources"]
65 with open(yaml_file) as fh:
67 assert all([k in yml for k in required_key_values])
70 def test_heat_template_structure_sections_have_the_right_format(yaml_file):
72 Check that all heat templates have sections of the right format.
73 Do note that it only tests for dicts or not dicts currently.
75 key_values = ["heat_template_version", "description",
76 "parameter_groups", "parameters", "resources",
77 "outputs", "conditions"]
78 key_values_not_dicts = ["heat_template_version", "description"]
80 with open(yaml_file) as fh:
86 should_not_be_dict = 0
87 for key_value in key_values:
89 if isinstance(yml[key_value], dict):
91 if key_value not in key_values_not_dicts:
93 elif not isinstance(yml[key_value], list):
95 if key_value in key_values_not_dicts:
96 should_not_be_dict += 1
97 assert (is_dict == should_be_dict and
98 is_not_dict == should_not_be_dict)
101 @validates('R-11441')
102 def test_parameter_type(yaml_file):
107 'comma_delimited_list',
110 with open(yaml_file) as fh:
112 for key, param in yml.get('parameters', {}).items():
113 assert isinstance(param, dict), '%s parameter %s is not dict' % (
116 assert 'type' in param, '%s parameter %s has no "type"' % (
120 assert typ in types, '%s parameter %s has invalid type "%s"' % (