Skip to content

Commit

Permalink
Bug: put api do not support local dir (#147)
Browse files Browse the repository at this point in the history
  • Loading branch information
yanghua authored Sep 26, 2024
1 parent 5226daa commit 743e315
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 25 deletions.
6 changes: 3 additions & 3 deletions tosfs/core.py
Original file line number Diff line number Diff line change
Expand Up @@ -780,8 +780,6 @@ def put_file(
------
FileNotFoundError
If the local file does not exist.
IsADirectoryError
If the local path is a directory.
TosClientError
If there is a client error while putting the file.
TosServerError
Expand All @@ -799,7 +797,8 @@ def put_file(
raise FileNotFoundError(f"Local file {lpath} not found.")

if os.path.isdir(lpath):
raise IsADirectoryError(f"{lpath} is a directory.")
self.makedirs(rpath, exist_ok=True)
return

size = os.path.getsize(lpath)

Expand All @@ -812,6 +811,7 @@ def put_file(

if self.isdir(rpath):
rpath = os.path.join(rpath, os.path.basename(lpath))
self.mkdirs(self._parent(rpath), exist_ok=True)

bucket, key, _ = self._split_path(rpath)

Expand Down
58 changes: 38 additions & 20 deletions tosfs/tests/test_fsspec.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@

import io
import os
import tempfile
from typing import Any

import pytest
Expand Down Expand Up @@ -763,27 +764,44 @@ def test_get(fsspecfs: Any, bucket: str, temporary_workspace: str):


def test_put(fsspecfs: Any, bucket: str, temporary_workspace: str):
file_name = random_str()
local_temp_dir = create_temp_dir()
local_file_path = f"{local_temp_dir}/{file_name}"
test_data = b"Data for testing ProtonFileSystem put method."
file_name = f"{random_str()}.txt"
with tempfile.TemporaryDirectory() as local_temp_dir:
local_file_path = f"{local_temp_dir}/{file_name}"
test_data = b"Data for testing ProtonFileSystem put method."

with open(local_file_path, "wb") as f:
f.write(test_data)
with open(local_file_path, "wb") as f:
f.write(test_data)

remote_file_path = f"{bucket}/{temporary_workspace}/{file_name}"
fsspecfs.put(local_file_path, remote_file_path)
remote_file_path = f"{bucket}/{temporary_workspace}/{file_name}"
fsspecfs.put(local_file_path, remote_file_path)

assert fsspecfs.exists(
remote_file_path
), "The file should exist in the remote location after upload."
assert fsspecfs.exists(
remote_file_path
), "The file should exist in the remote location after upload."

downloaded_file_path = f"{local_temp_dir}/downloaded_{file_name}"
fsspecfs.get(remote_file_path, downloaded_file_path)
with open(downloaded_file_path, "rb") as f:
downloaded_data = f.read()
assert (
downloaded_data == test_data
), "The downloaded file's contents should match the original test data."
os.remove(downloaded_file_path)
os.remove(local_file_path)
downloaded_file_path = f"{local_temp_dir}/downloaded_{file_name}"
fsspecfs.get(remote_file_path, downloaded_file_path)
with open(downloaded_file_path, "rb") as f:
downloaded_data = f.read()
assert (
downloaded_data == test_data
), "The downloaded file's contents should match the original test data."

# test lpath and rpath are both dirs
remote_temp_dir = f"{bucket}/{temporary_workspace}/{random_str()}"

fsspecfs.mkdir(remote_temp_dir)
fsspecfs.put(local_temp_dir, remote_temp_dir, recursive=True)
assert fsspecfs.exists(remote_temp_dir), "The remote directory should exist."
remote_file_path = os.path.join(
remote_temp_dir, os.path.basename(local_temp_dir), file_name
)
assert fsspecfs.exists(
remote_file_path
), "The remote directory should contain the local directory."

with fsspecfs.open(remote_file_path, "rb") as f:
downloaded_data = f.read()
assert (
downloaded_data == test_data
), "The downloaded file's contents should match the original test data."
3 changes: 1 addition & 2 deletions tosfs/tests/test_tosfs.py
Original file line number Diff line number Diff line change
Expand Up @@ -336,8 +336,7 @@ def test_put_file(tosfs: TosFileSystem, bucket: str, temporary_workspace: str) -
with tosfs.open(f"{bucket}/{temporary_workspace}/{file_name}", "r") as f:
assert f.read() == "hello world"

with pytest.raises(IsADirectoryError):
tosfs.put_file(temp_dir, f"{bucket}/{temporary_workspace}")
tosfs.put_file(temp_dir, f"{bucket}/{temporary_workspace}")

with pytest.raises(FileNotFoundError):
tosfs.put_file(f"/notexist/{random_str()}", rpath)
Expand Down

0 comments on commit 743e315

Please sign in to comment.