rclone-api 1.1.39__tar.gz → 1.1.41__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (86) hide show
  1. {rclone_api-1.1.39 → rclone_api-1.1.41}/PKG-INFO +1 -1
  2. {rclone_api-1.1.39 → rclone_api-1.1.41}/pyproject.toml +1 -1
  3. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/profile/mount_copy_bytes.py +49 -46
  4. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/rclone.py +3 -3
  5. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api.egg-info/PKG-INFO +1 -1
  6. {rclone_api-1.1.39 → rclone_api-1.1.41}/.aiderignore +0 -0
  7. {rclone_api-1.1.39 → rclone_api-1.1.41}/.github/workflows/lint.yml +0 -0
  8. {rclone_api-1.1.39 → rclone_api-1.1.41}/.github/workflows/push_macos.yml +0 -0
  9. {rclone_api-1.1.39 → rclone_api-1.1.41}/.github/workflows/push_ubuntu.yml +0 -0
  10. {rclone_api-1.1.39 → rclone_api-1.1.41}/.github/workflows/push_win.yml +0 -0
  11. {rclone_api-1.1.39 → rclone_api-1.1.41}/.gitignore +0 -0
  12. {rclone_api-1.1.39 → rclone_api-1.1.41}/.pylintrc +0 -0
  13. {rclone_api-1.1.39 → rclone_api-1.1.41}/.vscode/launch.json +0 -0
  14. {rclone_api-1.1.39 → rclone_api-1.1.41}/.vscode/settings.json +0 -0
  15. {rclone_api-1.1.39 → rclone_api-1.1.41}/.vscode/tasks.json +0 -0
  16. {rclone_api-1.1.39 → rclone_api-1.1.41}/LICENSE +0 -0
  17. {rclone_api-1.1.39 → rclone_api-1.1.41}/MANIFEST.in +0 -0
  18. {rclone_api-1.1.39 → rclone_api-1.1.41}/README.md +0 -0
  19. {rclone_api-1.1.39 → rclone_api-1.1.41}/clean +0 -0
  20. {rclone_api-1.1.39 → rclone_api-1.1.41}/install +0 -0
  21. {rclone_api-1.1.39 → rclone_api-1.1.41}/lint +0 -0
  22. {rclone_api-1.1.39 → rclone_api-1.1.41}/requirements.testing.txt +0 -0
  23. {rclone_api-1.1.39 → rclone_api-1.1.41}/setup.cfg +0 -0
  24. {rclone_api-1.1.39 → rclone_api-1.1.41}/setup.py +0 -0
  25. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/__init__.py +0 -0
  26. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/assets/example.txt +0 -0
  27. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/cli.py +0 -0
  28. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/cmd/copy_large_s3.py +0 -0
  29. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/cmd/list_files.py +0 -0
  30. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/completed_process.py +0 -0
  31. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/config.py +0 -0
  32. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/convert.py +0 -0
  33. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/deprecated.py +0 -0
  34. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/diff.py +0 -0
  35. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/dir.py +0 -0
  36. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/dir_listing.py +0 -0
  37. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/exec.py +0 -0
  38. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/experimental/flags.py +0 -0
  39. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/experimental/flags_base.py +0 -0
  40. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/file.py +0 -0
  41. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/filelist.py +0 -0
  42. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/group_files.py +0 -0
  43. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/mount.py +0 -0
  44. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/process.py +0 -0
  45. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/remote.py +0 -0
  46. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/rpath.py +0 -0
  47. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/s3/api.py +0 -0
  48. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/s3/basic_ops.py +0 -0
  49. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/s3/chunk_file.py +0 -0
  50. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/s3/chunk_types.py +0 -0
  51. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/s3/create.py +0 -0
  52. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/s3/types.py +0 -0
  53. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/s3/upload_file_multipart.py +0 -0
  54. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/scan_missing_folders.py +0 -0
  55. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/types.py +0 -0
  56. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/util.py +0 -0
  57. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api/walk.py +0 -0
  58. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api.egg-info/SOURCES.txt +0 -0
  59. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api.egg-info/dependency_links.txt +0 -0
  60. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api.egg-info/entry_points.txt +0 -0
  61. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api.egg-info/requires.txt +0 -0
  62. {rclone_api-1.1.39 → rclone_api-1.1.41}/src/rclone_api.egg-info/top_level.txt +0 -0
  63. {rclone_api-1.1.39 → rclone_api-1.1.41}/test +0 -0
  64. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/archive/test_paramiko.py.disabled +0 -0
  65. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_cmd_list_files.py +0 -0
  66. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_copy.py +0 -0
  67. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_copy_bytes.py +0 -0
  68. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_copy_file_resumable_s3.py +0 -0
  69. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_copy_files.py +0 -0
  70. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_diff.py +0 -0
  71. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_group_files.py +0 -0
  72. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_is_synced.py +0 -0
  73. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_ls.py +0 -0
  74. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_mount.py +0 -0
  75. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_mount_s3.py +0 -0
  76. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_obscure.py +0 -0
  77. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_rclone_config.py +0 -0
  78. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_remote_control.py +0 -0
  79. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_remotes.py +0 -0
  80. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_s3.py +0 -0
  81. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_scan_missing_folders.py +0 -0
  82. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_size_files.py +0 -0
  83. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_size_suffix.py +0 -0
  84. {rclone_api-1.1.39 → rclone_api-1.1.41}/tests/test_walk.py +0 -0
  85. {rclone_api-1.1.39 → rclone_api-1.1.41}/tox.ini +0 -0
  86. {rclone_api-1.1.39 → rclone_api-1.1.41}/upload_package.sh +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.2
2
2
  Name: rclone_api
3
- Version: 1.1.39
3
+ Version: 1.1.41
4
4
  Summary: rclone api in python
5
5
  Home-page: https://github.com/zackees/rclone-api
6
6
  License: BSD 3-Clause License
@@ -23,7 +23,7 @@ dependencies = [
23
23
  ]
24
24
 
25
25
  # Change this with the version number bump.
26
- version = "1.1.39"
26
+ version = "1.1.41"
27
27
 
28
28
  [tool.setuptools]
29
29
  package-dir = {"" = "src"}
@@ -103,6 +103,53 @@ def _init() -> None:
103
103
  os.environ["RCLONE_API_VERBOSE"] = "1"
104
104
 
105
105
 
106
+ def _run_profile(rclone: Rclone, src_file: str, transfers: int, size: int) -> None:
107
+ mount_log = Path("logs") / "mount" / f"mount_{size}_{transfers}.log"
108
+ print("\n\n")
109
+ print("#" * 80)
110
+ print(f"# Started test download of {SizeSuffix(size)} with {transfers} transfers")
111
+ print("#" * 80)
112
+ net_io_start = psutil.net_io_counters()
113
+ start = time.time()
114
+ bytes_or_err: bytes | Exception = rclone.copy_bytes(
115
+ src=src_file,
116
+ offset=0,
117
+ length=size,
118
+ direct_io=True,
119
+ transfers=transfers,
120
+ mount_log=mount_log,
121
+ )
122
+ diff = time.time() - start
123
+ net_io_end = psutil.net_io_counters()
124
+ if isinstance(bytes_or_err, Exception):
125
+ print(bytes_or_err)
126
+ stack_trace = bytes_or_err.__traceback__
127
+ assert False, f"Error: {bytes_or_err}\nStack trace:\n{stack_trace}"
128
+ assert isinstance(bytes_or_err, bytes)
129
+ # self.assertEqual(len(bytes_or_err), size)
130
+ assert len(bytes_or_err) == size, f"Length: {len(bytes_or_err)} != {size}"
131
+
132
+ # print io stats
133
+ bytes_sent = net_io_end.bytes_sent - net_io_start.bytes_sent
134
+ bytes_recv = net_io_end.bytes_recv - net_io_start.bytes_recv
135
+ packets_sent = net_io_end.packets_sent - net_io_start.packets_sent
136
+ efficiency = size / (bytes_recv)
137
+ efficiency_100 = efficiency * 100
138
+ efficiency_str = f"{efficiency_100:.2f}"
139
+
140
+ bytes_send_suffix = SizeSuffix(bytes_sent)
141
+ bytes_recv_suffix = SizeSuffix(bytes_recv)
142
+ range_size = SizeSuffix(size)
143
+
144
+ print(f"\nFinished downloading {range_size} with {transfers} transfers")
145
+ print("Net IO stats:")
146
+ print(f"Bytes sent: {bytes_send_suffix}")
147
+ print(f"Bytes received: {bytes_recv_suffix}")
148
+ print(f"Packets sent: {packets_sent}")
149
+ print(f"Efficiency: {efficiency_str}%")
150
+ print(f"Time: {diff:.1f} seconds")
151
+
152
+
106
153
  def test_profile_copy_bytes() -> None:
107
154
  print("Running test_profile_copy_bytes")
108
155
  config, creds = _generate_rclone_config()
@@ -130,53 +177,9 @@ def test_profile_copy_bytes() -> None:
130
177
 
131
178
  for size in sizes:
132
179
  for transfers in transfer_list:
133
- mount_log = Path("logs") / "mount" / f"mount_{size}_{transfers}.log"
134
- print("\n\n")
135
- print("#" * 80)
136
- print(
137
- f"# Started test download of {SizeSuffix(size)} with {transfers} transfers"
180
+ _run_profile(
181
+ rclone=rclone, src_file=src_file, transfers=transfers, size=size
138
182
  )
139
- print("#" * 80)
140
- net_io_start = psutil.net_io_counters()
141
- start = time.time()
142
- bytes_or_err: bytes | Exception = rclone.copy_bytes(
143
- src=src_file,
144
- offset=0,
145
- length=size,
146
- direct_io=True,
147
- transfers=transfers,
148
- mount_log=mount_log,
149
- )
150
- diff = time.time() - start
151
- net_io_end = psutil.net_io_counters()
152
- if isinstance(bytes_or_err, Exception):
153
- print(bytes_or_err)
154
- stack_trace = bytes_or_err.__traceback__
155
- assert False, f"Error: {bytes_or_err}\nStack trace:\n{stack_trace}"
156
- assert isinstance(bytes_or_err, bytes)
157
- # self.assertEqual(len(bytes_or_err), size)
158
- assert len(bytes_or_err) == size, f"Length: {len(bytes_or_err)} != {size}"
159
-
160
- # print io stats
161
- bytes_sent = net_io_end.bytes_sent - net_io_start.bytes_sent
162
- bytes_recv = net_io_end.bytes_recv - net_io_start.bytes_recv
163
- packets_sent = net_io_end.packets_sent - net_io_start.packets_sent
164
- efficiency = size / (bytes_recv)
165
- efficiency_100 = efficiency * 100
166
- efficiency_str = f"{efficiency_100:.2f}"
167
-
168
- bytes_send_suffix = SizeSuffix(bytes_sent)
169
- bytes_recv_suffix = SizeSuffix(bytes_recv)
170
- range_size = SizeSuffix(size)
171
-
172
- print(f"\nFinished downloading {range_size} with {transfers} transfers")
173
- print("Net IO stats:")
174
- print(f"Bytes sent: {bytes_send_suffix}")
175
- print(f"Bytes received: {bytes_recv_suffix}")
176
- print(f"Packets sent: {packets_sent}")
177
- print(f"Efficiency: {efficiency_str}%")
178
- print(f"Time: {diff:.1f} seconds")
179
-
180
183
  print("done")
181
184
 
182
185
 
@@ -833,10 +833,10 @@ class Rclone:
833
833
  src_parent_path = Path(src).parent.as_posix()
834
834
  src_file = Path(src).name
835
835
  other_args: list[str] = ["--no-modtime", "--vfs-read-wait", "1s"]
836
- vfs_read_chunk_size = length // transfers
837
- vfs_read_chunk_size_limit = length
836
+ vfs_read_chunk_size = SizeSuffix(length // transfers)
837
+ vfs_read_chunk_size_limit = SizeSuffix(length)
838
838
  vfs_read_chunk_streams = transfers
839
- vfs_disk_space_total_size = length
839
+ vfs_disk_space_total_size = SizeSuffix(length)
840
840
  other_args += ["--vfs-read-chunk-size", str(vfs_read_chunk_size)]
841
841
  other_args += ["--vfs-read-chunk-size-limit", str(vfs_read_chunk_size_limit)]
842
842
  other_args += ["--vfs-read-chunk-streams", str(vfs_read_chunk_streams)]
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.2
2
2
  Name: rclone_api
3
- Version: 1.1.39
3
+ Version: 1.1.41
4
4
  Summary: rclone api in python
5
5
  Home-page: https://github.com/zackees/rclone-api
6
6
  License: BSD 3-Clause License
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes