mirror of
https://github.com/netinvent/npbackup.git
synced 2025-10-04 02:36:33 +08:00
tests: Improve restic download strategy
This commit is contained in:
parent
bbc19f749d
commit
cb89b3de36
2 changed files with 43 additions and 30 deletions
|
@ -23,7 +23,7 @@ sys.path.insert(0, os.path.normpath(os.path.join(os.path.dirname(__file__), ".."
|
|||
from npbackup.path_helper import BASEDIR
|
||||
|
||||
|
||||
def download_restic_binaries(arch: str = "amd64", move_is_fatal: bool = True) -> bool:
|
||||
def download_restic_binaries(arch: str = "amd64") -> bool:
|
||||
"""
|
||||
We must first download latest restic binaries to make sure we can run all tests and/or compile
|
||||
"""
|
||||
|
@ -36,29 +36,54 @@ def download_restic_binaries(arch: str = "amd64", move_is_fatal: bool = True) ->
|
|||
# print("RESPONSE: ", response)
|
||||
json_response = json.loads(response.text)
|
||||
current_version = json_response["tag_name"].lstrip("v")
|
||||
|
||||
# print("JSON RESPONSE")
|
||||
# pprint(json_response, indent=5)
|
||||
|
||||
dest_dir = Path(BASEDIR).absolute().parent.joinpath("RESTIC_SOURCE_FILES")
|
||||
if os.name == "nt":
|
||||
fname = f"_windows_{arch}.zip"
|
||||
fname = f"_windows_{arch}"
|
||||
suffix = ".exe"
|
||||
arch_suffix = ".zip"
|
||||
else:
|
||||
fname = f"_linux_{arch}.bz2"
|
||||
fname = f"_linux_{arch}"
|
||||
suffix = ""
|
||||
arch_suffix = ".bz2"
|
||||
|
||||
if not dest_dir.joinpath("ARCHIVES").is_dir():
|
||||
os.makedirs(dest_dir.joinpath("ARCHIVES"))
|
||||
|
||||
dest_file = dest_dir.joinpath("restic_" + current_version + fname + arch_suffix)
|
||||
|
||||
dest_file = dest_dir.joinpath("restic_" + current_version + fname).with_suffix(
|
||||
suffix
|
||||
)
|
||||
if dest_file.is_file():
|
||||
print(f"RESTIC SOURCE ALREADY PRESENT. NOT DOWNLOADING {dest_file}")
|
||||
return True
|
||||
else:
|
||||
print(f"DOWNALOADING RESTIC {dest_file}")
|
||||
# Also we need to move any earlier file that may not be current version to archives
|
||||
for file in dest_dir.glob(f"restic_*{fname}{suffix}"):
|
||||
# We need to keep legacy binary for Windows 7 32 bits
|
||||
if (
|
||||
not file == "restic_0.16.2_windows_386.exe"
|
||||
and not file == "restic_0.16.2_windows_amd64.exe"
|
||||
):
|
||||
try:
|
||||
archive_file = dest_dir.joinpath("ARCHIVES").joinpath(file.name)
|
||||
if archive_file.is_file():
|
||||
archive_file.unlink()
|
||||
shutil.move(
|
||||
file,
|
||||
archive_file,
|
||||
)
|
||||
except OSError as exc:
|
||||
print(
|
||||
f"CANNOT MOVE OLD FILES ARCHIVE: {file} to {archive_file}: {exc}"
|
||||
)
|
||||
return False
|
||||
|
||||
downloaded = False
|
||||
for entry in json_response["assets"]:
|
||||
if fname in entry["browser_download_url"]:
|
||||
if f"{fname}{arch_suffix}" in entry["browser_download_url"]:
|
||||
file_request = requests.get(
|
||||
entry["browser_download_url"], allow_redirects=True
|
||||
)
|
||||
|
@ -66,26 +91,25 @@ def download_restic_binaries(arch: str = "amd64", move_is_fatal: bool = True) ->
|
|||
filename = entry["browser_download_url"].rsplit("/", 1)[1]
|
||||
full_path = dest_dir.joinpath(filename)
|
||||
print("PATH TO DOWNLOADED ARCHIVE: ", full_path)
|
||||
if fname.endswith("bz2"):
|
||||
with open(full_path.with_suffix(""), "wb") as fp:
|
||||
if arch_suffix == ".bz2":
|
||||
with open(str(full_path).rstrip("arch_suffix"), "wb") as fp:
|
||||
fp.write(bz2.decompress(file_request.content))
|
||||
# We also need to make that file executable
|
||||
os.chmod(full_path.with_suffix(""), 0o775)
|
||||
os.chmod(str(full_path).rstrip(arch_suffix), 0o775)
|
||||
else:
|
||||
with open(full_path, "wb") as fp:
|
||||
fp.write(file_request.content)
|
||||
# Assume we have a zip or tar.gz
|
||||
shutil.unpack_archive(full_path, dest_dir)
|
||||
try:
|
||||
if not dest_dir.joinpath("ARCHIVES").is_dir():
|
||||
os.makedirs(dest_dir.joinpath("ARCHIVES"))
|
||||
if dest_dir.joinpath("ARCHIVES").joinpath(filename).is_file():
|
||||
dest_dir.joinpath("ARCHIVES").joinpath(filename).unlink()
|
||||
shutil.move(full_path, dest_dir.joinpath("ARCHIVES").joinpath(filename))
|
||||
except OSError:
|
||||
if move_is_fatal:
|
||||
print(
|
||||
f'CANNOT MOVE TO ARCHIVE: {full_path} to {dest_dir.joinpath("ARCHIVES").joinpath(filename)}'
|
||||
)
|
||||
return False
|
||||
except OSError as exc:
|
||||
print(
|
||||
f'CANNOT MOVE TO ARCHIVE: {full_path} to {dest_dir.joinpath("ARCHIVES").joinpath(filename)}: {[exc]}'
|
||||
)
|
||||
return False
|
||||
print(f"DOWNLOADED {dest_dir}")
|
||||
downloaded = True
|
||||
break
|
||||
|
|
|
@ -65,15 +65,6 @@ repo_config, _ = get_repo_config(full_config)
|
|||
DUMP_FILE = "__version__.py"
|
||||
|
||||
|
||||
def running_on_github_actions():
|
||||
"""
|
||||
This is set in github actions workflow with
|
||||
env:
|
||||
RUNNING_ON_GITHUB_ACTIONS: true
|
||||
"""
|
||||
return os.environ.get("RUNNING_ON_GITHUB_ACTIONS", "False").lower() == "true"
|
||||
|
||||
|
||||
class RedirectedStdout:
|
||||
"""
|
||||
Balantly copied from https://stackoverflow.com/a/45899925/2635443
|
||||
|
@ -100,9 +91,7 @@ def test_download_restic_binaries():
|
|||
We must first download latest restic binaries to make sure we can run all tests
|
||||
Currently we only run these on amd64
|
||||
"""
|
||||
assert download_restic_binaries(
|
||||
"amd64", move_is_fatal=not running_on_github_actions()
|
||||
), "Could not download restic binaries"
|
||||
assert download_restic_binaries("amd64"), "Could not download restic binaries"
|
||||
|
||||
|
||||
def test_npbackup_cli_no_config():
|
||||
|
|
Loading…
Add table
Reference in a new issue