Add set mode shards in teardown test ec #298
1 changed files with 23 additions and 5 deletions
|
@ -1,7 +1,10 @@
|
||||||
import json
|
import json
|
||||||
from dataclasses import dataclass
|
from dataclasses import dataclass
|
||||||
|
import time
|
||||||
|
|
||||||
import allure
|
import allure
|
||||||
|
from frostfs_testlib.shell.interfaces import Shell
|
||||||
|
from frostfs_testlib.utils import datetime_utils
|
||||||
import pytest
|
import pytest
|
||||||
import yaml
|
import yaml
|
||||||
from frostfs_testlib import plugins, reporter
|
from frostfs_testlib import plugins, reporter
|
||||||
|
@ -9,7 +12,7 @@ from frostfs_testlib.cli import FrostfsAdm, FrostfsCli
|
||||||
from frostfs_testlib.cli.netmap_parser import NetmapParser
|
from frostfs_testlib.cli.netmap_parser import NetmapParser
|
||||||
from frostfs_testlib.credentials.interfaces import User
|
from frostfs_testlib.credentials.interfaces import User
|
||||||
from frostfs_testlib.resources.cli import CLI_DEFAULT_TIMEOUT, FROSTFS_ADM_CONFIG_PATH, FROSTFS_ADM_EXEC, FROSTFS_CLI_EXEC
|
from frostfs_testlib.resources.cli import CLI_DEFAULT_TIMEOUT, FROSTFS_ADM_CONFIG_PATH, FROSTFS_ADM_EXEC, FROSTFS_CLI_EXEC
|
||||||
from frostfs_testlib.resources.common import COMPLEX_OBJECT_CHUNKS_COUNT, COMPLEX_OBJECT_TAIL_SIZE, HOSTING_CONFIG_FILE
|
from frostfs_testlib.resources.common import COMPLEX_OBJECT_CHUNKS_COUNT, COMPLEX_OBJECT_TAIL_SIZE, HOSTING_CONFIG_FILE, MORPH_BLOCK_TIME
|
||||||
from frostfs_testlib.s3 import AwsCliClient, S3ClientWrapper
|
from frostfs_testlib.s3 import AwsCliClient, S3ClientWrapper
|
||||||
from frostfs_testlib.s3.interfaces import BucketContainerResolver, VersioningStatus
|
from frostfs_testlib.s3.interfaces import BucketContainerResolver, VersioningStatus
|
||||||
from frostfs_testlib.steps.cli.object import get_object, put_object
|
from frostfs_testlib.steps.cli.object import get_object, put_object
|
||||||
|
@ -67,6 +70,21 @@ def frostfs_remote_adm(cluster: Cluster) -> FrostfsAdm:
|
||||||
@pytest.mark.replication
|
@pytest.mark.replication
|
||||||
@pytest.mark.ec_replication
|
@pytest.mark.ec_replication
|
||||||
class TestECReplication(ClusterTestBase):
|
class TestECReplication(ClusterTestBase):
|
||||||
|
def get_node_cli(self, cluster_node: ClusterNode, config: str) -> FrostfsCli:
|
||||||
|
shell = cluster_node.host.get_shell()
|
||||||
|
cli = FrostfsCli(shell, frostfs_cli_exec_path=FROSTFS_CLI_EXEC, config_file=config)
|
||||||
|
self.cli_change_shards_mode: dict[FrostfsCli, str] = {cli: cluster_node.storage_node.get_control_endpoint()}
|
||||||
|
return cli
|
||||||
|
|
||||||
|
@pytest.fixture()
|
||||||
|
def restore_nodes_shards_mode(self):
|
||||||
|
yield
|
||||||
|
|
||||||
|
for cli, endpoint in self.cli_change_shards_mode.items():
|
||||||
|
cli.shards.set_mode(endpoint, mode='read-write', all=True)
|
||||||
|
|
||||||
|
time.sleep(datetime_utils.parse_time(MORPH_BLOCK_TIME))
|
||||||
|
|
||||||
@pytest.fixture()
|
@pytest.fixture()
|
||||||
def rep_count(self, object_size: ObjectSize) -> int:
|
def rep_count(self, object_size: ObjectSize) -> int:
|
||||||
rep_count = 3
|
rep_count = 3
|
||||||
|
@ -777,6 +795,7 @@ class TestECReplication(ClusterTestBase):
|
||||||
@pytest.mark.parametrize("type, get_chunk", [("data", get_data_chunk_object), ("parity", get_parity_chunk_object)])
|
@pytest.mark.parametrize("type, get_chunk", [("data", get_data_chunk_object), ("parity", get_parity_chunk_object)])
|
||||||
def test_evacuation_data_shard(
|
def test_evacuation_data_shard(
|
||||||
self,
|
self,
|
||||||
|
restore_nodes_shards_mode: None,
|
||||||
default_user: User,
|
default_user: User,
|
||||||
frostfs_cli: FrostfsCli,
|
frostfs_cli: FrostfsCli,
|
||||||
max_object_size: int,
|
max_object_size: int,
|
||||||
|
@ -793,10 +812,9 @@ class TestECReplication(ClusterTestBase):
|
||||||
with reporter.step("Get object chunks."):
|
with reporter.step("Get object chunks."):
|
||||||
chunk = get_chunk(self, frostfs_cli, cid, oid, self.cluster.default_rpc_endpoint)
|
chunk = get_chunk(self, frostfs_cli, cid, oid, self.cluster.default_rpc_endpoint)
|
||||||
chunk_node = self.get_chunk_node(frostfs_cli, chunk)
|
chunk_node = self.get_chunk_node(frostfs_cli, chunk)
|
||||||
frostfs_node_cli = FrostfsCli(
|
frostfs_node_cli = self.get_node_cli(
|
||||||
chunk_node[0].host.get_shell(),
|
chunk_node[0],
|
||||||
frostfs_cli_exec_path=FROSTFS_CLI_EXEC,
|
config=chunk_node[0].storage_node.get_remote_wallet_config_path(),
|
||||||
config_file=chunk_node[0].storage_node.get_remote_wallet_config_path(),
|
|
||||||
)
|
)
|
||||||
|
|
||||||
with reporter.step("Search shards chunk"):
|
with reporter.step("Search shards chunk"):
|
||||||
|
|
Loading…
Reference in a new issue