diff options
author | Jeff Forcier <jeff@bitprophet.org> | 2014-01-08 13:43:46 -0800 |
---|---|---|
committer | Jeff Forcier <jeff@bitprophet.org> | 2014-01-08 13:43:46 -0800 |
commit | 19fedd261e3136fd5690c6e1998b4e015f94e9bc (patch) | |
tree | 7b5049627fbdaa2e56fe7ef708bb05063e7b82ac /tests/test_client.py | |
parent | dd3e203e00f33b1b00a07aa6ea54703da362a5f4 (diff) | |
parent | 96ca8d49c1246ebe6b9bb2001c8a67baf868f880 (diff) |
Merge branch '1.12'
Diffstat (limited to 'tests/test_client.py')
-rw-r--r-- | tests/test_client.py | 31 |
1 files changed, 30 insertions, 1 deletions
diff --git a/tests/test_client.py b/tests/test_client.py index e5352278..fae1d329 100644 --- a/tests/test_client.py +++ b/tests/test_client.py @@ -20,11 +20,14 @@ Some unit tests for SSHClient. """ +from __future__ import with_statement # Python 2.5 support import socket import threading import time import unittest import weakref +import warnings +import os from binascii import hexlify import paramiko @@ -184,7 +187,33 @@ class SSHClientTest (unittest.TestCase): self.assertEquals(1, len(self.tc.get_host_keys())) self.assertEquals(public_host_key, self.tc.get_host_keys()['[%s]:%d' % (self.addr, self.port)]['ssh-rsa']) - def test_5_cleanup(self): + def test_5_save_host_keys(self): + """ + verify that SSHClient correctly saves a known_hosts file. + """ + warnings.filterwarnings('ignore', 'tempnam.*') + + host_key = paramiko.RSAKey.from_private_key_file('tests/test_rsa.key') + public_host_key = paramiko.RSAKey(data=str(host_key)) + localname = os.tempnam() + + client = paramiko.SSHClient() + self.assertEquals(0, len(client.get_host_keys())) + + host_id = '[%s]:%d' % (self.addr, self.port) + + client.get_host_keys().add(host_id, 'ssh-rsa', public_host_key) + self.assertEquals(1, len(client.get_host_keys())) + self.assertEquals(public_host_key, client.get_host_keys()[host_id]['ssh-rsa']) + + client.save_host_keys(localname) + + with open(localname) as fd: + assert host_id in fd.read() + + os.unlink(localname) + + def test_6_cleanup(self): """ verify that when an SSHClient is collected, its transport (and the transport's packetizer) is closed. |