Move ssh_utils tests to test_ssh_utils
The code was split from utils.py a bit ago, should move the tests as well. Change-Id: Ifff9d3f6eb8d3c1669102c06b040654be139ccd6
This commit is contained in:
parent
867fccf833
commit
77b5519b2f
297
cinder/tests/unit/test_ssh_utils.py
Normal file
297
cinder/tests/unit/test_ssh_utils.py
Normal file
@ -0,0 +1,297 @@
|
||||
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||
# not use this file 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.
|
||||
|
||||
|
||||
import mock
|
||||
import paramiko
|
||||
import uuid
|
||||
|
||||
from oslo_config import cfg
|
||||
|
||||
from cinder import exception
|
||||
from cinder import ssh_utils
|
||||
from cinder import test
|
||||
|
||||
CONF = cfg.CONF
|
||||
|
||||
|
||||
class FakeSock(object):
|
||||
def settimeout(self, timeout):
|
||||
pass
|
||||
|
||||
|
||||
class FakeTransport(object):
|
||||
|
||||
def __init__(self):
|
||||
self.active = True
|
||||
self.sock = FakeSock()
|
||||
|
||||
def set_keepalive(self, timeout):
|
||||
pass
|
||||
|
||||
def is_active(self):
|
||||
return self.active
|
||||
|
||||
|
||||
class FakeSSHClient(object):
|
||||
|
||||
def __init__(self):
|
||||
self.id = uuid.uuid4()
|
||||
self.transport = FakeTransport()
|
||||
|
||||
def set_missing_host_key_policy(self, policy):
|
||||
self.policy = policy
|
||||
|
||||
def load_system_host_keys(self):
|
||||
self.system_host_keys = 'system_host_keys'
|
||||
|
||||
def load_host_keys(self, hosts_key_file):
|
||||
self.hosts_key_file = hosts_key_file
|
||||
|
||||
def connect(self, ip, port=22, username=None, password=None,
|
||||
pkey=None, timeout=10):
|
||||
pass
|
||||
|
||||
def get_transport(self):
|
||||
return self.transport
|
||||
|
||||
def get_policy(self):
|
||||
return self.policy
|
||||
|
||||
def get_host_keys(self):
|
||||
return '127.0.0.1 ssh-rsa deadbeef'
|
||||
|
||||
def close(self):
|
||||
pass
|
||||
|
||||
def __call__(self, *args, **kwargs):
|
||||
pass
|
||||
|
||||
|
||||
class SSHPoolTestCase(test.TestCase):
|
||||
"""Unit test for SSH Connection Pool."""
|
||||
@mock.patch('cinder.ssh_utils.CONF')
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
@mock.patch('os.path.isfile', return_value=True)
|
||||
def test_ssh_default_hosts_key_file(self, mock_isfile, mock_sshclient,
|
||||
mock_open, mock_conf):
|
||||
mock_ssh = mock.MagicMock()
|
||||
mock_sshclient.return_value = mock_ssh
|
||||
mock_conf.ssh_hosts_key_file = '/var/lib/cinder/ssh_known_hosts'
|
||||
|
||||
# create with customized setting
|
||||
sshpool = ssh_utils.SSHPool("127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
|
||||
host_key_files = sshpool.hosts_key_file
|
||||
|
||||
self.assertEqual('/var/lib/cinder/ssh_known_hosts', host_key_files)
|
||||
|
||||
mock_ssh.load_host_keys.assert_called_once_with(
|
||||
'/var/lib/cinder/ssh_known_hosts')
|
||||
|
||||
@mock.patch('cinder.ssh_utils.CONF')
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
@mock.patch('os.path.isfile', return_value=True)
|
||||
def test_ssh_host_key_file_kwargs(self, mock_isfile, mock_sshclient,
|
||||
mock_open, mock_conf):
|
||||
mock_ssh = mock.MagicMock()
|
||||
mock_sshclient.return_value = mock_ssh
|
||||
mock_conf.ssh_hosts_key_file = '/var/lib/cinder/ssh_known_hosts'
|
||||
|
||||
# create with customized setting
|
||||
sshpool = ssh_utils.SSHPool("127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=1,
|
||||
hosts_key_file='dummy_host_keyfile')
|
||||
|
||||
host_key_files = sshpool.hosts_key_file
|
||||
|
||||
self.assertIn('dummy_host_keyfile', host_key_files)
|
||||
self.assertIn('/var/lib/cinder/ssh_known_hosts', host_key_files)
|
||||
|
||||
expected = [
|
||||
mock.call.load_host_keys('dummy_host_keyfile'),
|
||||
mock.call.load_host_keys('/var/lib/cinder/ssh_known_hosts')]
|
||||
|
||||
mock_ssh.assert_has_calls(expected, any_order=True)
|
||||
|
||||
@mock.patch('cinder.ssh_utils.CONF')
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('os.path.isfile', return_value=True)
|
||||
@mock.patch('paramiko.RSAKey.from_private_key_file')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
def test_single_ssh_connect(self, mock_sshclient, mock_pkey, mock_isfile,
|
||||
mock_open, mock_conf):
|
||||
mock_conf.ssh_hosts_key_file = '/var/lib/cinder/ssh_known_hosts'
|
||||
|
||||
# create with password
|
||||
sshpool = ssh_utils.SSHPool("127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
with sshpool.item() as ssh:
|
||||
first_id = ssh.id
|
||||
|
||||
with sshpool.item() as ssh:
|
||||
second_id = ssh.id
|
||||
|
||||
self.assertEqual(first_id, second_id)
|
||||
self.assertEqual(1, mock_sshclient.return_value.connect.call_count)
|
||||
|
||||
# create with private key
|
||||
sshpool = ssh_utils.SSHPool("127.0.0.1", 22, 10,
|
||||
"test",
|
||||
privatekey="test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
self.assertEqual(2, mock_sshclient.return_value.connect.call_count)
|
||||
|
||||
# attempt to create with no password or private key
|
||||
self.assertRaises(paramiko.SSHException,
|
||||
ssh_utils.SSHPool,
|
||||
"127.0.0.1", 22, 10,
|
||||
"test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
def test_closed_reopened_ssh_connections(self, mock_sshclient, mock_open):
|
||||
mock_sshclient.return_value = eval('FakeSSHClient')()
|
||||
sshpool = ssh_utils.SSHPool("127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=4)
|
||||
with sshpool.item() as ssh:
|
||||
mock_sshclient.reset_mock()
|
||||
first_id = ssh.id
|
||||
|
||||
with sshpool.item() as ssh:
|
||||
second_id = ssh.id
|
||||
ssh.get_transport().active = False
|
||||
sshpool.remove(ssh)
|
||||
|
||||
self.assertEqual(first_id, second_id)
|
||||
|
||||
# create a new client
|
||||
mock_sshclient.return_value = FakeSSHClient()
|
||||
with sshpool.item() as ssh:
|
||||
third_id = ssh.id
|
||||
|
||||
self.assertNotEqual(first_id, third_id)
|
||||
|
||||
@mock.patch('cinder.ssh_utils.CONF')
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
def test_missing_ssh_hosts_key_config(self, mock_sshclient, mock_open,
|
||||
mock_conf):
|
||||
mock_sshclient.return_value = FakeSSHClient()
|
||||
|
||||
mock_conf.ssh_hosts_key_file = None
|
||||
# create with password
|
||||
self.assertRaises(exception.ParameterNotFound,
|
||||
ssh_utils.SSHPool,
|
||||
"127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
def test_create_default_known_hosts_file(self, mock_sshclient,
|
||||
mock_open):
|
||||
mock_sshclient.return_value = FakeSSHClient()
|
||||
|
||||
CONF.state_path = '/var/lib/cinder'
|
||||
CONF.ssh_hosts_key_file = '/var/lib/cinder/ssh_known_hosts'
|
||||
|
||||
default_file = '/var/lib/cinder/ssh_known_hosts'
|
||||
|
||||
ssh_pool = ssh_utils.SSHPool("127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
|
||||
with ssh_pool.item() as ssh:
|
||||
mock_open.assert_called_once_with(default_file, 'a')
|
||||
ssh_pool.remove(ssh)
|
||||
|
||||
@mock.patch('os.path.isfile', return_value=False)
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
def test_ssh_missing_hosts_key_file(self, mock_sshclient, mock_open,
|
||||
mock_isfile):
|
||||
mock_sshclient.return_value = FakeSSHClient()
|
||||
|
||||
CONF.ssh_hosts_key_file = '/tmp/blah'
|
||||
|
||||
self.assertNotIn(CONF.state_path, CONF.ssh_hosts_key_file)
|
||||
self.assertRaises(exception.InvalidInput,
|
||||
ssh_utils.SSHPool,
|
||||
"127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
|
||||
@mock.patch.multiple('cinder.ssh_utils.CONF',
|
||||
strict_ssh_host_key_policy=True,
|
||||
ssh_hosts_key_file='/var/lib/cinder/ssh_known_hosts')
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
@mock.patch('os.path.isfile', return_value=True)
|
||||
def test_ssh_strict_host_key_policy(self, mock_isfile, mock_sshclient,
|
||||
mock_open):
|
||||
mock_sshclient.return_value = FakeSSHClient()
|
||||
|
||||
# create with customized setting
|
||||
sshpool = ssh_utils.SSHPool("127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
|
||||
with sshpool.item() as ssh:
|
||||
self.assertTrue(isinstance(ssh.get_policy(),
|
||||
paramiko.RejectPolicy))
|
||||
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
@mock.patch('os.path.isfile', return_value=True)
|
||||
def test_ssh_not_strict_host_key_policy(self, mock_isfile, mock_sshclient,
|
||||
mock_open):
|
||||
mock_sshclient.return_value = FakeSSHClient()
|
||||
|
||||
CONF.strict_ssh_host_key_policy = False
|
||||
|
||||
# create with customized setting
|
||||
sshpool = ssh_utils.SSHPool("127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
|
||||
with sshpool.item() as ssh:
|
||||
self.assertTrue(isinstance(ssh.get_policy(),
|
||||
paramiko.AutoAddPolicy))
|
@ -17,19 +17,16 @@ import datetime
|
||||
import functools
|
||||
import os
|
||||
import time
|
||||
import uuid
|
||||
|
||||
import mock
|
||||
from oslo_concurrency import processutils as putils
|
||||
from oslo_config import cfg
|
||||
from oslo_utils import timeutils
|
||||
import paramiko
|
||||
import six
|
||||
from six.moves import range
|
||||
|
||||
import cinder
|
||||
from cinder import exception
|
||||
from cinder import ssh_utils
|
||||
from cinder import test
|
||||
from cinder import utils
|
||||
|
||||
@ -763,279 +760,6 @@ class AuditPeriodTest(test.TestCase):
|
||||
self.assertEqual(60.0 * 60 * 24, (end2 - begin2).total_seconds())
|
||||
|
||||
|
||||
class FakeSSHClient(object):
|
||||
|
||||
def __init__(self):
|
||||
self.id = uuid.uuid4()
|
||||
self.transport = FakeTransport()
|
||||
|
||||
def set_missing_host_key_policy(self, policy):
|
||||
self.policy = policy
|
||||
|
||||
def load_system_host_keys(self):
|
||||
self.system_host_keys = 'system_host_keys'
|
||||
|
||||
def load_host_keys(self, hosts_key_file):
|
||||
self.hosts_key_file = hosts_key_file
|
||||
|
||||
def connect(self, ip, port=22, username=None, password=None,
|
||||
pkey=None, timeout=10):
|
||||
pass
|
||||
|
||||
def get_transport(self):
|
||||
return self.transport
|
||||
|
||||
def get_policy(self):
|
||||
return self.policy
|
||||
|
||||
def get_host_keys(self):
|
||||
return '127.0.0.1 ssh-rsa deadbeef'
|
||||
|
||||
def close(self):
|
||||
pass
|
||||
|
||||
def __call__(self, *args, **kwargs):
|
||||
pass
|
||||
|
||||
|
||||
class FakeSock(object):
|
||||
def settimeout(self, timeout):
|
||||
pass
|
||||
|
||||
|
||||
class FakeTransport(object):
|
||||
|
||||
def __init__(self):
|
||||
self.active = True
|
||||
self.sock = FakeSock()
|
||||
|
||||
def set_keepalive(self, timeout):
|
||||
pass
|
||||
|
||||
def is_active(self):
|
||||
return self.active
|
||||
|
||||
|
||||
class SSHPoolTestCase(test.TestCase):
|
||||
"""Unit test for SSH Connection Pool."""
|
||||
@mock.patch('cinder.ssh_utils.CONF')
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
@mock.patch('os.path.isfile', return_value=True)
|
||||
def test_ssh_default_hosts_key_file(self, mock_isfile, mock_sshclient,
|
||||
mock_open, mock_conf):
|
||||
mock_ssh = mock.MagicMock()
|
||||
mock_sshclient.return_value = mock_ssh
|
||||
mock_conf.ssh_hosts_key_file = '/var/lib/cinder/ssh_known_hosts'
|
||||
|
||||
# create with customized setting
|
||||
sshpool = ssh_utils.SSHPool("127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
|
||||
host_key_files = sshpool.hosts_key_file
|
||||
|
||||
self.assertEqual('/var/lib/cinder/ssh_known_hosts', host_key_files)
|
||||
|
||||
mock_ssh.load_host_keys.assert_called_once_with(
|
||||
'/var/lib/cinder/ssh_known_hosts')
|
||||
|
||||
@mock.patch('cinder.ssh_utils.CONF')
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
@mock.patch('os.path.isfile', return_value=True)
|
||||
def test_ssh_host_key_file_kwargs(self, mock_isfile, mock_sshclient,
|
||||
mock_open, mock_conf):
|
||||
mock_ssh = mock.MagicMock()
|
||||
mock_sshclient.return_value = mock_ssh
|
||||
mock_conf.ssh_hosts_key_file = '/var/lib/cinder/ssh_known_hosts'
|
||||
|
||||
# create with customized setting
|
||||
sshpool = ssh_utils.SSHPool("127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=1,
|
||||
hosts_key_file='dummy_host_keyfile')
|
||||
|
||||
host_key_files = sshpool.hosts_key_file
|
||||
|
||||
self.assertIn('dummy_host_keyfile', host_key_files)
|
||||
self.assertIn('/var/lib/cinder/ssh_known_hosts', host_key_files)
|
||||
|
||||
expected = [
|
||||
mock.call.load_host_keys('dummy_host_keyfile'),
|
||||
mock.call.load_host_keys('/var/lib/cinder/ssh_known_hosts')]
|
||||
|
||||
mock_ssh.assert_has_calls(expected, any_order=True)
|
||||
|
||||
@mock.patch('cinder.ssh_utils.CONF')
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('os.path.isfile', return_value=True)
|
||||
@mock.patch('paramiko.RSAKey.from_private_key_file')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
def test_single_ssh_connect(self, mock_sshclient, mock_pkey, mock_isfile,
|
||||
mock_open, mock_conf):
|
||||
mock_conf.ssh_hosts_key_file = '/var/lib/cinder/ssh_known_hosts'
|
||||
|
||||
# create with password
|
||||
sshpool = ssh_utils.SSHPool("127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
with sshpool.item() as ssh:
|
||||
first_id = ssh.id
|
||||
|
||||
with sshpool.item() as ssh:
|
||||
second_id = ssh.id
|
||||
|
||||
self.assertEqual(first_id, second_id)
|
||||
self.assertEqual(1, mock_sshclient.return_value.connect.call_count)
|
||||
|
||||
# create with private key
|
||||
sshpool = ssh_utils.SSHPool("127.0.0.1", 22, 10,
|
||||
"test",
|
||||
privatekey="test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
self.assertEqual(2, mock_sshclient.return_value.connect.call_count)
|
||||
|
||||
# attempt to create with no password or private key
|
||||
self.assertRaises(paramiko.SSHException,
|
||||
ssh_utils.SSHPool,
|
||||
"127.0.0.1", 22, 10,
|
||||
"test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
def test_closed_reopened_ssh_connections(self, mock_sshclient, mock_open):
|
||||
mock_sshclient.return_value = eval('FakeSSHClient')()
|
||||
sshpool = ssh_utils.SSHPool("127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=4)
|
||||
with sshpool.item() as ssh:
|
||||
mock_sshclient.reset_mock()
|
||||
first_id = ssh.id
|
||||
|
||||
with sshpool.item() as ssh:
|
||||
second_id = ssh.id
|
||||
ssh.get_transport().active = False
|
||||
sshpool.remove(ssh)
|
||||
|
||||
self.assertEqual(first_id, second_id)
|
||||
|
||||
# create a new client
|
||||
mock_sshclient.return_value = FakeSSHClient()
|
||||
with sshpool.item() as ssh:
|
||||
third_id = ssh.id
|
||||
|
||||
self.assertNotEqual(first_id, third_id)
|
||||
|
||||
@mock.patch('cinder.ssh_utils.CONF')
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
def test_missing_ssh_hosts_key_config(self, mock_sshclient, mock_open,
|
||||
mock_conf):
|
||||
mock_sshclient.return_value = FakeSSHClient()
|
||||
|
||||
mock_conf.ssh_hosts_key_file = None
|
||||
# create with password
|
||||
self.assertRaises(exception.ParameterNotFound,
|
||||
ssh_utils.SSHPool,
|
||||
"127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
def test_create_default_known_hosts_file(self, mock_sshclient,
|
||||
mock_open):
|
||||
mock_sshclient.return_value = FakeSSHClient()
|
||||
|
||||
CONF.state_path = '/var/lib/cinder'
|
||||
CONF.ssh_hosts_key_file = '/var/lib/cinder/ssh_known_hosts'
|
||||
|
||||
default_file = '/var/lib/cinder/ssh_known_hosts'
|
||||
|
||||
ssh_pool = ssh_utils.SSHPool("127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
|
||||
with ssh_pool.item() as ssh:
|
||||
mock_open.assert_called_once_with(default_file, 'a')
|
||||
ssh_pool.remove(ssh)
|
||||
|
||||
@mock.patch('os.path.isfile', return_value=False)
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
def test_ssh_missing_hosts_key_file(self, mock_sshclient, mock_open,
|
||||
mock_isfile):
|
||||
mock_sshclient.return_value = FakeSSHClient()
|
||||
|
||||
CONF.ssh_hosts_key_file = '/tmp/blah'
|
||||
|
||||
self.assertNotIn(CONF.state_path, CONF.ssh_hosts_key_file)
|
||||
self.assertRaises(exception.InvalidInput,
|
||||
ssh_utils.SSHPool,
|
||||
"127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
|
||||
@mock.patch.multiple('cinder.ssh_utils.CONF',
|
||||
strict_ssh_host_key_policy=True,
|
||||
ssh_hosts_key_file='/var/lib/cinder/ssh_known_hosts')
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
@mock.patch('os.path.isfile', return_value=True)
|
||||
def test_ssh_strict_host_key_policy(self, mock_isfile, mock_sshclient,
|
||||
mock_open):
|
||||
mock_sshclient.return_value = FakeSSHClient()
|
||||
|
||||
# create with customized setting
|
||||
sshpool = ssh_utils.SSHPool("127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
|
||||
with sshpool.item() as ssh:
|
||||
self.assertTrue(isinstance(ssh.get_policy(),
|
||||
paramiko.RejectPolicy))
|
||||
|
||||
@mock.patch('six.moves.builtins.open')
|
||||
@mock.patch('paramiko.SSHClient')
|
||||
@mock.patch('os.path.isfile', return_value=True)
|
||||
def test_ssh_not_strict_host_key_policy(self, mock_isfile, mock_sshclient,
|
||||
mock_open):
|
||||
mock_sshclient.return_value = FakeSSHClient()
|
||||
|
||||
CONF.strict_ssh_host_key_policy = False
|
||||
|
||||
# create with customized setting
|
||||
sshpool = ssh_utils.SSHPool("127.0.0.1", 22, 10,
|
||||
"test",
|
||||
password="test",
|
||||
min_size=1,
|
||||
max_size=1)
|
||||
|
||||
with sshpool.item() as ssh:
|
||||
self.assertTrue(isinstance(ssh.get_policy(),
|
||||
paramiko.AutoAddPolicy))
|
||||
|
||||
|
||||
class BrickUtils(test.TestCase):
|
||||
"""Unit test to test the brick utility wrapper functions."""
|
||||
|
||||
|
@ -81,6 +81,7 @@ cinder.tests.unit.test_sheepdog
|
||||
cinder.tests.unit.test_smbfs
|
||||
cinder.tests.unit.test_srb
|
||||
cinder.tests.unit.test_solidfire
|
||||
cinder.tests.unit.test_ssh_utils
|
||||
cinder.tests.unit.test_test
|
||||
cinder.tests.unit.test_test_utils
|
||||
cinder.tests.unit.test_v6000_common
|
||||
|
Loading…
x
Reference in New Issue
Block a user