diff options
Diffstat (limited to 'tests/test_ssh.py')
| -rw-r--r-- | tests/test_ssh.py | 90 |
1 files changed, 47 insertions, 43 deletions
diff --git a/tests/test_ssh.py b/tests/test_ssh.py index ffb5cb94..a9c1be7f 100644 --- a/tests/test_ssh.py +++ b/tests/test_ssh.py | |||
| @@ -23,52 +23,56 @@ import ssh | |||
| 23 | 23 | ||
| 24 | 24 | ||
| 25 | class SshTests(unittest.TestCase): | 25 | class SshTests(unittest.TestCase): |
| 26 | """Tests the ssh functions.""" | 26 | """Tests the ssh functions.""" |
| 27 | 27 | ||
| 28 | def test_parse_ssh_version(self): | 28 | def test_parse_ssh_version(self): |
| 29 | """Check _parse_ssh_version() handling.""" | 29 | """Check _parse_ssh_version() handling.""" |
| 30 | ver = ssh._parse_ssh_version('Unknown\n') | 30 | ver = ssh._parse_ssh_version("Unknown\n") |
| 31 | self.assertEqual(ver, ()) | 31 | self.assertEqual(ver, ()) |
| 32 | ver = ssh._parse_ssh_version('OpenSSH_1.0\n') | 32 | ver = ssh._parse_ssh_version("OpenSSH_1.0\n") |
| 33 | self.assertEqual(ver, (1, 0)) | 33 | self.assertEqual(ver, (1, 0)) |
| 34 | ver = ssh._parse_ssh_version('OpenSSH_6.6.1p1 Ubuntu-2ubuntu2.13, OpenSSL 1.0.1f 6 Jan 2014\n') | 34 | ver = ssh._parse_ssh_version( |
| 35 | self.assertEqual(ver, (6, 6, 1)) | 35 | "OpenSSH_6.6.1p1 Ubuntu-2ubuntu2.13, OpenSSL 1.0.1f 6 Jan 2014\n" |
| 36 | ver = ssh._parse_ssh_version('OpenSSH_7.6p1 Ubuntu-4ubuntu0.3, OpenSSL 1.0.2n 7 Dec 2017\n') | 36 | ) |
| 37 | self.assertEqual(ver, (7, 6)) | 37 | self.assertEqual(ver, (6, 6, 1)) |
| 38 | ver = ssh._parse_ssh_version( | ||
| 39 | "OpenSSH_7.6p1 Ubuntu-4ubuntu0.3, OpenSSL 1.0.2n 7 Dec 2017\n" | ||
| 40 | ) | ||
| 41 | self.assertEqual(ver, (7, 6)) | ||
| 38 | 42 | ||
| 39 | def test_version(self): | 43 | def test_version(self): |
| 40 | """Check version() handling.""" | 44 | """Check version() handling.""" |
| 41 | with mock.patch('ssh._run_ssh_version', return_value='OpenSSH_1.2\n'): | 45 | with mock.patch("ssh._run_ssh_version", return_value="OpenSSH_1.2\n"): |
| 42 | self.assertEqual(ssh.version(), (1, 2)) | 46 | self.assertEqual(ssh.version(), (1, 2)) |
| 43 | 47 | ||
| 44 | def test_context_manager_empty(self): | 48 | def test_context_manager_empty(self): |
| 45 | """Verify context manager with no clients works correctly.""" | 49 | """Verify context manager with no clients works correctly.""" |
| 46 | with multiprocessing.Manager() as manager: | 50 | with multiprocessing.Manager() as manager: |
| 47 | with ssh.ProxyManager(manager): | 51 | with ssh.ProxyManager(manager): |
| 48 | pass | 52 | pass |
| 49 | 53 | ||
| 50 | def test_context_manager_child_cleanup(self): | 54 | def test_context_manager_child_cleanup(self): |
| 51 | """Verify orphaned clients & masters get cleaned up.""" | 55 | """Verify orphaned clients & masters get cleaned up.""" |
| 52 | with multiprocessing.Manager() as manager: | 56 | with multiprocessing.Manager() as manager: |
| 53 | with ssh.ProxyManager(manager) as ssh_proxy: | 57 | with ssh.ProxyManager(manager) as ssh_proxy: |
| 54 | client = subprocess.Popen(['sleep', '964853320']) | 58 | client = subprocess.Popen(["sleep", "964853320"]) |
| 55 | ssh_proxy.add_client(client) | 59 | ssh_proxy.add_client(client) |
| 56 | master = subprocess.Popen(['sleep', '964853321']) | 60 | master = subprocess.Popen(["sleep", "964853321"]) |
| 57 | ssh_proxy.add_master(master) | 61 | ssh_proxy.add_master(master) |
| 58 | # If the process still exists, these will throw timeout errors. | 62 | # If the process still exists, these will throw timeout errors. |
| 59 | client.wait(0) | 63 | client.wait(0) |
| 60 | master.wait(0) | 64 | master.wait(0) |
| 61 | 65 | ||
| 62 | def test_ssh_sock(self): | 66 | def test_ssh_sock(self): |
| 63 | """Check sock() function.""" | 67 | """Check sock() function.""" |
| 64 | manager = multiprocessing.Manager() | 68 | manager = multiprocessing.Manager() |
| 65 | proxy = ssh.ProxyManager(manager) | 69 | proxy = ssh.ProxyManager(manager) |
| 66 | with mock.patch('tempfile.mkdtemp', return_value='/tmp/foo'): | 70 | with mock.patch("tempfile.mkdtemp", return_value="/tmp/foo"): |
| 67 | # old ssh version uses port | 71 | # Old ssh version uses port. |
| 68 | with mock.patch('ssh.version', return_value=(6, 6)): | 72 | with mock.patch("ssh.version", return_value=(6, 6)): |
| 69 | self.assertTrue(proxy.sock().endswith('%p')) | 73 | self.assertTrue(proxy.sock().endswith("%p")) |
| 70 | 74 | ||
| 71 | proxy._sock_path = None | 75 | proxy._sock_path = None |
| 72 | # new ssh version uses hash | 76 | # New ssh version uses hash. |
| 73 | with mock.patch('ssh.version', return_value=(6, 7)): | 77 | with mock.patch("ssh.version", return_value=(6, 7)): |
| 74 | self.assertTrue(proxy.sock().endswith('%C')) | 78 | self.assertTrue(proxy.sock().endswith("%C")) |
