2024-07-26 13:34:47 +00:00
|
|
|
import logging
|
|
|
|
import os
|
|
|
|
from importlib.metadata import entry_points
|
|
|
|
|
|
|
|
import pytest
|
|
|
|
import yaml
|
|
|
|
|
|
|
|
from frostfs_testlib import reporter
|
|
|
|
from frostfs_testlib.hosting.hosting import Hosting
|
2024-09-10 12:14:32 +00:00
|
|
|
from frostfs_testlib.resources.common import ASSETS_DIR, HOSTING_CONFIG_FILE
|
2024-07-26 13:34:47 +00:00
|
|
|
from frostfs_testlib.storage import get_service_registry
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(scope="session")
|
|
|
|
def configure_testlib():
|
|
|
|
reporter.get_reporter().register_handler(reporter.AllureHandler())
|
|
|
|
reporter.get_reporter().register_handler(reporter.StepsLogger())
|
|
|
|
logging.getLogger("paramiko").setLevel(logging.INFO)
|
|
|
|
|
|
|
|
# Register Services for cluster
|
|
|
|
registry = get_service_registry()
|
|
|
|
services = entry_points(group="frostfs.testlib.services")
|
|
|
|
for svc in services:
|
|
|
|
registry.register_service(svc.name, svc.load())
|
|
|
|
|
|
|
|
|
2024-09-10 12:14:32 +00:00
|
|
|
@pytest.fixture(scope="session")
|
|
|
|
def temp_directory(configure_testlib):
|
|
|
|
with reporter.step("Prepare tmp directory"):
|
|
|
|
full_path = ASSETS_DIR
|
|
|
|
if not os.path.exists(full_path):
|
|
|
|
os.mkdir(full_path)
|
|
|
|
|
|
|
|
return full_path
|
|
|
|
|
|
|
|
|
2024-07-26 13:34:47 +00:00
|
|
|
@pytest.fixture(scope="session")
|
|
|
|
def hosting(configure_testlib) -> Hosting:
|
|
|
|
with open(HOSTING_CONFIG_FILE, "r") as file:
|
|
|
|
hosting_config = yaml.full_load(file)
|
|
|
|
|
|
|
|
hosting_instance = Hosting()
|
|
|
|
hosting_instance.configure(hosting_config)
|
|
|
|
|
|
|
|
return hosting_instance
|