|
|
|
# Ultralytics YOLO 🚀, AGPL-3.0 license
|
|
|
|
|
|
|
|
import shutil
|
|
|
|
from pathlib import Path
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
|
|
|
|
TMP = Path(__file__).resolve().parent / 'tmp' # temp directory for test files
|
|
|
|
|
|
|
|
|
|
|
|
def pytest_addoption(parser):
|
|
|
|
"""Add custom command-line options to pytest.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
parser (pytest.config.Parser): The pytest parser object.
|
|
|
|
"""
|
|
|
|
parser.addoption('--slow', action='store_true', default=False, help='Run slow tests')
|
|
|
|
|
|
|
|
|
|
|
|
def pytest_configure(config):
|
|
|
|
"""Register custom markers to avoid pytest warnings.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
config (pytest.config.Config): The pytest config object.
|
|
|
|
"""
|
|
|
|
config.addinivalue_line('markers', 'slow: mark test as slow to run')
|
|
|
|
|
|
|
|
|
|
|
|
def pytest_runtest_setup(item):
|
|
|
|
"""Setup hook to skip tests marked as slow if the --slow option is not provided.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
item (pytest.Item): The test item object.
|
|
|
|
"""
|
|
|
|
if 'slow' in item.keywords and not item.config.getoption('--slow'):
|
|
|
|
pytest.skip('skip slow tests unless --slow is set')
|
|
|
|
|
|
|
|
|
|
|
|
def pytest_collection_modifyitems(config, items):
|
|
|
|
"""
|
|
|
|
Modify the list of test items to remove tests marked as slow if the --slow option is not provided.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
config (pytest.config.Config): The pytest config object.
|
|
|
|
items (list): List of test items to be executed.
|
|
|
|
"""
|
|
|
|
if not config.getoption('--slow'):
|
|
|
|
# Remove the item entirely from the list of test items if it's marked as 'slow'
|
|
|
|
items[:] = [item for item in items if 'slow' not in item.keywords]
|
|
|
|
|
|
|
|
|
|
|
|
def pytest_sessionstart(session):
|
|
|
|
"""
|
|
|
|
Initialize session configurations for pytest.
|
|
|
|
|
|
|
|
This function is automatically called by pytest after the 'Session' object has been created but before performing
|
|
|
|
test collection. It sets the initial seeds and prepares the temporary directory for the test session.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
session (pytest.Session): The pytest session object.
|
|
|
|
"""
|
|
|
|
from ultralytics.utils.torch_utils import init_seeds
|
|
|
|
|
|
|
|
init_seeds()
|
|
|
|
shutil.rmtree(TMP, ignore_errors=True) # delete any existing tests/tmp directory
|
|
|
|
TMP.mkdir(parents=True, exist_ok=True) # create a new empty directory
|
|
|
|
|
|
|
|
|
|
|
|
def pytest_terminal_summary(terminalreporter, exitstatus, config):
|
|
|
|
"""
|
|
|
|
Cleanup operations after pytest session.
|
|
|
|
|
|
|
|
This function is automatically called by pytest at the end of the entire test session. It removes certain files
|
|
|
|
and directories used during testing.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
terminalreporter (pytest.terminal.TerminalReporter): The terminal reporter object.
|
|
|
|
exitstatus (int): The exit status of the test run.
|
|
|
|
config (pytest.config.Config): The pytest config object.
|
|
|
|
"""
|
|
|
|
from ultralytics.utils import WEIGHTS_DIR
|
|
|
|
|
|
|
|
# Remove files
|
|
|
|
models = [path for x in ['*.onnx', '*.torchscript'] for path in WEIGHTS_DIR.rglob(x)]
|
|
|
|
for file in ['bus.jpg', 'yolov8n.onnx', 'yolov8n.torchscript'] + models:
|
|
|
|
Path(file).unlink(missing_ok=True)
|
|
|
|
|
|
|
|
# Remove directories
|
|
|
|
models = [path for x in ['*.mlpackage', '*_openvino_model'] for path in WEIGHTS_DIR.rglob(x)]
|
|
|
|
for directory in [TMP.parents[1] / '.pytest_cache', TMP] + models:
|
|
|
|
shutil.rmtree(directory, ignore_errors=True)
|