sinc master branch #1
5 changed files with 108 additions and 612 deletions
24
pytest_tests/resources/load_params.py
Normal file
24
pytest_tests/resources/load_params.py
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
import os
|
||||||
|
|
||||||
|
# Load node parameters
|
||||||
|
LOAD_NODES = os.getenv("LOAD_NODES", "").split(",")
|
||||||
|
LOAD_NODE_SSH_USER = os.getenv("LOAD_NODE_SSH_USER", "root")
|
||||||
|
LOAD_NODE_SSH_PRIVATE_KEY_PATH = os.getenv("LOAD_NODE_SSH_PRIVATE_KEY_PATH")
|
||||||
|
BACKGROUND_WRITERS_COUNT = os.getenv("BACKGROUND_WRITERS_COUNT", 10)
|
||||||
|
BACKGROUND_READERS_COUNT = os.getenv("BACKGROUND_READERS_COUNT", 10)
|
||||||
|
BACKGROUND_OBJ_SIZE = os.getenv("BACKGROUND_OBJ_SIZE", 1024)
|
||||||
|
BACKGROUND_LOAD_MAX_TIME = os.getenv("BACKGROUND_LOAD_MAX_TIME", 600)
|
||||||
|
|
||||||
|
# Load run parameters
|
||||||
|
|
||||||
|
OBJ_SIZE = os.getenv("OBJ_SIZE", "1000").split(",")
|
||||||
|
CONTAINERS_COUNT = os.getenv("CONTAINERS_COUNT", "1").split(",")
|
||||||
|
OUT_FILE = os.getenv("OUT_FILE", "1mb_200.json").split(",")
|
||||||
|
OBJ_COUNT = os.getenv("OBJ_COUNT", "4").split(",")
|
||||||
|
WRITERS = os.getenv("WRITERS", "200").split(",")
|
||||||
|
READERS = os.getenv("READER", "0").split(",")
|
||||||
|
DELETERS = os.getenv("DELETERS", "0").split(",")
|
||||||
|
LOAD_TIME = os.getenv("LOAD_TIME", "200").split(",")
|
||||||
|
LOAD_TYPE = os.getenv("LOAD_TYPE", "grpc").split(",")
|
||||||
|
LOAD_NODES_COUNT = os.getenv("LOAD_NODES_COUNT", "1").split(",")
|
||||||
|
STORAGE_NODE_COUNT = os.getenv("STORAGE_NODE_COUNT", "4").split(",")
|
|
@ -12,6 +12,7 @@ from neofs_testlib.shell import CommandOptions, SSHShell
|
||||||
from neofs_testlib.shell.interfaces import InteractiveInput
|
from neofs_testlib.shell.interfaces import InteractiveInput
|
||||||
|
|
||||||
NEOFS_AUTHMATE_PATH = "neofs-s3-authmate"
|
NEOFS_AUTHMATE_PATH = "neofs-s3-authmate"
|
||||||
|
STOPPED_HOSTS = []
|
||||||
|
|
||||||
|
|
||||||
@allure.title("Get services endpoints")
|
@allure.title("Get services endpoints")
|
||||||
|
@ -22,6 +23,21 @@ def get_services_endpoints(
|
||||||
return [service_config.attributes[endpoint_attribute] for service_config in service_configs]
|
return [service_config.attributes[endpoint_attribute] for service_config in service_configs]
|
||||||
|
|
||||||
|
|
||||||
|
@allure.title("Stop nodes")
|
||||||
|
def stop_unused_nodes(storage_nodes: list, used_nodes_count: int):
|
||||||
|
for node in storage_nodes[used_nodes_count:]:
|
||||||
|
host = node.host
|
||||||
|
STOPPED_HOSTS.append(host)
|
||||||
|
host.stop_host("hard")
|
||||||
|
|
||||||
|
|
||||||
|
@allure.title("Start nodes")
|
||||||
|
def start_stopped_nodes():
|
||||||
|
for host in STOPPED_HOSTS:
|
||||||
|
host.start_host()
|
||||||
|
STOPPED_HOSTS.remove(host)
|
||||||
|
|
||||||
|
|
||||||
@allure.title("Init s3 client")
|
@allure.title("Init s3 client")
|
||||||
def init_s3_client(load_nodes: list, login: str, pkey: str, hosting: Hosting):
|
def init_s3_client(load_nodes: list, login: str, pkey: str, hosting: Hosting):
|
||||||
service_configs = hosting.find_service_configs(STORAGE_NODE_SERVICE_NAME_REGEX)
|
service_configs = hosting.find_service_configs(STORAGE_NODE_SERVICE_NAME_REGEX)
|
||||||
|
|
|
@ -12,17 +12,10 @@ from binary_version_helper import get_local_binaries_versions, get_remote_binari
|
||||||
from cluster import Cluster
|
from cluster import Cluster
|
||||||
from common import (
|
from common import (
|
||||||
ASSETS_DIR,
|
ASSETS_DIR,
|
||||||
BACKGROUND_LOAD_MAX_TIME,
|
|
||||||
BACKGROUND_OBJ_SIZE,
|
|
||||||
BACKGROUND_READERS_COUNT,
|
|
||||||
BACKGROUND_WRITERS_COUNT,
|
|
||||||
COMPLEX_OBJECT_CHUNKS_COUNT,
|
COMPLEX_OBJECT_CHUNKS_COUNT,
|
||||||
COMPLEX_OBJECT_TAIL_SIZE,
|
COMPLEX_OBJECT_TAIL_SIZE,
|
||||||
FREE_STORAGE,
|
FREE_STORAGE,
|
||||||
HOSTING_CONFIG_FILE,
|
HOSTING_CONFIG_FILE,
|
||||||
LOAD_NODE_SSH_PRIVATE_KEY_PATH,
|
|
||||||
LOAD_NODE_SSH_USER,
|
|
||||||
LOAD_NODES,
|
|
||||||
SIMPLE_OBJECT_SIZE,
|
SIMPLE_OBJECT_SIZE,
|
||||||
STORAGE_NODE_SERVICE_NAME_REGEX,
|
STORAGE_NODE_SERVICE_NAME_REGEX,
|
||||||
WALLET_PASS,
|
WALLET_PASS,
|
||||||
|
@ -30,6 +23,15 @@ from common import (
|
||||||
from env_properties import save_env_properties
|
from env_properties import save_env_properties
|
||||||
from k6 import LoadParams
|
from k6 import LoadParams
|
||||||
from load import get_services_endpoints, prepare_k6_instances
|
from load import get_services_endpoints, prepare_k6_instances
|
||||||
|
from load_params import (
|
||||||
|
BACKGROUND_LOAD_MAX_TIME,
|
||||||
|
BACKGROUND_OBJ_SIZE,
|
||||||
|
BACKGROUND_READERS_COUNT,
|
||||||
|
BACKGROUND_WRITERS_COUNT,
|
||||||
|
LOAD_NODE_SSH_PRIVATE_KEY_PATH,
|
||||||
|
LOAD_NODE_SSH_USER,
|
||||||
|
LOAD_NODES,
|
||||||
|
)
|
||||||
from neofs_testlib.hosting import Hosting
|
from neofs_testlib.hosting import Hosting
|
||||||
from neofs_testlib.reporter import AllureHandler, get_reporter
|
from neofs_testlib.reporter import AllureHandler, get_reporter
|
||||||
from neofs_testlib.shell import LocalShell, Shell
|
from neofs_testlib.shell import LocalShell, Shell
|
||||||
|
|
|
@ -1,12 +1,8 @@
|
||||||
from enum import Enum
|
|
||||||
|
|
||||||
import allure
|
import allure
|
||||||
import pytest
|
import pytest
|
||||||
|
from cluster_test_base import ClusterTestBase
|
||||||
from common import (
|
from common import (
|
||||||
HTTP_GATE_SERVICE_NAME_REGEX,
|
HTTP_GATE_SERVICE_NAME_REGEX,
|
||||||
LOAD_NODE_SSH_PRIVATE_KEY_PATH,
|
|
||||||
LOAD_NODE_SSH_USER,
|
|
||||||
LOAD_NODES,
|
|
||||||
S3_GATE_SERVICE_NAME_REGEX,
|
S3_GATE_SERVICE_NAME_REGEX,
|
||||||
STORAGE_NODE_SERVICE_NAME_REGEX,
|
STORAGE_NODE_SERVICE_NAME_REGEX,
|
||||||
)
|
)
|
||||||
|
@ -17,34 +13,63 @@ from load import (
|
||||||
init_s3_client,
|
init_s3_client,
|
||||||
multi_node_k6_run,
|
multi_node_k6_run,
|
||||||
prepare_k6_instances,
|
prepare_k6_instances,
|
||||||
|
start_stopped_nodes,
|
||||||
|
stop_unused_nodes,
|
||||||
|
)
|
||||||
|
from load_params import (
|
||||||
|
CONTAINERS_COUNT,
|
||||||
|
DELETERS,
|
||||||
|
LOAD_NODE_SSH_PRIVATE_KEY_PATH,
|
||||||
|
LOAD_NODE_SSH_USER,
|
||||||
|
LOAD_NODES,
|
||||||
|
LOAD_NODES_COUNT,
|
||||||
|
LOAD_TIME,
|
||||||
|
LOAD_TYPE,
|
||||||
|
OBJ_COUNT,
|
||||||
|
OBJ_SIZE,
|
||||||
|
OUT_FILE,
|
||||||
|
READERS,
|
||||||
|
STORAGE_NODE_COUNT,
|
||||||
|
WRITERS,
|
||||||
)
|
)
|
||||||
from neofs_testlib.hosting import Hosting
|
from neofs_testlib.hosting import Hosting
|
||||||
|
|
||||||
|
ENDPOINTS_ATTRIBUTES = {
|
||||||
class LoadTime(Enum):
|
"http": {"regex": HTTP_GATE_SERVICE_NAME_REGEX, "endpoint_attribute": "endpoint"},
|
||||||
EXPECTED_MAXIMUM = 200
|
"grpc": {"regex": STORAGE_NODE_SERVICE_NAME_REGEX, "endpoint_attribute": "rpc_endpoint"},
|
||||||
PMI_EXPECTATION = 900
|
"s3": {"regex": S3_GATE_SERVICE_NAME_REGEX, "endpoint_attribute": "endpoint"},
|
||||||
|
}
|
||||||
|
|
||||||
CONTAINERS_COUNT = 1
|
|
||||||
OBJ_COUNT = 3
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.load
|
@pytest.mark.load
|
||||||
class TestLoad:
|
class TestLoad(ClusterTestBase):
|
||||||
@pytest.fixture(autouse=True)
|
@pytest.fixture(autouse=True)
|
||||||
def clear_cache_and_data(self, hosting: Hosting):
|
def clear_cache_and_data(self, hosting: Hosting):
|
||||||
clear_cache_and_data(hosting=hosting)
|
clear_cache_and_data(hosting=hosting)
|
||||||
|
yield
|
||||||
|
start_stopped_nodes()
|
||||||
|
|
||||||
@pytest.mark.parametrize("obj_size, out_file", [(1000, "1mb_200.json")])
|
@pytest.fixture(scope="session", autouse=True)
|
||||||
@pytest.mark.parametrize("writers, readers, deleters", [(140, 60, 0), (200, 0, 0)])
|
def init_s3_client(self, hosting: Hosting):
|
||||||
@pytest.mark.parametrize(
|
if "s3" in LOAD_TYPE.lower():
|
||||||
"load_time", [LoadTime.EXPECTED_MAXIMUM.value, LoadTime.PMI_EXPECTATION.value]
|
init_s3_client(
|
||||||
)
|
load_nodes=LOAD_NODES,
|
||||||
@pytest.mark.parametrize("node_count", [4])
|
login=LOAD_NODE_SSH_USER,
|
||||||
|
pkey=LOAD_NODE_SSH_PRIVATE_KEY_PATH,
|
||||||
|
hosting=hosting,
|
||||||
|
)
|
||||||
|
|
||||||
|
@pytest.mark.parametrize("obj_size, out_file", list(zip(OBJ_SIZE, OUT_FILE)))
|
||||||
|
@pytest.mark.parametrize("writers, readers, deleters", list(zip(WRITERS, READERS, DELETERS)))
|
||||||
|
@pytest.mark.parametrize("load_time", LOAD_TIME)
|
||||||
|
@pytest.mark.parametrize("node_count", STORAGE_NODE_COUNT)
|
||||||
|
@pytest.mark.parametrize("containers_count", CONTAINERS_COUNT)
|
||||||
|
@pytest.mark.parametrize("load_type", LOAD_TYPE)
|
||||||
|
@pytest.mark.parametrize("obj_count", OBJ_COUNT)
|
||||||
|
@pytest.mark.parametrize("load_nodes_count", LOAD_NODES_COUNT)
|
||||||
@pytest.mark.benchmark
|
@pytest.mark.benchmark
|
||||||
@pytest.mark.grpc
|
@pytest.mark.grpc
|
||||||
def test_grpc_benchmark(
|
def test_custom_load(
|
||||||
self,
|
self,
|
||||||
obj_size,
|
obj_size,
|
||||||
out_file,
|
out_file,
|
||||||
|
@ -53,604 +78,41 @@ class TestLoad:
|
||||||
deleters,
|
deleters,
|
||||||
load_time,
|
load_time,
|
||||||
node_count,
|
node_count,
|
||||||
|
obj_count,
|
||||||
|
load_type,
|
||||||
|
load_nodes_count,
|
||||||
|
containers_count,
|
||||||
hosting: Hosting,
|
hosting: Hosting,
|
||||||
):
|
):
|
||||||
allure.dynamic.title(
|
allure.dynamic.title(
|
||||||
f"Benchmark test - node_count = {node_count}, "
|
f"Load test - node_count = {node_count}, "
|
||||||
f"writers = {writers} readers = {readers}, "
|
f"writers = {writers} readers = {readers}, "
|
||||||
f"deleters = {deleters}, obj_size = {obj_size}, "
|
f"deleters = {deleters}, obj_size = {obj_size}, "
|
||||||
f"load_time = {load_time}"
|
f"load_time = {load_time}"
|
||||||
)
|
)
|
||||||
|
stop_unused_nodes(self.cluster.storage_nodes, node_count)
|
||||||
with allure.step("Get endpoints"):
|
with allure.step("Get endpoints"):
|
||||||
endpoints_list = get_services_endpoints(
|
endpoints_list = get_services_endpoints(
|
||||||
hosting=hosting,
|
hosting=hosting,
|
||||||
service_name_regex=STORAGE_NODE_SERVICE_NAME_REGEX,
|
service_name_regex=ENDPOINTS_ATTRIBUTES[LOAD_TYPE]["regex"],
|
||||||
endpoint_attribute="rpc_endpoint",
|
endpoint_attribute=ENDPOINTS_ATTRIBUTES[LOAD_TYPE]["endpoint_attribute"],
|
||||||
)
|
)
|
||||||
endpoints = ",".join(endpoints_list[:node_count])
|
endpoints = ",".join(endpoints_list[:node_count])
|
||||||
load_params = LoadParams(
|
load_params = LoadParams(
|
||||||
endpoint=endpoints,
|
endpoint=endpoints,
|
||||||
obj_size=obj_size,
|
obj_size=obj_size,
|
||||||
containers_count=CONTAINERS_COUNT,
|
containers_count=containers_count,
|
||||||
out_file=out_file,
|
out_file=out_file,
|
||||||
obj_count=OBJ_COUNT,
|
obj_count=obj_count,
|
||||||
writers=writers,
|
writers=writers,
|
||||||
readers=readers,
|
readers=readers,
|
||||||
deleters=deleters,
|
deleters=deleters,
|
||||||
load_time=load_time,
|
load_time=load_time,
|
||||||
load_type="grpc",
|
load_type=load_type,
|
||||||
)
|
)
|
||||||
|
load_nodes_list = LOAD_NODES[:load_nodes_count]
|
||||||
k6_load_instances = prepare_k6_instances(
|
k6_load_instances = prepare_k6_instances(
|
||||||
load_nodes=LOAD_NODES,
|
load_nodes=load_nodes_list,
|
||||||
login=LOAD_NODE_SSH_USER,
|
|
||||||
pkey=LOAD_NODE_SSH_PRIVATE_KEY_PATH,
|
|
||||||
load_params=load_params,
|
|
||||||
)
|
|
||||||
with allure.step("Run load"):
|
|
||||||
multi_node_k6_run(k6_load_instances)
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"obj_size, out_file, writers",
|
|
||||||
[
|
|
||||||
(4, "4kb_300.json", 300),
|
|
||||||
(16, "16kb_250.json", 250),
|
|
||||||
(64, "64kb_250.json", 250),
|
|
||||||
(128, "128kb_250.json", 250),
|
|
||||||
(512, "512kb_200.json", 200),
|
|
||||||
(1000, "1mb_200.json", 200),
|
|
||||||
(8000, "8mb_150.json", 150),
|
|
||||||
(32000, "32mb_150.json", 150),
|
|
||||||
(128000, "128mb_100.json", 100),
|
|
||||||
(512000, "512mb_50.json", 50),
|
|
||||||
],
|
|
||||||
)
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"load_time", [LoadTime.EXPECTED_MAXIMUM.value, LoadTime.PMI_EXPECTATION.value]
|
|
||||||
)
|
|
||||||
@pytest.mark.benchmark
|
|
||||||
@pytest.mark.grpc
|
|
||||||
def test_grpc_benchmark_write(
|
|
||||||
self,
|
|
||||||
obj_size,
|
|
||||||
out_file,
|
|
||||||
writers,
|
|
||||||
load_time,
|
|
||||||
hosting: Hosting,
|
|
||||||
):
|
|
||||||
allure.dynamic.title(
|
|
||||||
f"Single gate benchmark write test - "
|
|
||||||
f"writers = {writers}, "
|
|
||||||
f"obj_size = {obj_size}, "
|
|
||||||
f"load_time = {load_time}"
|
|
||||||
)
|
|
||||||
with allure.step("Get endpoints"):
|
|
||||||
endpoints_list = get_services_endpoints(
|
|
||||||
hosting=hosting,
|
|
||||||
service_name_regex=STORAGE_NODE_SERVICE_NAME_REGEX,
|
|
||||||
endpoint_attribute="rpc_endpoint",
|
|
||||||
)
|
|
||||||
endpoints = ",".join(endpoints_list[:1])
|
|
||||||
load_params = LoadParams(
|
|
||||||
endpoint=endpoints,
|
|
||||||
obj_size=obj_size,
|
|
||||||
containers_count=CONTAINERS_COUNT,
|
|
||||||
out_file=out_file,
|
|
||||||
obj_count=OBJ_COUNT,
|
|
||||||
writers=writers,
|
|
||||||
readers=0,
|
|
||||||
deleters=0,
|
|
||||||
load_time=load_time,
|
|
||||||
load_type="grpc",
|
|
||||||
)
|
|
||||||
k6_load_instances = prepare_k6_instances(
|
|
||||||
load_nodes=LOAD_NODES,
|
|
||||||
login=LOAD_NODE_SSH_USER,
|
|
||||||
pkey=LOAD_NODE_SSH_PRIVATE_KEY_PATH,
|
|
||||||
load_params=load_params,
|
|
||||||
)
|
|
||||||
with allure.step("Run load"):
|
|
||||||
multi_node_k6_run(k6_load_instances)
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"obj_size, out_file, writers, readers",
|
|
||||||
[
|
|
||||||
(8000, "8mb_350.json", 245, 105),
|
|
||||||
(32000, "32mb_300.json", 210, 90),
|
|
||||||
(128000, "128mb_100.json", 70, 30),
|
|
||||||
(512000, "512mb_70.json", 49, 21),
|
|
||||||
],
|
|
||||||
)
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"load_time", [LoadTime.EXPECTED_MAXIMUM.value, LoadTime.PMI_EXPECTATION.value]
|
|
||||||
)
|
|
||||||
@pytest.mark.benchmark
|
|
||||||
@pytest.mark.grpc
|
|
||||||
def test_grpc_benchmark_write_read_70_30(
|
|
||||||
self,
|
|
||||||
obj_size,
|
|
||||||
out_file,
|
|
||||||
writers,
|
|
||||||
readers,
|
|
||||||
load_time,
|
|
||||||
hosting: Hosting,
|
|
||||||
):
|
|
||||||
allure.dynamic.title(
|
|
||||||
f"Single gate benchmark write + read (70%/30%) test - "
|
|
||||||
f"writers = {writers}, "
|
|
||||||
f"readers = {readers}, "
|
|
||||||
f"obj_size = {obj_size}, "
|
|
||||||
f"load_time = {load_time}"
|
|
||||||
)
|
|
||||||
with allure.step("Get endpoints"):
|
|
||||||
endpoints_list = get_services_endpoints(
|
|
||||||
hosting=hosting,
|
|
||||||
service_name_regex=STORAGE_NODE_SERVICE_NAME_REGEX,
|
|
||||||
endpoint_attribute="rpc_endpoint",
|
|
||||||
)
|
|
||||||
endpoints = ",".join(endpoints_list[:1])
|
|
||||||
load_params = LoadParams(
|
|
||||||
endpoint=endpoints,
|
|
||||||
obj_size=obj_size,
|
|
||||||
containers_count=CONTAINERS_COUNT,
|
|
||||||
out_file=out_file,
|
|
||||||
obj_count=500,
|
|
||||||
writers=writers,
|
|
||||||
readers=readers,
|
|
||||||
deleters=0,
|
|
||||||
load_time=load_time,
|
|
||||||
load_type="grpc",
|
|
||||||
)
|
|
||||||
k6_load_instances = prepare_k6_instances(
|
|
||||||
load_nodes=LOAD_NODES,
|
|
||||||
login=LOAD_NODE_SSH_USER,
|
|
||||||
pkey=LOAD_NODE_SSH_PRIVATE_KEY_PATH,
|
|
||||||
load_params=load_params,
|
|
||||||
)
|
|
||||||
with allure.step("Run load"):
|
|
||||||
multi_node_k6_run(k6_load_instances)
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"obj_size, out_file, readers",
|
|
||||||
[
|
|
||||||
(4, "4kb_300.json", 300),
|
|
||||||
(16, "16kb_300.json", 300),
|
|
||||||
(64, "64kb_300.json", 300),
|
|
||||||
(128, "128kb_250.json", 250),
|
|
||||||
(512, "512kb_150.json", 150),
|
|
||||||
(1000, "1mb_150.json", 150),
|
|
||||||
(8000, "8mb_150.json", 150),
|
|
||||||
(32000, "32mb_100.json", 100),
|
|
||||||
(128000, "128mb_25.json", 25),
|
|
||||||
(512000, "512mb_25.json", 25),
|
|
||||||
],
|
|
||||||
)
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"load_time", [LoadTime.EXPECTED_MAXIMUM.value, LoadTime.PMI_EXPECTATION.value]
|
|
||||||
)
|
|
||||||
@pytest.mark.benchmark
|
|
||||||
@pytest.mark.grpc
|
|
||||||
def test_grpc_benchmark_read(
|
|
||||||
self,
|
|
||||||
obj_size,
|
|
||||||
out_file,
|
|
||||||
readers,
|
|
||||||
load_time,
|
|
||||||
hosting: Hosting,
|
|
||||||
):
|
|
||||||
allure.dynamic.title(
|
|
||||||
f"Single gate benchmark read test - "
|
|
||||||
f"readers = {readers}, "
|
|
||||||
f"obj_size = {obj_size}, "
|
|
||||||
f"load_time = {load_time}"
|
|
||||||
)
|
|
||||||
with allure.step("Get endpoints"):
|
|
||||||
endpoints_list = get_services_endpoints(
|
|
||||||
hosting=hosting,
|
|
||||||
service_name_regex=STORAGE_NODE_SERVICE_NAME_REGEX,
|
|
||||||
endpoint_attribute="rpc_endpoint",
|
|
||||||
)
|
|
||||||
endpoints = ",".join(endpoints_list[:1])
|
|
||||||
load_params = LoadParams(
|
|
||||||
endpoint=endpoints,
|
|
||||||
obj_size=obj_size,
|
|
||||||
containers_count=1,
|
|
||||||
out_file=out_file,
|
|
||||||
obj_count=500,
|
|
||||||
writers=0,
|
|
||||||
readers=readers,
|
|
||||||
deleters=0,
|
|
||||||
load_time=load_time,
|
|
||||||
load_type="grpc",
|
|
||||||
)
|
|
||||||
k6_load_instances = prepare_k6_instances(
|
|
||||||
load_nodes=LOAD_NODES,
|
|
||||||
login=LOAD_NODE_SSH_USER,
|
|
||||||
pkey=LOAD_NODE_SSH_PRIVATE_KEY_PATH,
|
|
||||||
load_params=load_params,
|
|
||||||
)
|
|
||||||
with allure.step("Run load"):
|
|
||||||
multi_node_k6_run(k6_load_instances)
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"obj_size, out_file, writers",
|
|
||||||
[
|
|
||||||
(4, "4kb_300.json", 300),
|
|
||||||
(16, "16kb_250.json", 250),
|
|
||||||
(64, "64kb_250.json", 250),
|
|
||||||
(128, "128kb_250.json", 250),
|
|
||||||
(512, "512kb_200.json", 200),
|
|
||||||
(1000, "1mb_200.json", 200),
|
|
||||||
(8000, "8mb_150.json", 150),
|
|
||||||
(32000, "32mb_150.json", 150),
|
|
||||||
(128000, "128mb_100.json", 100),
|
|
||||||
(512000, "512mb_50.json", 50),
|
|
||||||
],
|
|
||||||
)
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"load_time", [LoadTime.EXPECTED_MAXIMUM.value, LoadTime.PMI_EXPECTATION.value]
|
|
||||||
)
|
|
||||||
@pytest.mark.benchmark
|
|
||||||
@pytest.mark.http
|
|
||||||
def test_http_benchmark_write(
|
|
||||||
self,
|
|
||||||
obj_size,
|
|
||||||
out_file,
|
|
||||||
writers,
|
|
||||||
load_time,
|
|
||||||
hosting: Hosting,
|
|
||||||
):
|
|
||||||
allure.dynamic.title(
|
|
||||||
f"Single gate benchmark write test - "
|
|
||||||
f"writers = {writers}, "
|
|
||||||
f"obj_size = {obj_size}, "
|
|
||||||
f"load_time = {load_time}"
|
|
||||||
)
|
|
||||||
with allure.step("Get endpoints"):
|
|
||||||
endpoints_list = get_services_endpoints(
|
|
||||||
hosting=hosting,
|
|
||||||
service_name_regex=HTTP_GATE_SERVICE_NAME_REGEX,
|
|
||||||
endpoint_attribute="endpoint",
|
|
||||||
)
|
|
||||||
endpoints = ",".join(endpoints_list[:1])
|
|
||||||
load_params = LoadParams(
|
|
||||||
endpoint=endpoints,
|
|
||||||
obj_size=obj_size,
|
|
||||||
containers_count=CONTAINERS_COUNT,
|
|
||||||
out_file=out_file,
|
|
||||||
obj_count=OBJ_COUNT,
|
|
||||||
writers=writers,
|
|
||||||
readers=0,
|
|
||||||
deleters=0,
|
|
||||||
load_time=load_time,
|
|
||||||
load_type="http",
|
|
||||||
)
|
|
||||||
k6_load_instances = prepare_k6_instances(
|
|
||||||
load_nodes=LOAD_NODES,
|
|
||||||
login=LOAD_NODE_SSH_USER,
|
|
||||||
pkey=LOAD_NODE_SSH_PRIVATE_KEY_PATH,
|
|
||||||
load_params=load_params,
|
|
||||||
)
|
|
||||||
with allure.step("Run load"):
|
|
||||||
multi_node_k6_run(k6_load_instances)
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"obj_size, out_file, writers, readers",
|
|
||||||
[
|
|
||||||
(8000, "8mb_350.json", 245, 105),
|
|
||||||
(32000, "32mb_300.json", 210, 90),
|
|
||||||
(128000, "128mb_100.json", 70, 30),
|
|
||||||
(512000, "512mb_70.json", 49, 21),
|
|
||||||
],
|
|
||||||
)
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"load_time", [LoadTime.EXPECTED_MAXIMUM.value, LoadTime.PMI_EXPECTATION.value]
|
|
||||||
)
|
|
||||||
@pytest.mark.benchmark
|
|
||||||
@pytest.mark.http
|
|
||||||
def test_http_benchmark_write_read_70_30(
|
|
||||||
self,
|
|
||||||
obj_size,
|
|
||||||
out_file,
|
|
||||||
writers,
|
|
||||||
readers,
|
|
||||||
load_time,
|
|
||||||
hosting: Hosting,
|
|
||||||
):
|
|
||||||
allure.dynamic.title(
|
|
||||||
f"Single gate benchmark write + read (70%/30%) test - "
|
|
||||||
f"writers = {writers}, "
|
|
||||||
f"readers = {readers}, "
|
|
||||||
f"obj_size = {obj_size}, "
|
|
||||||
f"load_time = {load_time}"
|
|
||||||
)
|
|
||||||
with allure.step("Get endpoints"):
|
|
||||||
endpoints_list = get_services_endpoints(
|
|
||||||
hosting=hosting,
|
|
||||||
service_name_regex=HTTP_GATE_SERVICE_NAME_REGEX,
|
|
||||||
endpoint_attribute="endpoint",
|
|
||||||
)
|
|
||||||
endpoints = ",".join(endpoints_list[:1])
|
|
||||||
load_params = LoadParams(
|
|
||||||
endpoint=endpoints,
|
|
||||||
obj_size=obj_size,
|
|
||||||
containers_count=CONTAINERS_COUNT,
|
|
||||||
out_file=out_file,
|
|
||||||
obj_count=500,
|
|
||||||
writers=writers,
|
|
||||||
readers=readers,
|
|
||||||
deleters=0,
|
|
||||||
load_time=load_time,
|
|
||||||
load_type="http",
|
|
||||||
)
|
|
||||||
k6_load_instances = prepare_k6_instances(
|
|
||||||
load_nodes=LOAD_NODES,
|
|
||||||
login=LOAD_NODE_SSH_USER,
|
|
||||||
pkey=LOAD_NODE_SSH_PRIVATE_KEY_PATH,
|
|
||||||
load_params=load_params,
|
|
||||||
)
|
|
||||||
with allure.step("Run load"):
|
|
||||||
multi_node_k6_run(k6_load_instances)
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"obj_size, out_file, readers",
|
|
||||||
[
|
|
||||||
(4, "4kb_300.json", 300),
|
|
||||||
(16, "16kb_300.json", 300),
|
|
||||||
(64, "64kb_300.json", 300),
|
|
||||||
(128, "128kb_250.json", 250),
|
|
||||||
(512, "512kb_150.json", 150),
|
|
||||||
(1000, "1mb_150.json", 150),
|
|
||||||
(8000, "8mb_150.json", 150),
|
|
||||||
(32000, "32mb_100.json", 100),
|
|
||||||
(128000, "128mb_25.json", 25),
|
|
||||||
(512000, "512mb_25.json", 25),
|
|
||||||
],
|
|
||||||
)
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"load_time", [LoadTime.EXPECTED_MAXIMUM.value, LoadTime.PMI_EXPECTATION.value]
|
|
||||||
)
|
|
||||||
@pytest.mark.benchmark
|
|
||||||
@pytest.mark.http
|
|
||||||
def test_http_benchmark_read(
|
|
||||||
self,
|
|
||||||
obj_size,
|
|
||||||
out_file,
|
|
||||||
readers,
|
|
||||||
load_time,
|
|
||||||
hosting: Hosting,
|
|
||||||
):
|
|
||||||
allure.dynamic.title(
|
|
||||||
f"Single gate benchmark read test - "
|
|
||||||
f"readers = {readers}, "
|
|
||||||
f"obj_size = {obj_size}, "
|
|
||||||
f"load_time = {load_time}"
|
|
||||||
)
|
|
||||||
with allure.step("Get endpoints"):
|
|
||||||
endpoints_list = get_services_endpoints(
|
|
||||||
hosting=hosting,
|
|
||||||
service_name_regex=HTTP_GATE_SERVICE_NAME_REGEX,
|
|
||||||
endpoint_attribute="endpoint",
|
|
||||||
)
|
|
||||||
endpoints = ",".join(endpoints_list[:1])
|
|
||||||
load_params = LoadParams(
|
|
||||||
endpoint=endpoints,
|
|
||||||
obj_size=obj_size,
|
|
||||||
containers_count=1,
|
|
||||||
out_file=out_file,
|
|
||||||
obj_count=500,
|
|
||||||
writers=0,
|
|
||||||
readers=readers,
|
|
||||||
deleters=0,
|
|
||||||
load_time=load_time,
|
|
||||||
load_type="http",
|
|
||||||
)
|
|
||||||
k6_load_instances = prepare_k6_instances(
|
|
||||||
load_nodes=LOAD_NODES,
|
|
||||||
login=LOAD_NODE_SSH_USER,
|
|
||||||
pkey=LOAD_NODE_SSH_PRIVATE_KEY_PATH,
|
|
||||||
load_params=load_params,
|
|
||||||
)
|
|
||||||
with allure.step("Run load"):
|
|
||||||
multi_node_k6_run(k6_load_instances)
|
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.load
|
|
||||||
@pytest.mark.s3
|
|
||||||
class TestS3Load:
|
|
||||||
@pytest.fixture(autouse=True)
|
|
||||||
def clear_cache_and_data(self, hosting: Hosting):
|
|
||||||
clear_cache_and_data(hosting=hosting)
|
|
||||||
|
|
||||||
@pytest.fixture(scope="session", autouse=True)
|
|
||||||
def init_s3_client(self, hosting: Hosting):
|
|
||||||
init_s3_client(
|
|
||||||
load_nodes=LOAD_NODES,
|
|
||||||
login=LOAD_NODE_SSH_USER,
|
|
||||||
pkey=LOAD_NODE_SSH_PRIVATE_KEY_PATH,
|
|
||||||
hosting=hosting,
|
|
||||||
)
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"obj_size, out_file, writers",
|
|
||||||
[
|
|
||||||
(4, "4kb_300.json", 400),
|
|
||||||
(16, "16kb_250.json", 350),
|
|
||||||
(64, "64kb_250.json", 350),
|
|
||||||
(128, "128kb_250.json", 300),
|
|
||||||
(512, "512kb_200.json", 250),
|
|
||||||
(1000, "1mb_200.json", 250),
|
|
||||||
(8000, "8mb_150.json", 200),
|
|
||||||
(32000, "32mb_150.json", 200),
|
|
||||||
(128000, "128mb_100.json", 150),
|
|
||||||
(512000, "512mb_50.json", 50),
|
|
||||||
],
|
|
||||||
)
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"load_time", [LoadTime.EXPECTED_MAXIMUM.value, LoadTime.PMI_EXPECTATION.value]
|
|
||||||
)
|
|
||||||
@pytest.mark.benchmark
|
|
||||||
@pytest.mark.s3
|
|
||||||
def test_s3_benchmark_write(
|
|
||||||
self,
|
|
||||||
obj_size,
|
|
||||||
out_file,
|
|
||||||
writers,
|
|
||||||
load_time,
|
|
||||||
hosting: Hosting,
|
|
||||||
):
|
|
||||||
allure.dynamic.title(
|
|
||||||
f"Single gate benchmark write test - "
|
|
||||||
f"writers = {writers}, "
|
|
||||||
f"obj_size = {obj_size}, "
|
|
||||||
f"load_time = {load_time}"
|
|
||||||
)
|
|
||||||
with allure.step("Get endpoints"):
|
|
||||||
endpoints_list = get_services_endpoints(
|
|
||||||
hosting=hosting,
|
|
||||||
service_name_regex=S3_GATE_SERVICE_NAME_REGEX,
|
|
||||||
endpoint_attribute="endpoint",
|
|
||||||
)
|
|
||||||
endpoints = ",".join(endpoints_list[:1])
|
|
||||||
load_params = LoadParams(
|
|
||||||
endpoint=endpoints,
|
|
||||||
obj_size=obj_size,
|
|
||||||
containers_count=CONTAINERS_COUNT,
|
|
||||||
out_file=out_file,
|
|
||||||
obj_count=OBJ_COUNT,
|
|
||||||
writers=writers,
|
|
||||||
readers=0,
|
|
||||||
deleters=0,
|
|
||||||
load_time=load_time,
|
|
||||||
load_type="s3",
|
|
||||||
)
|
|
||||||
k6_load_instances = prepare_k6_instances(
|
|
||||||
load_nodes=LOAD_NODES,
|
|
||||||
login=LOAD_NODE_SSH_USER,
|
|
||||||
pkey=LOAD_NODE_SSH_PRIVATE_KEY_PATH,
|
|
||||||
load_params=load_params,
|
|
||||||
)
|
|
||||||
with allure.step("Run load"):
|
|
||||||
multi_node_k6_run(k6_load_instances)
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"obj_size, out_file, writers, readers",
|
|
||||||
[
|
|
||||||
(4, "4kb_350.json", 210, 90),
|
|
||||||
(16, "16kb_300.json", 210, 90),
|
|
||||||
(64, "64kb_300.json", 210, 90),
|
|
||||||
(128, "128kb_300.json", 210, 90),
|
|
||||||
(512, "512kb_300.json", 210, 90),
|
|
||||||
(1000, "1mb_300.json", 210, 90),
|
|
||||||
(8000, "8mb_250.json", 175, 75),
|
|
||||||
(32000, "32mb_200.json", 140, 60),
|
|
||||||
(128000, "128mb_100.json", 70, 30),
|
|
||||||
(512000, "512mb_50.json", 35, 15),
|
|
||||||
],
|
|
||||||
)
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"load_time", [LoadTime.EXPECTED_MAXIMUM.value, LoadTime.PMI_EXPECTATION.value]
|
|
||||||
)
|
|
||||||
@pytest.mark.benchmark
|
|
||||||
@pytest.mark.s3
|
|
||||||
def test_s3_benchmark_write_read_70_30(
|
|
||||||
self,
|
|
||||||
obj_size,
|
|
||||||
out_file,
|
|
||||||
writers,
|
|
||||||
readers,
|
|
||||||
load_time,
|
|
||||||
hosting: Hosting,
|
|
||||||
):
|
|
||||||
allure.dynamic.title(
|
|
||||||
f"Single gate benchmark write + read (70%/30%) test - "
|
|
||||||
f"writers = {writers}, "
|
|
||||||
f"readers = {readers}, "
|
|
||||||
f"obj_size = {obj_size}, "
|
|
||||||
f"load_time = {load_time}"
|
|
||||||
)
|
|
||||||
with allure.step("Get endpoints"):
|
|
||||||
endpoints_list = get_services_endpoints(
|
|
||||||
hosting=hosting,
|
|
||||||
service_name_regex=S3_GATE_SERVICE_NAME_REGEX,
|
|
||||||
endpoint_attribute="endpoint",
|
|
||||||
)
|
|
||||||
endpoints = ",".join(endpoints_list[:1])
|
|
||||||
load_params = LoadParams(
|
|
||||||
endpoint=endpoints,
|
|
||||||
obj_size=obj_size,
|
|
||||||
containers_count=CONTAINERS_COUNT,
|
|
||||||
out_file=out_file,
|
|
||||||
obj_count=500,
|
|
||||||
writers=writers,
|
|
||||||
readers=readers,
|
|
||||||
deleters=0,
|
|
||||||
load_time=load_time,
|
|
||||||
load_type="s3",
|
|
||||||
)
|
|
||||||
k6_load_instances = prepare_k6_instances(
|
|
||||||
load_nodes=LOAD_NODES,
|
|
||||||
login=LOAD_NODE_SSH_USER,
|
|
||||||
pkey=LOAD_NODE_SSH_PRIVATE_KEY_PATH,
|
|
||||||
load_params=load_params,
|
|
||||||
)
|
|
||||||
with allure.step("Run load"):
|
|
||||||
multi_node_k6_run(k6_load_instances)
|
|
||||||
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"obj_size, out_file, readers",
|
|
||||||
[
|
|
||||||
(4, "4kb_400.json", 400),
|
|
||||||
(16, "16kb_400.json", 400),
|
|
||||||
(64, "64kb_350.json", 350),
|
|
||||||
(128, "128kb_300.json", 300),
|
|
||||||
(512, "512kb_300.json", 300),
|
|
||||||
(1000, "1mb_300.json", 300),
|
|
||||||
(8000, "8mb_300.json", 300),
|
|
||||||
(32000, "32mb_200.json", 200),
|
|
||||||
(128000, "128mb_150.json", 150),
|
|
||||||
(512000, "512mb_50.json", 50),
|
|
||||||
],
|
|
||||||
)
|
|
||||||
@pytest.mark.parametrize(
|
|
||||||
"load_time", [LoadTime.EXPECTED_MAXIMUM.value, LoadTime.PMI_EXPECTATION.value]
|
|
||||||
)
|
|
||||||
@pytest.mark.benchmark
|
|
||||||
@pytest.mark.s3
|
|
||||||
def test_s3_benchmark_read(
|
|
||||||
self,
|
|
||||||
obj_size,
|
|
||||||
out_file,
|
|
||||||
readers,
|
|
||||||
load_time,
|
|
||||||
hosting: Hosting,
|
|
||||||
):
|
|
||||||
allure.dynamic.title(
|
|
||||||
f"Single gate benchmark read test - "
|
|
||||||
f"readers = {readers}, "
|
|
||||||
f"obj_size = {obj_size}, "
|
|
||||||
f"load_time = {load_time}"
|
|
||||||
)
|
|
||||||
with allure.step("Get endpoints"):
|
|
||||||
endpoints_list = get_services_endpoints(
|
|
||||||
hosting=hosting,
|
|
||||||
service_name_regex=S3_GATE_SERVICE_NAME_REGEX,
|
|
||||||
endpoint_attribute="endpoint",
|
|
||||||
)
|
|
||||||
endpoints = ",".join(endpoints_list[:1])
|
|
||||||
load_params = LoadParams(
|
|
||||||
endpoint=endpoints,
|
|
||||||
obj_size=obj_size,
|
|
||||||
containers_count=1,
|
|
||||||
out_file=out_file,
|
|
||||||
obj_count=500,
|
|
||||||
writers=0,
|
|
||||||
readers=readers,
|
|
||||||
deleters=0,
|
|
||||||
load_time=load_time,
|
|
||||||
load_type="s3",
|
|
||||||
)
|
|
||||||
k6_load_instances = prepare_k6_instances(
|
|
||||||
load_nodes=LOAD_NODES,
|
|
||||||
login=LOAD_NODE_SSH_USER,
|
login=LOAD_NODE_SSH_USER,
|
||||||
pkey=LOAD_NODE_SSH_PRIVATE_KEY_PATH,
|
pkey=LOAD_NODE_SSH_PRIVATE_KEY_PATH,
|
||||||
load_params=load_params,
|
load_params=load_params,
|
||||||
|
|
|
@ -27,14 +27,6 @@ DEVENV_PATH = os.getenv("DEVENV_PATH", os.path.join("..", "neofs-dev-env"))
|
||||||
# Password of wallet owned by user on behalf of whom we are running tests
|
# Password of wallet owned by user on behalf of whom we are running tests
|
||||||
WALLET_PASS = os.getenv("WALLET_PASS", "")
|
WALLET_PASS = os.getenv("WALLET_PASS", "")
|
||||||
|
|
||||||
# Load node parameters
|
|
||||||
LOAD_NODES = os.getenv("LOAD_NODES", "").split(",")
|
|
||||||
LOAD_NODE_SSH_USER = os.getenv("LOAD_NODE_SSH_USER", "root")
|
|
||||||
LOAD_NODE_SSH_PRIVATE_KEY_PATH = os.getenv("LOAD_NODE_SSH_PRIVATE_KEY_PATH")
|
|
||||||
BACKGROUND_WRITERS_COUNT = os.getenv("BACKGROUND_WRITERS_COUNT", 10)
|
|
||||||
BACKGROUND_READERS_COUNT = os.getenv("BACKGROUND_READERS_COUNT", 10)
|
|
||||||
BACKGROUND_OBJ_SIZE = os.getenv("BACKGROUND_OBJ_SIZE", 1024)
|
|
||||||
BACKGROUND_LOAD_MAX_TIME = os.getenv("BACKGROUND_LOAD_MAX_TIME", 600)
|
|
||||||
|
|
||||||
# Paths to CLI executables on machine that runs tests
|
# Paths to CLI executables on machine that runs tests
|
||||||
NEOGO_EXECUTABLE = os.getenv("NEOGO_EXECUTABLE", "neo-go")
|
NEOGO_EXECUTABLE = os.getenv("NEOGO_EXECUTABLE", "neo-go")
|
||||||
|
|
Loading…
Reference in a new issue