forked from TrueCloudLab/frostfs-testlib
285 lines
7.7 KiB
Python
285 lines
7.7 KiB
Python
from abc import ABC, abstractmethod
|
|
from typing import Any, Optional
|
|
|
|
from frostfs_testlib.resources.cli import CLI_DEFAULT_TIMEOUT
|
|
from frostfs_testlib.shell.interfaces import CommandResult
|
|
from frostfs_testlib.storage.cluster import Cluster, ClusterNode
|
|
from frostfs_testlib.storage.constants import PlacementRule
|
|
from frostfs_testlib.storage.dataclasses.storage_object_info import Chunk, NodeNetmapInfo
|
|
from frostfs_testlib.utils import file_utils
|
|
|
|
|
|
class ChunksInterface(ABC):
|
|
@abstractmethod
|
|
def search_node_without_chunks(self, chunks: list[Chunk], cluster: Cluster, endpoint: str = None) -> list[ClusterNode]:
|
|
pass
|
|
|
|
@abstractmethod
|
|
def get_chunk_node(self, cluster: Cluster, chunk: Chunk) -> tuple[ClusterNode, NodeNetmapInfo]:
|
|
pass
|
|
|
|
@abstractmethod
|
|
def get_shard_chunk(self, node: ClusterNode, chunk: Chunk) -> str:
|
|
pass
|
|
|
|
@abstractmethod
|
|
def get_all(
|
|
self,
|
|
rpc_endpoint: str,
|
|
cid: str,
|
|
oid: str,
|
|
wallet: Optional[str] = None,
|
|
address: Optional[str] = None,
|
|
bearer: Optional[str] = None,
|
|
generate_key: Optional[bool] = None,
|
|
trace: bool = False,
|
|
root: bool = False,
|
|
verify_presence_all: bool = False,
|
|
json: bool = True,
|
|
ttl: Optional[int] = None,
|
|
xhdr: Optional[dict] = None,
|
|
timeout: Optional[str] = None,
|
|
) -> list[Chunk]:
|
|
pass
|
|
|
|
@abstractmethod
|
|
def get_parity(
|
|
self,
|
|
rpc_endpoint: str,
|
|
cid: str,
|
|
wallet: Optional[str] = None,
|
|
address: Optional[str] = None,
|
|
bearer: Optional[str] = None,
|
|
generate_key: Optional[bool] = None,
|
|
oid: Optional[str] = None,
|
|
trace: bool = False,
|
|
root: bool = False,
|
|
verify_presence_all: bool = False,
|
|
json: bool = True,
|
|
ttl: Optional[int] = None,
|
|
xhdr: Optional[dict] = None,
|
|
timeout: Optional[str] = None,
|
|
) -> Chunk:
|
|
pass
|
|
|
|
@abstractmethod
|
|
def get_first_data(
|
|
self,
|
|
rpc_endpoint: str,
|
|
cid: str,
|
|
wallet: Optional[str] = None,
|
|
address: Optional[str] = None,
|
|
bearer: Optional[str] = None,
|
|
generate_key: Optional[bool] = None,
|
|
oid: Optional[str] = None,
|
|
trace: bool = False,
|
|
root: bool = False,
|
|
verify_presence_all: bool = False,
|
|
json: bool = True,
|
|
ttl: Optional[int] = None,
|
|
xhdr: Optional[dict] = None,
|
|
timeout: Optional[str] = None,
|
|
) -> Chunk:
|
|
pass
|
|
|
|
|
|
class ObjectInterface(ABC):
|
|
def __init__(self) -> None:
|
|
self.chunks: ChunksInterface
|
|
|
|
@abstractmethod
|
|
def delete(
|
|
self,
|
|
cid: str,
|
|
oid: str,
|
|
endpoint: str,
|
|
bearer: str = "",
|
|
xhdr: Optional[dict] = None,
|
|
session: Optional[str] = None,
|
|
timeout: Optional[str] = CLI_DEFAULT_TIMEOUT,
|
|
) -> str:
|
|
pass
|
|
|
|
@abstractmethod
|
|
def get(
|
|
self,
|
|
cid: str,
|
|
oid: str,
|
|
endpoint: str,
|
|
bearer: Optional[str] = None,
|
|
write_object: Optional[str] = None,
|
|
xhdr: Optional[dict] = None,
|
|
no_progress: bool = True,
|
|
session: Optional[str] = None,
|
|
timeout: Optional[str] = CLI_DEFAULT_TIMEOUT,
|
|
) -> file_utils.TestFile:
|
|
pass
|
|
|
|
@abstractmethod
|
|
def get_from_random_node(
|
|
self,
|
|
cid: str,
|
|
oid: str,
|
|
cluster: Cluster,
|
|
bearer: Optional[str] = None,
|
|
write_object: Optional[str] = None,
|
|
xhdr: Optional[dict] = None,
|
|
no_progress: bool = True,
|
|
session: Optional[str] = None,
|
|
timeout: Optional[str] = CLI_DEFAULT_TIMEOUT,
|
|
) -> str:
|
|
pass
|
|
|
|
@abstractmethod
|
|
def hash(
|
|
self,
|
|
rpc_endpoint: str,
|
|
cid: str,
|
|
oid: str,
|
|
address: Optional[str] = None,
|
|
bearer: Optional[str] = None,
|
|
generate_key: Optional[bool] = None,
|
|
range: Optional[str] = None,
|
|
salt: Optional[str] = None,
|
|
ttl: Optional[int] = None,
|
|
session: Optional[str] = None,
|
|
hash_type: Optional[str] = None,
|
|
xhdr: Optional[dict] = None,
|
|
timeout: Optional[str] = CLI_DEFAULT_TIMEOUT,
|
|
) -> str:
|
|
pass
|
|
|
|
@abstractmethod
|
|
def head(
|
|
self,
|
|
cid: str,
|
|
oid: str,
|
|
endpoint: str,
|
|
bearer: str = "",
|
|
xhdr: Optional[dict] = None,
|
|
json_output: bool = True,
|
|
is_raw: bool = False,
|
|
is_direct: bool = False,
|
|
session: Optional[str] = None,
|
|
timeout: Optional[str] = CLI_DEFAULT_TIMEOUT,
|
|
) -> CommandResult | Any:
|
|
pass
|
|
|
|
@abstractmethod
|
|
def lock(
|
|
self,
|
|
cid: str,
|
|
oid: str,
|
|
endpoint: str,
|
|
lifetime: Optional[int] = None,
|
|
expire_at: Optional[int] = None,
|
|
address: Optional[str] = None,
|
|
bearer: Optional[str] = None,
|
|
session: Optional[str] = None,
|
|
ttl: Optional[int] = None,
|
|
xhdr: Optional[dict] = None,
|
|
timeout: Optional[str] = CLI_DEFAULT_TIMEOUT,
|
|
) -> str:
|
|
pass
|
|
|
|
@abstractmethod
|
|
def put(
|
|
self,
|
|
path: str,
|
|
cid: str,
|
|
endpoint: str,
|
|
bearer: Optional[str] = None,
|
|
copies_number: Optional[int] = None,
|
|
attributes: Optional[dict] = None,
|
|
xhdr: Optional[dict] = None,
|
|
expire_at: Optional[int] = None,
|
|
no_progress: bool = True,
|
|
session: Optional[str] = None,
|
|
timeout: Optional[str] = CLI_DEFAULT_TIMEOUT,
|
|
) -> str:
|
|
pass
|
|
|
|
@abstractmethod
|
|
def put_to_random_node(
|
|
self,
|
|
path: str,
|
|
cid: str,
|
|
cluster: Cluster,
|
|
bearer: Optional[str] = None,
|
|
copies_number: Optional[int] = None,
|
|
attributes: Optional[dict] = None,
|
|
xhdr: Optional[dict] = None,
|
|
expire_at: Optional[int] = None,
|
|
no_progress: bool = True,
|
|
session: Optional[str] = None,
|
|
timeout: Optional[str] = CLI_DEFAULT_TIMEOUT,
|
|
) -> str:
|
|
pass
|
|
|
|
@abstractmethod
|
|
def range(
|
|
self,
|
|
cid: str,
|
|
oid: str,
|
|
range_cut: str,
|
|
endpoint: str,
|
|
bearer: str = "",
|
|
xhdr: Optional[dict] = None,
|
|
session: Optional[str] = None,
|
|
timeout: Optional[str] = CLI_DEFAULT_TIMEOUT,
|
|
) -> tuple[file_utils.TestFile, bytes]:
|
|
pass
|
|
|
|
@abstractmethod
|
|
def search(
|
|
self,
|
|
cid: str,
|
|
endpoint: str,
|
|
bearer: str = "",
|
|
filters: Optional[dict] = None,
|
|
expected_objects_list: Optional[list] = None,
|
|
xhdr: Optional[dict] = None,
|
|
session: Optional[str] = None,
|
|
phy: bool = False,
|
|
root: bool = False,
|
|
timeout: Optional[str] = CLI_DEFAULT_TIMEOUT,
|
|
) -> list:
|
|
pass
|
|
|
|
@abstractmethod
|
|
def nodes(
|
|
self,
|
|
cluster: Cluster,
|
|
cid: str,
|
|
oid: str,
|
|
alive_node: ClusterNode,
|
|
bearer: str = "",
|
|
xhdr: Optional[dict] = None,
|
|
is_direct: bool = False,
|
|
verify_presence_all: bool = False,
|
|
timeout: Optional[str] = CLI_DEFAULT_TIMEOUT,
|
|
) -> list[ClusterNode]:
|
|
pass
|
|
|
|
|
|
class ContainerInterface(ABC):
|
|
@abstractmethod
|
|
def create(
|
|
self,
|
|
endpoint: str,
|
|
rule: str = PlacementRule.DEFAULT_PLACEMENT_RULE,
|
|
basic_acl: str = "",
|
|
attributes: Optional[dict] = None,
|
|
session_token: str = "",
|
|
name: Optional[str] = None,
|
|
options: Optional[dict] = None,
|
|
await_mode: bool = True,
|
|
timeout: Optional[str] = CLI_DEFAULT_TIMEOUT,
|
|
) -> str:
|
|
pass
|
|
|
|
|
|
class GrpcClientWrapper(ABC):
|
|
def __init__(self) -> None:
|
|
self.object: ObjectInterface
|
|
self.container: ContainerInterface
|