[VVP] Allow base templates to not have resources
[vvp/validation-scripts.git] / ice_validator / tests / test_heat_template_structure.py
index 0d8242e..da2de5e 100644 (file)
@@ -1,12 +1,12 @@
 # -*- coding: utf8 -*-
-# ============LICENSE_START=======================================================
+# ============LICENSE_START====================================================
 # org.onap.vvp/validation-scripts
 # ===================================================================
 # Copyright © 2017 AT&T Intellectual Property. All rights reserved.
 # ===================================================================
 #
 # Unless otherwise specified, all software contained herein is licensed
-# under the Apache License, Version 2.0 (the “License”);
+# under the Apache License, Version 2.0 (the "License");
 # you may not use this software except in compliance with the License.
 # You may obtain a copy of the License at
 #
@@ -21,7 +21,7 @@
 #
 #
 # Unless otherwise specified, all documentation contained herein is licensed
-# under the Creative Commons License, Attribution 4.0 Intl. (the “License”);
+# under the Creative Commons License, Attribution 4.0 Intl. (the "License");
 # you may not use this documentation except in compliance with the License.
 # You may obtain a copy of the License at
 #
 #
 # ============LICENSE_END============================================
 #
-# ECOMP is a trademark and service mark of AT&T Intellectual Property.
 #
-from .helpers import validates
-import yaml
 
+"""Test heat template structure
+"""
+import pytest
 
-def test_heat_template_structure(yaml_file):
-    '''
-    Check that all heat templates only have the allowed sections
-    '''
-    key_values = ["heat_template_version", "description",
-                  "parameter_groups", "parameters", "resources",
-                  "outputs", "conditions"]
+from tests import cached_yaml as yaml
+from .helpers import validates, is_base_module, load_yaml
+
+VERSION = "1.2.0"
+
+# pylint: disable=invalid-name
+
+
+@validates("R-27078")
+def test_heat_template_structure_contains_heat_template_version(yaml_file):
+    """
+    Check that all heat templates have the required sections
+    """
+    required_key_values = ["heat_template_version"]
 
     with open(yaml_file) as fh:
         yml = yaml.load(fh)
-    assert any(map(lambda v: v in yml, 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]
+    )
 
 
-@validates('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 any(map(lambda v: v in yml, 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):
-    '''
-    Check that all heat templates have sections of the right format.
-    Do note that it only tests for dicts or not dicts currently.
-    '''
-    key_values = ["heat_template_version", "description",
-                  "parameter_groups", "parameters", "resources",
-                  "outputs", "conditions"]
-    key_values_not_dicts = ["heat_template_version", "description"]
+@validates("R-35414")
+def test_heat_template_structure_contains_parameters(yaml_file):
+    """
+    Check that all heat templates have the required sections
+    """
+    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
+    """
+    if is_base_module(heat_template):
+        pytest.skip("Not applicable to base modules")
+    template = load_yaml(heat_template)
+    assert "resources" in template, "This template must contain a resources section"
+
+
+@validates("R-11441")
+def test_parameter_type(yaml_file):
+    """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():
+        assert isinstance(param, dict), "%s parameter %s is not dict" % (yaml_file, key)
+        if "type" not in param:
+            continue
+        typ = param["type"]
+        assert typ in types, '%s parameter %s has invalid type "%s"' % (
+            yaml_file,
+            key,
+            typ,
+        )