diff --git a/scmrepo/git/backend/dulwich/asyncssh_vendor.py b/scmrepo/git/backend/dulwich/asyncssh_vendor.py index ae881a50..f84c63b2 100644 --- a/scmrepo/git/backend/dulwich/asyncssh_vendor.py +++ b/scmrepo/git/backend/dulwich/asyncssh_vendor.py @@ -7,7 +7,7 @@ from scmrepo.asyn import BaseAsyncObject, sync_wrapper if TYPE_CHECKING: - from asyncssh.connection import SSHClientConnection, SSHConnection + from asyncssh.connection import SSHClientConnection from asyncssh.process import SSHClientProcess from asyncssh.stream import SSHReader @@ -37,7 +37,7 @@ async def _read(self, n: Optional[int] = None) -> bytes: class AsyncSSHWrapper(BaseAsyncObject): def __init__( - self, conn: "SSHConnection", proc: "SSHClientProcess", **kwargs + self, conn: "SSHClientConnection", proc: "SSHClientProcess", **kwargs ): super().__init__(**kwargs) self.conn: "SSHClientConnection" = conn @@ -146,7 +146,7 @@ async def _run_command( MSG_USERAUTH_PK_OK ] = _process_public_key_ok_gh - conn: "SSHClientConnection" = await asyncssh.connect( + conn = await asyncssh.connect( host, port=port if port is not None else (), username=username if username is not None else (), @@ -156,9 +156,7 @@ async def _run_command( known_hosts=None, encoding=None, ) - proc: "SSHClientProcess" = await conn.create_process( - command, encoding=None - ) + proc = await conn.create_process(command, encoding=None) return AsyncSSHWrapper(conn, proc) run_command = sync_wrapper(_run_command) diff --git a/setup.cfg b/setup.cfg index f6d4fa52..0395c474 100644 --- a/setup.cfg +++ b/setup.cfg @@ -30,7 +30,7 @@ install_requires= pygtrie>=2.3.2 fsspec>=2021.7.0 pathspec>=0.9.0,<0.10.0 - asyncssh>=2.7.1,<2.9 + asyncssh>=2.7.1,<3 funcy>=1.14 [options.extras_require] diff --git a/tests/conftest.py b/tests/conftest.py index d0c39e0a..794b1f77 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -126,14 +126,14 @@ def check() -> bool: @pytest.fixture async def ssh_connection( ssh_conn_info: Dict[str, Any], -) -> AsyncIterator[asyncssh.connection.SSHConnection]: +) -> AsyncIterator[asyncssh.connection.SSHClientConnection]: async with asyncssh.connect(**ssh_conn_info) as conn: yield conn @pytest.fixture async def sftp( - ssh_connection: asyncssh.connection.SSHConnection, + ssh_connection: asyncssh.connection.SSHClientConnection, ) -> AsyncIterator[asyncssh.SFTPClient]: async with ssh_connection.start_sftp_client() as sftp: yield sftp diff --git a/tests/test_git.py b/tests/test_git.py index 4a7c8d5a..adfc3de7 100644 --- a/tests/test_git.py +++ b/tests/test_git.py @@ -4,7 +4,7 @@ import pytest from asyncssh import SFTPClient -from asyncssh.connection import SSHConnection +from asyncssh.connection import SSHClientConnection from git import Repo as GitPythonRepo from pytest_test_utils import TempDirFactory, TmpDir from pytest_test_utils.matchers import Matcher @@ -844,7 +844,7 @@ async def test_git_ssh( scm: Git, git: Git, sftp: SFTPClient, - ssh_connection: SSHConnection, + ssh_connection: SSHClientConnection, ssh_conn_info: Dict[str, Any], ): host, port = ssh_conn_info["host"], ssh_conn_info["port"] @@ -868,7 +868,7 @@ async def test_git_ssh( ) async with sftp.open("test-repo.git/refs/heads/master") as fobj: - assert (await fobj.read()).strip() == rev + assert (await fobj.read(-1, 0)).strip() == rev shutil.rmtree(tmp_dir / ".git") (tmp_dir / "foo").unlink()