summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--tests/data/openrc_conf/admin-openrc.sh9
-rw-r--r--tests/data/openrc_conf/globals.yml12
-rw-r--r--tests/data/openrc_conf/globals_odl.yml13
-rw-r--r--tests/post/test_keystoneauth.py20
-rw-r--r--tests/unit/post/test_keystoneauth.py82
-rw-r--r--tests/unit/post/test_post_execute.py (renamed from tests/post/test_post_execute.py)36
-rw-r--r--tests/unit/prepare/test_prepare_execure.py (renamed from tests/prepare/test_execute.py)12
7 files changed, 163 insertions, 21 deletions
diff --git a/tests/data/openrc_conf/admin-openrc.sh b/tests/data/openrc_conf/admin-openrc.sh
new file mode 100644
index 00000000..3db0bcf3
--- /dev/null
+++ b/tests/data/openrc_conf/admin-openrc.sh
@@ -0,0 +1,9 @@
+export OS_PROJECT_DOMAIN_NAME=Default
+export OS_USER_DOMAIN_NAME=Default
+export OS_PROJECT_NAME=admin
+export OS_TENANT_NAME=admin
+export OS_USERNAME=admin
+export OS_PASSWORD=keystone
+export OS_AUTH_URL=http://10.20.11.11:35357/v3
+export OS_INTERFACE=internal
+export OS_IDENTITY_API_VERSION=3
diff --git a/tests/data/openrc_conf/globals.yml b/tests/data/openrc_conf/globals.yml
new file mode 100644
index 00000000..6d663125
--- /dev/null
+++ b/tests/data/openrc_conf/globals.yml
@@ -0,0 +1,12 @@
+docker_namespace: kolla
+docker_registry: 10.20.11.2:4000
+enable_ceph: 'yes'
+enable_cinder: 'yes'
+keepalived_interface: ens9
+kolla_external_vip_interface: ens3
+kolla_internal_vip_address: 10.20.11.11
+network_interface: ens3
+neutron_external_interface: ens8
+openstack_release: 4.0.2
+storage_interface: ens3
+tunnel_interface: ens3
diff --git a/tests/data/openrc_conf/globals_odl.yml b/tests/data/openrc_conf/globals_odl.yml
new file mode 100644
index 00000000..50df4084
--- /dev/null
+++ b/tests/data/openrc_conf/globals_odl.yml
@@ -0,0 +1,13 @@
+docker_namespace: kolla
+docker_registry: 10.20.11.2:4000
+enable_ceph: 'yes'
+enable_cinder: 'yes'
+keepalived_interface: ens9
+kolla_external_vip_interface: ens3
+kolla_internal_vip_address: 10.20.11.11
+network_interface: ens3
+neutron_external_interface: ens8
+openstack_release: 4.0.2
+storage_interface: ens3
+tunnel_interface: ens3
+opendaylight_leader_ip_address: 10.20.7.3 \ No newline at end of file
diff --git a/tests/post/test_keystoneauth.py b/tests/post/test_keystoneauth.py
deleted file mode 100644
index 1b208952..00000000
--- a/tests/post/test_keystoneauth.py
+++ /dev/null
@@ -1,20 +0,0 @@
-##############################################################################
-# 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 pytest
-
-from deploy.post.keystoneauth import Keystoneauth
-
-
-@pytest.mark.parametrize('openrc, expected', [
- ('/etc/kolla/admin-openrc.sh', '/etc/kolla/admin-openrc.sh'),
- (None, '/etc/kolla/admin-openrc.sh')])
-def test_create_Keystoneauth_instance_(openrc, expected):
- KeystoneClient = Keystoneauth(openrc)
- assert KeystoneClient.openrc == expected
diff --git a/tests/unit/post/test_keystoneauth.py b/tests/unit/post/test_keystoneauth.py
new file mode 100644
index 00000000..afd9062a
--- /dev/null
+++ b/tests/unit/post/test_keystoneauth.py
@@ -0,0 +1,82 @@
+##############################################################################
+# 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.post.keystoneauth import Keystoneauth
+
+
+@pytest.mark.parametrize('openrc, expected', [
+ ('/etc/kolla/admin-openrc.sh', '/etc/kolla/admin-openrc.sh'),
+ (None, '/etc/kolla/admin-openrc.sh')])
+def test_create_Keystoneauth_instance(openrc, expected):
+ KeystoneClient = Keystoneauth(openrc)
+ assert KeystoneClient.openrc == expected
+
+
+@pytest.mark.parametrize('raws, expected', [
+ (
+ {
+ 'OS_USERNAME': 'admin',
+ 'OS_PASSWORD': 'keystone',
+ 'OS_AUTH_URL': 'http://10.20.11.11:35357/v3',
+ 'OS_TENANT_NAME': 'admin',
+ 'OS_USER_DOMAIN_NAME': 'Default',
+ 'OS_PROJECT_DOMAIN_NAME': 'Default',
+ 'OS_PROJECT_NAME': 'admin',
+ 'OS_INTERFACE': 'internal',
+ 'OS_IDENTITY_API_VERSION': 'region_name'
+ },
+ {
+ 'username': 'admin',
+ 'password': 'keystone',
+ 'auth_url': 'http://10.20.11.11:35357/v3',
+ 'tenant_name': 'admin',
+ 'user_domain_name': 'Default',
+ 'project_domain_name': 'Default',
+ 'project_name': 'admin'
+ }),
+ (
+ {
+ 'OS_USERNAME': 'admin',
+ 'OS_PASSWORD': 'keystone',
+ 'OS_AUTH_URL': 'http://10.20.11.11:35357/v3',
+ 'OS_TENANT_NAME': 'admin',
+ 'OS_USER_DOMAIN_NAME': 'Default',
+ 'OS_PROJECT_DOMAIN_NAME': 'Default',
+ 'OS_PROJECT_NAME': 'admin',
+ 'OS_ENDPOINT_TYPE': 'Default',
+ 'OS_REGION_NAME': 'Default'
+ },
+ {
+ 'username': 'admin',
+ 'password': 'keystone',
+ 'auth_url': 'http://10.20.11.11:35357/v3',
+ 'tenant_name': 'admin',
+ 'user_domain_name': 'Default',
+ 'project_domain_name': 'Default',
+ 'project_name': 'admin',
+ 'endpoint_type': 'Default',
+ 'region_name': 'Default'
+ }
+ )])
+def test__parse_credentials_in_Keystoneauth(raws, expected):
+ assert Keystoneauth._parse_credentials(raws) == expected
+
+
+@pytest.fixture(scope="session")
+def openrc_conf_file_dir(data_root):
+ return os.path.join(data_root, 'openrc_conf')
+
+
+def test_session(openrc_conf_file_dir):
+ openrc = os.path.join(openrc_conf_file_dir, 'admin-openrc.sh')
+ KeystoneClient = Keystoneauth(openrc)
+ assert KeystoneClient.session
diff --git a/tests/post/test_post_execute.py b/tests/unit/post/test_post_execute.py
index 38a67c0e..d614360c 100644
--- a/tests/post/test_post_execute.py
+++ b/tests/unit/post/test_post_execute.py
@@ -6,13 +6,17 @@
# which accompanies this distribution, and is available at
# http://www.apache.org/licenses/LICENSE-2.0
##############################################################################
+import shutil
+import os
+from deepdiff import DeepDiff
import pytest
from deploy.post.execute import (
_config_external_network,
_config_icmp_security_group_rule,
- _config_ssh_security_group_rule
+ _config_ssh_security_group_rule,
+ _config_kolla_admin_openrc
)
@@ -95,3 +99,33 @@ def test__config_icmp_security_group_rule(security_group_id, expected):
})])
def test__config_ssh_security_group_rule(security_group_id, expected):
assert _config_ssh_security_group_rule(security_group_id) == expected
+
+
+@pytest.fixture(scope="module")
+def openrc_conf_file_dir(data_root):
+ return os.path.join(data_root, 'openrc_conf')
+
+
+@pytest.mark.parametrize('globals_file_name', [
+ ('globals.yml'), ('globals_odl.yml')])
+def test__config_kolla_admin_openrc(globals_file_name, openrc_conf_file_dir, tmpdir):
+ src_globals_file_path = os.path.join(openrc_conf_file_dir, globals_file_name)
+ dst_globals_file_path = os.path.join(tmpdir.dirname, 'globals.yml')
+ shutil.copyfile(src_globals_file_path, dst_globals_file_path)
+
+ src_openrc_file_path = os.path.join(openrc_conf_file_dir, 'admin-openrc.sh')
+ dst_openrc_file_path = os.path.join(tmpdir.dirname, 'admin-openrc.sh')
+ shutil.copyfile(src_openrc_file_path, dst_openrc_file_path)
+
+ _config_kolla_admin_openrc(tmpdir.dirname)
+ src_openrc_lines = open(src_openrc_file_path, 'r').readlines()
+ dst_openrc_lines = open(dst_openrc_file_path, 'r').readlines()
+ if globals_file_name == 'globals.yml':
+ assert DeepDiff(src_openrc_lines, dst_openrc_lines, ignore_order=True) == {}
+ elif globals_file_name == 'globals_odl.yml':
+ diff = DeepDiff(src_openrc_lines, dst_openrc_lines, ignore_order=True)
+ assert len(diff) == 1 and diff.get('iterable_item_added') is not None
+ assert len(diff['iterable_item_added']) == 1
+ for val in diff['iterable_item_added'].values():
+ assert 'export SDN_CONTROLLER_IP' in val
+ tmpdir.remove()
diff --git a/tests/prepare/test_execute.py b/tests/unit/prepare/test_prepare_execure.py
index 6eb27025..9e72722d 100644
--- a/tests/prepare/test_execute.py
+++ b/tests/unit/prepare/test_prepare_execure.py
@@ -35,10 +35,20 @@ def conf_file_dir(data_root):
return os.path.join(data_root, 'lab_conf')
+def clear_tmp_dir(path):
+ filelist = os.listdir(path)
+ for file in filelist:
+ file_path = os.path.join(path, file)
+ if os.path.isfile(file_path):
+ os.remove(file_path)
+ os.rmdir(path)
+
+
def test__set_qemu_compute(kolla_conf_file_nov_path):
_set_qemu_compute()
exp_conf_file = os.path.join(kolla_conf_file_nov_path, 'nova-compute.conf')
assert os.path.isfile(exp_conf_file)
+ clear_tmp_dir(kolla_conf_file_nov_path)
def test__set_default_floating_pool(kolla_conf_file_nov_path, conf_file_dir):
@@ -46,6 +56,7 @@ def test__set_default_floating_pool(kolla_conf_file_nov_path, conf_file_dir):
_set_default_floating_pool(network_conf_file)
exp_conf_file = os.path.join(kolla_conf_file_nov_path, 'nova-api.conf')
assert os.path.isfile(exp_conf_file)
+ clear_tmp_dir(kolla_conf_file_nov_path)
def test__set_trusts_auth(kolla_conf_file_heat_dir):
@@ -53,3 +64,4 @@ def test__set_trusts_auth(kolla_conf_file_heat_dir):
exp_conf_file_1 = os.path.join(kolla_conf_file_heat_dir, 'heat-api.conf')
exp_conf_file_2 = os.path.join(kolla_conf_file_heat_dir, 'heat-engine.conf')
assert (os.path.isfile(exp_conf_file_1) and os.path.isfile(exp_conf_file_2))
+ clear_tmp_dir(kolla_conf_file_heat_dir)