From 1f4df7c7ad27b23773ad9cdbe4db1632ce388cf1 Mon Sep 17 00:00:00 2001 From: "stark, steven" Date: Mon, 17 Dec 2018 12:43:02 -0800 Subject: [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 --- ice_validator/tests/test_resource_indices.py | 84 ++++++++++++++++++++++++++++ 1 file changed, 84 insertions(+) create mode 100644 ice_validator/tests/test_resource_indices.py (limited to 'ice_validator/tests/test_resource_indices.py') diff --git a/ice_validator/tests/test_resource_indices.py b/ice_validator/tests/test_resource_indices.py new file mode 100644 index 0000000..8e92567 --- /dev/null +++ b/ice_validator/tests/test_resource_indices.py @@ -0,0 +1,84 @@ +# -*- coding: utf8 -*- +# ============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"); +# you may not use this software except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# +# +# +# Unless otherwise specified, all documentation contained herein is licensed +# 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 +# +# https://creativecommons.org/licenses/by/4.0/ +# +# Unless required by applicable law or agreed to in writing, documentation +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +# +# ============LICENSE_END============================================ +# +import collections +from itertools import chain +from .structures import Heat +from .helpers import validates + + +def has_next(seq, index): + """ + Returns true if there is at least one more item after the current + index in the sequence + """ + next_index = index + 1 + return len(seq) > next_index + + +@validates("R-11690") +def test_indices_start_at_0_increment(yaml_files): + resources_ids = chain.from_iterable(Heat(f).resources.keys() for f in yaml_files) + prefix_indices = collections.defaultdict(set) + for r_id in resources_ids: + parts = r_id.split("_") + prefix_parts = [] + for i, part in enumerate(parts): + if part.isdigit(): + # It's an index so let's record it and its prefix + prefix = "_".join(prefix_parts) + "_" + index = int(part) + prefix_indices[prefix].add(index) + prefix_parts.append(part) + errors = [] + for prefix, indices in prefix_indices.items(): + indices = sorted(indices) + if indices[0] != 0: + errors.append( + ( + "Index values associated with resource ID " + + "prefix {} do not start at 0".format(prefix) + ) + ) + elif indices[-1] != (len(indices) - 1): + errors.append( + ( + "Index values associated with resource ID " + + "prefix {} are not contiguous: {}" + ).format(prefix, indices) + ) + assert not errors, ". ".join(errors) -- cgit 1.2.3-korg