tahoe-lafs/integration/test_sftp.py

133 lines
3.7 KiB
Python
Raw Normal View History

2021-01-07 17:50:31 +00:00
"""
It's possible to create/rename/delete files and directories in Tahoe-LAFS using
SFTP.
"""
from __future__ import unicode_literals
from __future__ import absolute_import
from __future__ import division
from __future__ import print_function
from future.utils import PY2
if PY2:
from future.builtins import filter, map, zip, ascii, chr, hex, input, next, oct, open, pow, round, super, bytes, dict, list, object, range, str, max, min # noqa: F401
2021-01-07 18:27:34 +00:00
from posixpath import join
from stat import S_ISDIR
2021-01-07 17:50:31 +00:00
from paramiko import SSHClient
from paramiko.client import AutoAddPolicy
from paramiko.sftp_client import SFTPClient
2021-01-07 18:27:34 +00:00
from paramiko.ssh_exception import AuthenticationException
2021-01-08 18:33:22 +00:00
from paramiko.rsakey import RSAKey
2021-01-07 17:50:31 +00:00
2021-01-07 18:27:34 +00:00
import pytest
2021-01-07 17:50:31 +00:00
2021-01-07 18:27:34 +00:00
def connect_sftp(connect_args={"username": "alice", "password": "password"}):
2021-01-07 18:27:34 +00:00
"""Create an SFTP client."""
2021-01-07 17:50:31 +00:00
client = SSHClient()
client.set_missing_host_key_policy(AutoAddPolicy)
2021-01-08 18:33:22 +00:00
client.connect("localhost", port=8022, look_for_keys=False,
allow_agent=False, **connect_args)
2021-01-07 17:50:31 +00:00
sftp = SFTPClient.from_transport(client.get_transport())
2021-01-07 18:27:34 +00:00
def rmdir(path, delete_root=True):
for f in sftp.listdir_attr(path=path):
childpath = join(path, f.filename)
if S_ISDIR(f.st_mode):
rmdir(childpath)
else:
sftp.remove(childpath)
if delete_root:
sftp.rmdir(path)
# Delete any files left over from previous tests :(
rmdir("/", delete_root=False)
return sftp
def test_bad_account_password_ssh_key(alice):
"""
Can't login with unknown username, wrong password, or wrong SSH pub key.
"""
2021-01-07 18:27:34 +00:00
for u, p in [("alice", "wrong"), ("someuser", "password")]:
with pytest.raises(AuthenticationException):
connect_sftp(connect_args={
"username": u, "password": p,
})
# TODO bad pubkey
def test_ssh_key_auth(alice):
"""It's possible to login authenticating with SSH public key."""
2021-01-08 18:33:22 +00:00
key = RSAKey(filename=join(alice.node_dir, "private", "ssh_client_rsa_key"))
sftp = connect_sftp(connect_args={
2021-01-08 18:33:22 +00:00
"username": "alice2", "pkey": key
})
assert sftp.listdir() == []
2021-01-07 18:27:34 +00:00
def test_read_write_files(alice):
"""It's possible to upload and download files."""
sftp = connect_sftp()
2021-01-07 17:50:31 +00:00
f = sftp.file("myfile", "wb")
f.write(b"abc")
f.write(b"def")
f.close()
f = sftp.file("myfile", "rb")
assert f.read(4) == b"abcd"
assert f.read(2) == b"ef"
assert f.read(1) == b""
f.close()
2021-01-07 18:27:34 +00:00
def test_directories(alice):
"""
It's possible to create, list directories, and create and remove files in
them.
"""
sftp = connect_sftp()
2021-01-07 18:27:34 +00:00
assert sftp.listdir() == []
sftp.mkdir("childdir")
assert sftp.listdir() == ["childdir"]
with sftp.file("myfile", "wb") as f:
f.write(b"abc")
assert sorted(sftp.listdir()) == ["childdir", "myfile"]
sftp.chdir("childdir")
assert sftp.listdir() == []
with sftp.file("myfile2", "wb") as f:
f.write(b"def")
assert sftp.listdir() == ["myfile2"]
sftp.chdir(None) # root
with sftp.file("childdir/myfile2", "rb") as f:
assert f.read() == b"def"
sftp.remove("myfile")
assert sftp.listdir() == ["childdir"]
sftp.rmdir("childdir")
assert sftp.listdir() == []
def test_rename(alice):
"""Directories and files can be renamed."""
sftp = connect_sftp()
sftp.mkdir("dir")
filepath = join("dir", "file")
with sftp.file(filepath, "wb") as f:
f.write(b"abc")
sftp.rename(filepath, join("dir", "file2"))
sftp.rename("dir", "dir2")
with sftp.file(join("dir2", "file2"), "rb") as f:
assert f.read() == b"abc"