aboutsummaryrefslogtreecommitdiffstats
path: root/ice_validator/tests/test_nova_servergroup_policies.py
diff options
context:
space:
mode:
authorstark, steven <steven.stark@att.com>2018-12-17 12:43:02 -0800
committerstark, steven <steven.stark@att.com>2018-12-17 13:04:00 -0800
commit1f4df7c7ad27b23773ad9cdbe4db1632ce388cf1 (patch)
tree8092104f8be23051ff81c9f71ee34116df4d33ba /ice_validator/tests/test_nova_servergroup_policies.py
parentca9085f0f77d442d3741a8c754e65cc45b6a318d (diff)
[VVP] updating validation scripts in dublin
- adding backlog of new validation scripts for dublin - updating existing tests - removing outdated tests Issue-ID: VVP-123 Change-Id: Ib8260889ac957c1dd28d8ede450fc8edc6fb0ec0 Signed-off-by: stark, steven <steven.stark@att.com>
Diffstat (limited to 'ice_validator/tests/test_nova_servergroup_policies.py')
-rw-r--r--ice_validator/tests/test_nova_servergroup_policies.py32
1 files changed, 20 insertions, 12 deletions
diff --git a/ice_validator/tests/test_nova_servergroup_policies.py b/ice_validator/tests/test_nova_servergroup_policies.py
index 6a49822..4e67f58 100644
--- a/ice_validator/tests/test_nova_servergroup_policies.py
+++ b/ice_validator/tests/test_nova_servergroup_policies.py
@@ -2,7 +2,7 @@
# ============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
@@ -43,11 +43,11 @@ import pytest
def test_nova_servergroup_policies(yaml_file):
- '''
+ """
Check that nova servergroup resources using either anti-affinity or
affinity rules in policies
- '''
- req_rules = ['affinity', 'anti-affinity']
+ """
+ req_rules = ["affinity", "anti-affinity"]
with open(yaml_file) as fh:
yml = yaml.load(fh)
@@ -56,8 +56,8 @@ def test_nova_servergroup_policies(yaml_file):
if "resources" not in yml:
pytest.skip("No resources specified in the heat template")
- has_req_rules = []
- for v1 in yml["resources"].values():
+ invalid_policies = []
+ for r_id, v1 in yml["resources"].items():
if not isinstance(v1, dict):
continue
if "properties" not in v1:
@@ -70,11 +70,19 @@ def test_nova_servergroup_policies(yaml_file):
try:
all_rules = v1["properties"]["policies"]
detected_rules = set(all_rules) & set(req_rules)
- has_req_rules.append(len(detected_rules) > 0)
- except (ValueError):
+ if len(detected_rules) == 0:
+ invalid_policies.append(
+ "{} policies must include one of {}".format(
+ r_id, ", ".join(req_rules)
+ )
+ )
+ elif len(detected_rules) > 1:
+ invalid_policies.append(
+ "{} policies must include only one of {}".format(
+ r_id, ", ".join(req_rules)
+ )
+ )
+ except ValueError:
continue
- if not has_req_rules:
- pytest.skip("No policies Nova::ServerGroup instances were detected")
-
- assert all(has_req_rules)
+ assert not invalid_policies, ". ".join(invalid_policies)