commit - d6f6b6696c6c35527b284127d8c74c79d85b5e01
commit + c240667fec5ab8776fa530ac6f60734b911c0350
blob - 9b2329c29060889e244ac86854f47f647dfc1dc2
blob + 3e1673b1ddd79cc1bfe2575ec24b11ab0ff0ad87
--- dulwich/contrib/test_paramiko_vendor.py
+++ dulwich/contrib/test_paramiko_vendor.py
"""Tests for paramiko_vendor."""
import socket
-import paramiko
import threading
from dulwich.tests import TestCase
-from dulwich.contrib.paramiko_vendor import ParamikoSSHVendor
from io import StringIO
+from unittest import skipIf
+try:
+ import paramiko
+except ImportError:
+ paramiko = None
+else:
+ from dulwich.contrib.paramiko_vendor import ParamikoSSHVendor
+
USER = 'testuser'
PASSWORD = 'test'
SERVER_KEY = """\
-----END RSA PRIVATE KEY-----"""
-class Server(paramiko.ServerInterface):
- """http://docs.paramiko.org/en/2.4/api/server.html"""
- def __init__(self, commands, *args, **kwargs):
- super(Server, self).__init__(*args, **kwargs)
- self.commands = commands
+if paramiko is not None:
+ class Server(paramiko.ServerInterface):
+ """http://docs.paramiko.org/en/2.4/api/server.html"""
+ def __init__(self, commands, *args, **kwargs):
+ super(Server, self).__init__(*args, **kwargs)
+ self.commands = commands
- def check_channel_exec_request(self, channel, command):
- self.commands.append(command)
- return True
+ def check_channel_exec_request(self, channel, command):
+ self.commands.append(command)
+ return True
- def check_auth_password(self, username, password):
- if username == USER and password == PASSWORD:
- return paramiko.AUTH_SUCCESSFUL
- return paramiko.AUTH_FAILED
+ def check_auth_password(self, username, password):
+ if username == USER and password == PASSWORD:
+ return paramiko.AUTH_SUCCESSFUL
+ return paramiko.AUTH_FAILED
- def check_auth_publickey(self, username, key):
- pubkey = paramiko.RSAKey.from_private_key(StringIO(CLIENT_KEY))
- if username == USER and key == pubkey:
- return paramiko.AUTH_SUCCESSFUL
- return paramiko.AUTH_FAILED
+ def check_auth_publickey(self, username, key):
+ pubkey = paramiko.RSAKey.from_private_key(StringIO(CLIENT_KEY))
+ if username == USER and key == pubkey:
+ return paramiko.AUTH_SUCCESSFUL
+ return paramiko.AUTH_FAILED
- def check_channel_request(self, kind, chanid):
- if kind == "session":
- return paramiko.OPEN_SUCCEEDED
- return paramiko.OPEN_FAILED_ADMINISTRATIVELY_PROHIBITED
+ def check_channel_request(self, kind, chanid):
+ if kind == "session":
+ return paramiko.OPEN_SUCCEEDED
+ return paramiko.OPEN_FAILED_ADMINISTRATIVELY_PROHIBITED
- def get_allowed_auths(self, username):
- return "password,publickey"
+ def get_allowed_auths(self, username):
+ return "password,publickey"
+@skipIf(paramiko is None, "paramiko is not installed")
class ParamikoSSHVendorTests(TestCase):
def setUp(self):