1
0
mirror of https://codeberg.org/privacy1st/subprocess-util synced 2025-01-13 00:46:07 +01:00

112 lines
3.1 KiB
Python
Raw Normal View History

2023-01-10 20:18:28 +01:00
import os
2023-01-10 22:13:56 +01:00
import shutil
2023-01-10 17:24:35 +01:00
from pathlib import Path
2023-01-10 20:18:28 +01:00
from exec_capture import execute_capture
from exec_print_capture import execute_print_capture
from exec_print_transfer import execute_print_transfer_chunks
2023-01-10 22:13:56 +01:00
from transfer_inform import transfer_inform
2023-01-10 15:42:33 +01:00
def test():
2023-01-10 20:18:28 +01:00
# test1()
# test2()
# test3()
# test4()
test5()
def test1():
2023-01-10 22:13:56 +01:00
_init(1)
returncode, out, err = execute_capture(['ls', '-la'])
print(f'stdout:\n{out}\nstderr:\n{err}')
print()
returncode, out, err = execute_capture(['ls', '/foo/bar'])
print(f'stdout:\n{out}\nstderr:\n{err}')
2023-01-10 17:24:35 +01:00
def test2():
2023-01-10 22:13:56 +01:00
_init(2)
2023-01-10 15:42:33 +01:00
returncode, out, err = execute_print_capture(['ls', '-la'])
print()
returncode, out, err = execute_print_capture(['ls', '/foo/bar'])
def test3():
2023-01-10 22:13:56 +01:00
_init(3)
2023-01-10 20:18:28 +01:00
returncode = execute_print_transfer_chunks(['ls', '-la'], Path('test/3-1'))
print("TEST 3-2")
returncode = execute_print_transfer_chunks(['ls', '/foo/bar'], Path('test/3-2'))
print("TEST 3-3")
2023-01-10 22:13:56 +01:00
returncode = execute_print_transfer_chunks(['cat', 'transfer_inform.py'], Path('test/3-3'),
chunk_size=1024)
def test4():
2023-01-10 22:13:56 +01:00
_init(4)
2023-01-10 20:18:28 +01:00
2023-01-10 22:13:56 +01:00
transfer_inform(
2023-01-10 20:18:28 +01:00
['ls', 'test/4-rsync-error'], # rsync src to dst
['ls', 'test/4-ssh-error'], # ssh target-pc 'echo "OK" | nc -U "/path/to/unix-socket"'
Path('test/4-UNIX-socket')
)
def test5():
2023-01-10 22:13:56 +01:00
_init(5)
2023-01-10 20:18:28 +01:00
2023-01-10 22:13:56 +01:00
chunk_file_tmpl = Path('test/5')
source_file = Path('transfer_inform.py') # A python script file with some content to copy ;)
2023-01-10 20:18:28 +01:00
remote_target_file = Path(f'test/5-copy-of-{source_file}')
ssh_error_file = Path('test/5-ssh-error-while-informing-remote-pc')
concat_script = Path('test/5-concat')
concat_script.write_text(f'#!/usr/bin/bash\n'
2023-01-10 22:13:56 +01:00
f'echo "rsync $1 ... command output"\n'
2023-01-10 20:18:28 +01:00
f'cat "$1" >> "$2"')
os.chmod(concat_script, 0o0755)
# TODO:
# When running this test:
2023-01-10 22:13:56 +01:00
# The intentionally generated error, can be fixed by touching (creating) the missing file.
2023-01-10 20:18:28 +01:00
execute_print_transfer_chunks(
command=['cat', str(source_file)],
2023-01-10 22:13:56 +01:00
chunk_file_tmpl=chunk_file_tmpl,
chunk_transfer_fun=_chunk_transfer_fun,
chunk_transfer_args=(ssh_error_file, concat_script, remote_target_file),
2023-01-10 20:18:28 +01:00
chunk_size=512,
)
2023-01-10 17:24:35 +01:00
2023-01-10 15:42:33 +01:00
2023-01-10 22:13:56 +01:00
def _chunk_transfer_fun(chunk_file: Path,
eof: bool,
ssh_error_file: Path,
concat_script: Path,
remote_target_file: Path):
rsync_cmd = [str(concat_script), str(chunk_file), str(remote_target_file)]
inform_cmd = ['ls',
chunk_file.parent.joinpath(f'5.remote.EOF={eof}'),
]
transfer_inform(
rsync_cmd=rsync_cmd,
inform_cmd=inform_cmd,
user_input_file=chunk_file.parent.joinpath(f'5.SOCKET'),
)
def _init(test_number: int):
print(f"TEST {test_number}")
test_dir = Path('test')
if test_dir.exists():
shutil.rmtree('test')
Path('test').mkdir(exist_ok=False)
2023-01-10 15:42:33 +01:00
if __name__ == '__main__':
test()