diff options
author | zhongjun <zhong.jun@zte.com.cn> | 2017-08-31 21:52:03 +0800 |
---|---|---|
committer | zhongjun <zhong.jun@zte.com.cn> | 2017-08-31 22:14:58 +0800 |
commit | 814729059a385d5edb0c19347b3dfa76930220a5 (patch) | |
tree | aad882cbea94f7d7ced43d73430ae265b6d2802d /tests/unit/config | |
parent | 91b18eadfb2ca83d9291281210342dfefa7694b2 (diff) |
Add some unit test files test_netwrok.py
1.add the below unit test files:
test_netwrok.py/test_schemas.py/test_query.py/test_utils.py
2.add the corresponding test conf file deploy_virtual_error.yml.
Change-Id: I01292d4c94b9d6159597961a0cab515f57727ec3
Signed-off-by: zhongjun <zhong.jun@zte.com.cn>
Diffstat (limited to 'tests/unit/config')
-rw-r--r-- | tests/unit/config/test_network.py | 97 | ||||
-rw-r--r-- | tests/unit/config/test_schemas.py | 33 |
2 files changed, 130 insertions, 0 deletions
diff --git a/tests/unit/config/test_network.py b/tests/unit/config/test_network.py new file mode 100644 index 00000000..98107929 --- /dev/null +++ b/tests/unit/config/test_network.py @@ -0,0 +1,97 @@ +############################################################################## +# Copyright (c) 2017 ZTE Corp and others. +# +# All rights reserved. This program and the accompanying materials +# are made available under the terms of the Apache License, Version 2.0 +# which accompanies this distribution, and is available at +# http://www.apache.org/licenses/LICENSE-2.0 +############################################################################## +import os + +import pytest + +from deploy.config.network import NetworkConfig + + +@pytest.fixture(scope="session") +def conf_file_dir(data_root): + return os.path.join(data_root, 'lab_conf') + + +@pytest.mark.parametrize('network_file_name, metadatas, networks, interfaces, internal_vip, public_vip', [ + ('network_virtual1.yml', + {'title': 'zte-virtual1 network config', + 'version': '0.1', + 'created': 'Tue Apr 11 2017', + 'comment': 'five vm node deploy'}, + [{'cidr': '10.20.11.0/24', 'gateway': '10.20.11.1', + 'ip_ranges': [{'start': '10.20.11.3', 'end': '10.20.11.10'}], + 'name': 'MANAGEMENT'}, + {'cidr': '10.20.11.0/24', 'gateway': '10.20.11.1', + 'ip_ranges': [{'start': '10.20.11.3', 'end': '10.20.11.10'}], + 'name': 'STORAGE'}, + {'cidr': '172.10.101.0/24', 'gateway': '172.10.101.1', + 'ip_ranges': [{'start': '172.10.101.2', 'end': '172.10.101.20'}], + 'name': 'EXTERNAL', 'network_name': 'admin_external', 'mapping': 'physnet1'}, + {'cidr': '10.20.11.0/24', 'gateway': '10.20.11.1', + 'ip_ranges': [{'start': '10.20.11.3', 'end': '10.20.11.10'}], + 'name': 'PUBLICAPI'}, + {'cidr': '10.20.11.0/24', 'gateway': '10.20.11.1', + 'ip_ranges': [{'start': '10.20.11.3', 'end': '10.20.11.10'}], + 'name': 'TENANT'}, + {'cidr': '100.20.11.0/24', 'gateway': '100.20.11.1', + 'ip_ranges': [{'start': '100.20.11.3', 'end': '100.20.11.10'}], + 'name': 'HEARTBEAT'}], + [{'name': 'EXTERNAL', 'interface': 'ens8'}, + {'name': 'MANAGEMENT', 'interface': 'ens3'}, + {'name': 'PUBLICAPI', 'interface': 'ens3'}, + {'name': 'STORAGE', 'interface': 'ens3'}, + {'name': 'TENANT', 'interface': 'ens3'}, + {'name': 'HEARTBEAT', 'interface': 'ens9'}], + '10.20.11.11', + '10.20.11.11')]) +def test_create_NetworkConf_instance(conf_file_dir, network_file_name, metadatas, + networks, interfaces, internal_vip, public_vip): + type2name = { + 'EXTERNAL': 'ext', + 'MANAGEMENT': 'man', + 'STORAGE': 'stor', + 'PUBLICAPI': 'pub', + 'TENANT': 'tenant', + 'HEARTBEAT': 'hbt', + } + + network_file_path = os.path.join(conf_file_dir, network_file_name) + NetworkConfClient = NetworkConfig(network_file_path) + assert NetworkConfClient._file == network_file_path + + for key, val in metadatas.iteritems(): + assert getattr(NetworkConfClient, key) == val + for network in networks: + name = network['name'] + mapname = type2name[name] + assert getattr(NetworkConfClient, mapname) == network + for net_key, net_val in network.iteritems(): + net_name = '{}_{}'.format(mapname, net_key) + assert getattr(NetworkConfClient, net_name) == net_val + + for interface in interfaces: + name = interface['name'] + mapname = type2name[name] + interface_name = '{}_{}'.format(mapname, 'iterface') + assert getattr(NetworkConfClient, interface_name) == interface['interface'] + + assert getattr(NetworkConfClient, 'internal_vip') == internal_vip + assert getattr(NetworkConfClient, 'public_vip') == public_vip + + +@pytest.mark.parametrize('network_file_name, name, expected', [ + ('network_virtual1.yml', 'EXTERNAL', + {'cidr': '172.10.101.0/24', 'gateway': '172.10.101.1', + 'ip_ranges': [{'start': '172.10.101.2', 'end': '172.10.101.20'}], + 'name': 'EXTERNAL', 'network_name': 'admin_external', 'mapping': 'physnet1'}), + ('network_virtual1.yml', 'NO_EXIT', None)]) +def test__get_network_NetworkConf(conf_file_dir, network_file_name, name, expected): + network_file_path = os.path.join(conf_file_dir, network_file_name) + NetworkConfClient = NetworkConfig(network_file_path) + assert NetworkConfClient._get_network(name) == expected diff --git a/tests/unit/config/test_schemas.py b/tests/unit/config/test_schemas.py new file mode 100644 index 00000000..04705fda --- /dev/null +++ b/tests/unit/config/test_schemas.py @@ -0,0 +1,33 @@ +############################################################################## +# Copyright (c) 2017 ZTE Corp and others. +# +# All rights reserved. This program and the accompanying materials +# are made available under the terms of the Apache License, Version 2.0 +# which accompanies this distribution, and is available at +# http://www.apache.org/licenses/LICENSE-2.0 +############################################################################## +import os + +import yaml +import pytest + +from deploy.config.schemas import ( + deploy_schema_validate +) + + +@pytest.fixture(scope="session") +def conf_file_dir(data_root): + return os.path.join(data_root, 'lab_conf') + + +@pytest.mark.parametrize('deploy_file_name', [ + ('deploy_virtual1.yml'), + ('deploy_virtual_error.yml')]) +def test_deploy_schema_validate(conf_file_dir, deploy_file_name): + data = yaml.safe_load(open(os.path.join(conf_file_dir, deploy_file_name), 'r')) + errors = deploy_schema_validate(data) + if deploy_file_name == 'deploy_virtual1.yml': + assert errors == [] + elif deploy_file_name == 'deploy_virtual_error.yml': + assert errors != [] |