aboutsummaryrefslogtreecommitdiffstats
path: root/ice_validator/tests/test_network_format_use_get_param_or_get_resource.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_network_format_use_get_param_or_get_resource.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_network_format_use_get_param_or_get_resource.py')
-rw-r--r--ice_validator/tests/test_network_format_use_get_param_or_get_resource.py45
1 files changed, 32 insertions, 13 deletions
diff --git a/ice_validator/tests/test_network_format_use_get_param_or_get_resource.py b/ice_validator/tests/test_network_format_use_get_param_or_get_resource.py
index 98d4401..dada3e5 100644
--- a/ice_validator/tests/test_network_format_use_get_param_or_get_resource.py
+++ b/ice_validator/tests/test_network_format_use_get_param_or_get_resource.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
@@ -44,12 +44,12 @@ from tests import cached_yaml as yaml
from .helpers import validates
-@validates('R-93177')
+@validates("R-93177")
def test_network_format_use_get_param_or_get_resource(heat_template):
- '''
+ """
Make sure all network properties only use get_param
or get_resource of an internal network
- '''
+ """
with open(heat_template) as fh:
yml = yaml.load(fh)
@@ -58,7 +58,8 @@ def test_network_format_use_get_param_or_get_resource(heat_template):
if "resources" not in yml:
pytest.skip("No resources specified in the heat template")
- invalid_ports = []
+ invalid_get_resource = []
+ invalid_get_param = []
for k1, v1 in yml["resources"].items():
if not isinstance(v1, dict):
continue
@@ -67,17 +68,35 @@ def test_network_format_use_get_param_or_get_resource(heat_template):
if v1.get("type") != "OS::Neutron::Port":
continue
- valid_network = True
for k2, v2 in v1["properties"].items():
if k2 != "network":
continue
- if "get_resource" in v2:
- if not v2["get_resource"].startswith('int_'):
- valid_network = False
+ if not isinstance(v2, dict):
+ invalid_get_param.append(k1)
+ elif "get_resource" in v2:
+ if not v2["get_resource"].startswith("int_"):
+ invalid_get_resource.append(k1)
elif "get_param" not in v2:
- valid_network = False
+ invalid_get_param.append(k1)
+ # TODO: I don't think this test needs to check get_param as that is
+ # already covered by another test.
- if not valid_network:
- invalid_ports.append(k1)
+ msg = (
+ "A OS::Neutron::Port must connect to an internal network using "
+ "get_resource (network created in same template) or get_param "
+ "(network created in a different template)."
+ )
+ if invalid_get_resource:
+ msg = (
+ msg
+ + " These resources use get_resource to connect to a "
+ + "non-internal network: {}"
+ ).format(", ".join(invalid_get_resource))
+ if invalid_get_param:
+ msg = (
+ msg
+ + " These resources do not use get_resource or get_param "
+ + "to connect to a network: {}"
+ ).format(", ".join(invalid_get_param))
- assert not set(invalid_ports)
+ assert not (invalid_get_param or invalid_get_resource), msg