Skip to content

Commit

Permalink
feat: make unpack_7zarchive raise ReadError for invalid files
Browse files Browse the repository at this point in the history
  • Loading branch information
francoisfreitag committed Jul 1, 2024
1 parent 72fd6f1 commit c0ebecc
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 3 deletions.
3 changes: 3 additions & 0 deletions py7zr/py7zr.py
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@
import sys
import time
from multiprocessing import Process
from shutil import ReadError
from threading import Thread
from typing import IO, Any, BinaryIO, Collection, Dict, List, Optional, Tuple, Type, Union

Expand Down Expand Up @@ -1210,6 +1211,8 @@ def unpack_7zarchive(archive, path, extra=None):
"""
Function for registering with shutil.register_unpack_format().
"""
if not is_7zfile(archive):
raise ReadError(f"{archive} is not a 7zip file.")
with SevenZipFile(archive) as arc:
arc.extractall(path)

Expand Down
9 changes: 9 additions & 0 deletions tests/conftest.py
Original file line number Diff line number Diff line change
@@ -1,9 +1,18 @@
# Configuration for pytest.
# Thanks to Guilherme Salgado.

import shutil

import cpuinfo
import pytest

from py7zr import unpack_7zarchive


@pytest.fixture(scope="session")
def register_shutil_unpack_format():
shutil.register_unpack_format('7zip', ['.7z'], unpack_7zarchive)


def pytest_benchmark_update_json(config, benchmarks, output_json):
"""Calculate compression/decompression speed and add as extra_info"""
Expand Down
11 changes: 8 additions & 3 deletions tests/test_extract.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,12 +7,12 @@
import shutil
import subprocess
import sys
import tempfile
from datetime import datetime

import pytest

import py7zr
from py7zr import unpack_7zarchive
from py7zr.exceptions import CrcError, UnsupportedCompressionMethodError
from py7zr.helpers import UTC

Expand Down Expand Up @@ -306,8 +306,7 @@ def test_zerosize_mem():


@pytest.mark.api
def test_register_unpack_archive(tmp_path):
shutil.register_unpack_format("7zip", [".7z"], unpack_7zarchive)
def test_register_unpack_archive(register_shutil_unpack_format, tmp_path):
shutil.unpack_archive(str(testdata_path.joinpath("test_1.7z")), str(tmp_path))
target = tmp_path.joinpath("setup.cfg")
expected_mode = 33188
Expand All @@ -326,6 +325,12 @@ def test_register_unpack_archive(tmp_path):
assert m.digest() == binascii.unhexlify("b0385e71d6a07eb692f5fb9798e9d33aaf87be7dfff936fd2473eab2a593d4fd")


@pytest.mark.api
def test_register_unpack_archive_error(register_shutil_unpack_format, tmp_path):
with tempfile.NamedTemporaryFile(suffix=".7z") as f, pytest.raises(shutil.ReadError):
shutil.unpack_archive(f.name, str(tmp_path))


@pytest.mark.files
def test_skip():
archive = py7zr.SevenZipFile(testdata_path.joinpath("test_1.7z").open(mode="rb"))
Expand Down

0 comments on commit c0ebecc

Please sign in to comment.