[VVP] Performance Enhancements (report generation and test collection)
[vvp/validation-scripts.git] / ice_validator / tests / test_volume_templates.py
index d30ee19..634da5c 100644 (file)
@@ -6,7 +6,7 @@
 # ===================================================================
 #
 # 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 tests import cached_yaml as yaml
 
-import yaml
+from .helpers import validates
+from .utils.nested_files import get_list_of_nested_files
+
+import os
 import pytest
 
 
-def test_volume_templates_only_contains_cinder(volume_template):
-    '''
+@validates("R-270358")
+def test_volume_templates_contains_cinder_or_resource_group(volume_template):
+    """
     Check that all templates marked as volume templates are
     in fact volume templates
-    '''
+    """
+    acceptable_resources = []
+    dirname = os.path.dirname(volume_template)
+    list_of_files = get_list_of_nested_files(volume_template, dirname)
+
+    list_of_files.append(volume_template)
+
+    for file in list_of_files:
+        with open(file) as fh:
+            yml = yaml.load(fh)
+        resources = yml.get("resources") or {}
+        for k, v in resources.items():
+            if not isinstance(v, dict):
+                continue
+            if "type" not in v:
+                continue
+            if v["type"] in ["OS::Cinder::Volume", "OS::Heat::ResourceGroup"]:
+                acceptable_resources.append(k)
+
+    assert acceptable_resources, (
+        "No OS::Cinder::Volume or OS::Heat::ResourceGroup resources "
+        "found in volume module"
+    )
+
+
+@validates("R-55306")
+def test_no_vf_module_index_in_cinder(volume_template):
+    """
+    vf_module_index is prohibited in volume templates
+    """
+
     with open(volume_template) as fh:
         yml = yaml.load(fh)
 
-    # skip if resources are not defined
-    if "resources" not in yml:
-        pytest.skip("No resources specified in the heat template")
-
-    non_volumes = []
-    for k, v in yml["resources"].items():
-        if not isinstance(v, dict):
-            continue
-        if "type" not in v:
-            continue
-        if v["type"] not in ["OS::Cinder::Volume",
-                             "OS::Heat::ResourceGroup"]:
-            non_volumes.append(k)
+    if "parameters" not in yml:
+        pytest.skip("No parameters specified in the heat template")
 
-    assert not set(non_volumes)
+    parameters = yml.get("parameters")
+    if parameters and isinstance(parameters, dict):
+        assert (
+            "vf_module_index" not in parameters
+        ), "{} must not use vf_module_index as a parameter".format(volume_template)