diff options
author | stark, steven <steven.stark@att.com> | 2019-01-28 14:59:01 -0800 |
---|---|---|
committer | stark, steven <steven.stark@att.com> | 2019-01-29 08:03:41 -0800 |
commit | 48a07b6942d3956666d30947372653feb702fdae (patch) | |
tree | 5a5fc3135f2703ad19543b78e661ea954e98bb33 /ice_validator/tests/test_server_and_port_vm_indices_match.py | |
parent | 43130f8b173d9053ad4f56f264376851d3fb890c (diff) |
[VVP] stand alone tool, script updates
1) Validation script updates:
Various bug fixes and script enhancements
New tests for:
R-18683
R-94669
R-304011
R-01455
R-86476
R-708564
R-85734
R-18683
R-94669
R-304011
R-01455
R-86476
R-86476
R-589037
Removed tests for:
R-75202
R-62954
R-22441
R-49177
R-16576
R-86237
R-44491
R-70757
R-01896
R-26124
2) Stand Alone tool introduced
3) Added optional "categories" capability
Change-Id: I193cd5c267750791d97b350e91fc36faa72d8d5f
Issue-ID: VVP-143
Signed-off-by: stark, steven <steven.stark@att.com>
Diffstat (limited to 'ice_validator/tests/test_server_and_port_vm_indices_match.py')
-rw-r--r-- | ice_validator/tests/test_server_and_port_vm_indices_match.py | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/ice_validator/tests/test_server_and_port_vm_indices_match.py b/ice_validator/tests/test_server_and_port_vm_indices_match.py new file mode 100644 index 0000000..20423bb --- /dev/null +++ b/ice_validator/tests/test_server_and_port_vm_indices_match.py @@ -0,0 +1,84 @@ +# -*- coding: utf8 -*- +# ============LICENSE_START======================================================= +# org.onap.vvp/validation-scripts +# =================================================================== +# Copyright © 2019 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 re + +from tests.helpers import validates +from tests.structures import Heat +from tests.utils import nested_dict + +SERVER_ID_PATTERN = re.compile(r"\w+_server_(\d+)") +PORT_ID_PATTERN = re.compile(r"\w+_(\d+)_\w+\d+") + + +def get_ports(server): + props = server.get("properties") or {} + networks = props.get("networks") or [] + for network in networks: + r_id = nested_dict.get(network, "port", "get_resource") + if r_id: + yield r_id + + +@validates("R-304011") +def test_server_and_port_vmtype_indices_match(yaml_file): + # NOTE: This test is only going to validate that the index values + # match between the between the ports and server names. Other + # tests already cover the other aspects of this requirement + + heat = Heat(filepath=yaml_file) + servers = heat.get_resource_by_type("OS::Nova::Server") + errors = [] + for r_id, server in servers.items(): + match = SERVER_ID_PATTERN.match(r_id) + if not match: + continue # other tests cover valid server ID format + server_index = match.group(1) + ports = get_ports(server) + for port in ports: + port_match = PORT_ID_PATTERN.match(port) + if port_match: + port_vm_index = port_match.group(1) + if port_vm_index != server_index: + errors.append( + ( + "{{vm-type_index}} ({}) in port ID ({}) " + + "does not match the {{index}} ({}) in the " + + "servers resource ID ({})" + ).format(port_vm_index, port, server_index, r_id) + ) + assert not errors, ". ".join(errors) |