summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorstark, steven <steven.stark@att.com>2019-05-02 08:50:11 -0700
committerstark, steven <steven.stark@att.com>2019-05-02 08:50:11 -0700
commitb4faced895883a6a6f93bec02d7df4b165a6e75c (patch)
tree96e37c32cd42104246b5d66a4e814116f688a47a
parent7a7bc66879f2efd93be2ebbd959176a10b07f74f (diff)
[VVP] adding list support for non-server-name uniqueness
Change-Id: I9990cc0f3535df96f1ea7679fb87aea36398f433 Issue-ID: VVP-179 Signed-off-by: stark, steven <steven.stark@att.com>
-rw-r--r--ice_validator/tests/fixtures/test_non_server_name/pass/pass0.yaml20
-rw-r--r--ice_validator/tests/structures.py12
2 files changed, 29 insertions, 3 deletions
diff --git a/ice_validator/tests/fixtures/test_non_server_name/pass/pass0.yaml b/ice_validator/tests/fixtures/test_non_server_name/pass/pass0.yaml
index ca80c87..267d0b2 100644
--- a/ice_validator/tests/fixtures/test_non_server_name/pass/pass0.yaml
+++ b/ice_validator/tests/fixtures/test_non_server_name/pass/pass0.yaml
@@ -52,6 +52,26 @@ parameters:
resources:
+ testr0:
+ type: testr
+ properties:
+ name:
+ str_replace:
+ template: vnfname_param
+ params:
+ vnfname: { get_param: vnf_name }
+ param: { get_param: [params, 0]}
+
+ testr1:
+ type: testr
+ properties:
+ name:
+ str_replace:
+ template: vnfname_param
+ params:
+ vnfname: { get_param: vnf_name }
+ param: { get_param: [params, 1]}
+
vm_typeX_0_bialy_port_2:
type: OS::Neutron::Port
properties:
diff --git a/ice_validator/tests/structures.py b/ice_validator/tests/structures.py
index e81f3a1..a6b2015 100644
--- a/ice_validator/tests/structures.py
+++ b/ice_validator/tests/structures.py
@@ -85,13 +85,19 @@ class HeatProcessor(object):
# regex parses the proper resource id format.
@staticmethod
- def get_param_value(value):
+ def get_param_value(value, withIndex=False):
"""Return get_param value of `value`
"""
if isinstance(value, dict) and len(value) == 1:
v = value.get("get_param")
if isinstance(v, list) and v:
- v = v[0]
+ if withIndex and len(v) > 1:
+ idx = v[1]
+ if isinstance(idx, dict):
+ idx = idx.get("get_param", idx)
+ v = "{}{}".format(v[0], idx)
+ else:
+ v = v[0]
else:
v = None
return v
@@ -161,7 +167,7 @@ class HeatProcessor(object):
# are replaced in the template in arbitrary order.
name = template
for key, value in params.items():
- param = cls.get_param_value(value)
+ param = cls.get_param_value(value, withIndex=True)
if param is None:
return None
name = name.replace(key, str(param))