Support replica as input parameters and update test cases to adapt to different replicas (#16757)

Signed-off-by: Binbin Lv <binbin.lv@zilliz.com>
pull/16810/head
binbin 2022-05-05 18:15:51 +08:00 committed by GitHub
parent 8c004fa981
commit b60c7f9ba3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 57 additions and 33 deletions

View File

@ -15,21 +15,6 @@ from common import common_func as cf
from common import common_type as ct from common import common_type as ct
class ParamInfo:
def __init__(self):
self.param_host = ""
self.param_port = ""
self.param_handler = ""
def prepare_param_info(self, host, port, handler):
self.param_host = host
self.param_port = port
self.param_handler = handler
param_info = ParamInfo()
class Base: class Base:
""" Initialize class object """ """ Initialize class object """
connection_wrap = None connection_wrap = None
@ -65,8 +50,8 @@ class Base:
try: try:
""" Drop collection before disconnect """ """ Drop collection before disconnect """
if not self.connection_wrap.has_connection(alias=DefaultConfig.DEFAULT_USING)[0]: if not self.connection_wrap.has_connection(alias=DefaultConfig.DEFAULT_USING)[0]:
self.connection_wrap.connect(alias=DefaultConfig.DEFAULT_USING, host=param_info.param_host, self.connection_wrap.connect(alias=DefaultConfig.DEFAULT_USING, host=cf.param_info.param_host,
port=param_info.param_port) port=cf.param_info.param_port)
if self.collection_wrap.collection is not None: if self.collection_wrap.collection is not None:
self.collection_wrap.drop(check_task=ct.CheckTasks.check_nothing) self.collection_wrap.drop(check_task=ct.CheckTasks.check_nothing)
@ -100,8 +85,8 @@ class TestcaseBase(Base):
def _connect(self): def _connect(self):
""" Add a connection and create the connect """ """ Add a connection and create the connect """
res, is_succ = self.connection_wrap.connect(alias=DefaultConfig.DEFAULT_USING, host=param_info.param_host, res, is_succ = self.connection_wrap.connect(alias=DefaultConfig.DEFAULT_USING, host=cf.param_info.param_host,
port=param_info.param_port) port=cf.param_info.param_port)
return res return res
def init_collection_wrap(self, name=None, schema=None, shards_num=2, check_task=None, check_items=None, **kwargs): def init_collection_wrap(self, name=None, schema=None, shards_num=2, check_task=None, check_items=None, **kwargs):

View File

@ -1,6 +1,7 @@
import sys import sys
import time import time
import timeout_decorator import timeout_decorator
from numpy import NaN
from pymilvus import Collection from pymilvus import Collection
@ -10,6 +11,7 @@ from utils.api_request import api_request
from utils.wrapper import trace from utils.wrapper import trace
from utils.util_log import test_log as log from utils.util_log import test_log as log
from pymilvus.orm.types import CONSISTENCY_STRONG from pymilvus.orm.types import CONSISTENCY_STRONG
from common.common_func import param_info
TIMEOUT = 20 TIMEOUT = 20
@ -85,8 +87,9 @@ class ApiCollectionWrapper:
return res, check_result return res, check_result
@trace() @trace()
def load(self, partition_names=None, replica_number=1, timeout=None, check_task=None, check_items=None, **kwargs): def load(self, partition_names=None, replica_number=NaN, timeout=None, check_task=None, check_items=None, **kwargs):
timeout = TIMEOUT if timeout is None else timeout timeout = TIMEOUT if timeout is None else timeout
replica_number = param_info.param_replica_num if replica_number is NaN else replica_number
func_name = sys._getframe().f_code.co_name func_name = sys._getframe().f_code.co_name
res, check = api_request([self.collection.load, partition_names, replica_number, timeout], **kwargs) res, check = api_request([self.collection.load, partition_names, replica_number, timeout], **kwargs)

View File

@ -1,10 +1,12 @@
import sys import sys
from numpy import NaN
from pymilvus import Partition from pymilvus import Partition
sys.path.append("..") sys.path.append("..")
from check.func_check import ResponseChecker from check.func_check import ResponseChecker
from utils.api_request import api_request from utils.api_request import api_request
from common.common_func import param_info
TIMEOUT = 20 TIMEOUT = 20
@ -49,8 +51,9 @@ class ApiPartitionWrapper:
check_task, check_items, succ, **kwargs).run() check_task, check_items, succ, **kwargs).run()
return res, check_result return res, check_result
def load(self, replica_number=1, timeout=None, check_task=None, check_items=None, **kwargs): def load(self, replica_number=NaN, timeout=None, check_task=None, check_items=None, **kwargs):
timeout = TIMEOUT if timeout is None else timeout timeout = TIMEOUT if timeout is None else timeout
replica_number = param_info.param_replica_num if replica_number is NaN else replica_number
func_name = sys._getframe().f_code.co_name func_name = sys._getframe().f_code.co_name
res, succ = api_request([self.partition.load, replica_number, timeout], **kwargs) res, succ = api_request([self.partition.load, replica_number, timeout], **kwargs)

View File

@ -13,6 +13,22 @@ from utils.util_log import test_log as log
"""" Methods of processing data """ """" Methods of processing data """
class ParamInfo:
def __init__(self):
self.param_host = ""
self.param_port = ""
self.param_handler = ""
self.param_replica_num = ct.default_replica_num
def prepare_param_info(self, host, port, handler, replica_num):
self.param_host = host
self.param_port = port
self.param_handler = handler
self.param_replica_num = replica_num
param_info = ParamInfo()
def gen_unique_str(str_value=None): def gen_unique_str(str_value=None):
prefix = "".join(random.choice(string.ascii_letters + string.digits) for _ in range(8)) prefix = "".join(random.choice(string.ascii_letters + string.digits) for _ in range(8))

View File

@ -50,6 +50,7 @@ compact_delta_ratio_reciprocal = 5 # compact_delta_binlog_ratio is 0.2
compact_retention_duration = 40 # compaction travel time retention range 20s compact_retention_duration = 40 # compaction travel time retention range 20s
max_compaction_interval = 60 # the max time interval (s) from the last compaction max_compaction_interval = 60 # the max time interval (s) from the last compaction
max_field_num = 256 # Maximum number of fields in a collection max_field_num = 256 # Maximum number of fields in a collection
default_replica_num = 1 # default memory replica number
Not_Exist = "Not_Exist" Not_Exist = "Not_Exist"
Connect_Object_Name = True Connect_Object_Name = True

View File

@ -7,7 +7,7 @@ import socket
import common.common_type as ct import common.common_type as ct
import common.common_func as cf import common.common_func as cf
from utils.util_log import test_log as log from utils.util_log import test_log as log
from base.client_base import param_info from common.common_func import param_info
from check.param_check import ip_check, number_check from check.param_check import ip_check, number_check
from config.log_config import log_config from config.log_config import log_config
from utils.util_pymilvus import get_milvus, gen_unique_str, gen_default_fields, gen_binary_default_fields from utils.util_pymilvus import get_milvus, gen_unique_str, gen_default_fields, gen_binary_default_fields
@ -39,6 +39,7 @@ def pytest_addoption(parser):
parser.addoption('--term_expr', action='store', default="term_expr", help="expr of query quest") parser.addoption('--term_expr', action='store', default="term_expr", help="expr of query quest")
parser.addoption('--check_content', action='store', default="check_content", help="content of check") parser.addoption('--check_content', action='store', default="check_content", help="content of check")
parser.addoption('--field_name', action='store', default="field_name", help="field_name of index") parser.addoption('--field_name', action='store', default="field_name", help="field_name of index")
parser.addoption('--replica_num', type='int', action='store', default=ct.default_replica_num, help="memory replica number")
@pytest.fixture @pytest.fixture
@ -153,6 +154,7 @@ def initialize_env(request):
port = request.config.getoption("--port") port = request.config.getoption("--port")
handler = request.config.getoption("--handler") handler = request.config.getoption("--handler")
clean_log = request.config.getoption("--clean_log") clean_log = request.config.getoption("--clean_log")
replica_num = request.config.getoption("--replica_num")
""" params check """ """ params check """
assert ip_check(host) and number_check(port) assert ip_check(host) and number_check(port)
@ -165,7 +167,7 @@ def initialize_env(request):
log.info("#" * 80) log.info("#" * 80)
log.info("[initialize_milvus] Log cleaned up, start testing...") log.info("[initialize_milvus] Log cleaned up, start testing...")
param_info.prepare_param_info(host, port, handler) param_info.prepare_param_info(host, port, handler, replica_num)
@pytest.fixture(params=ct.get_invalid_strs) @pytest.fixture(params=ct.get_invalid_strs)

View File

@ -2195,7 +2195,7 @@ class TestLoadCollection(TestcaseBase):
""" """
target: test load partition with invalid replica number target: test load partition with invalid replica number
method: load with invalid replica number method: load with invalid replica number
expected: raise exception expected: load successfully as replica = 1
""" """
# create, insert # create, insert
collection_w = self.init_collection_wrap(cf.gen_unique_str(prefix)) collection_w = self.init_collection_wrap(cf.gen_unique_str(prefix))

View File

@ -321,8 +321,10 @@ class TestCompactionParams(TestcaseBase):
# verify queryNode load the compacted segments # verify queryNode load the compacted segments
collection_w.load() collection_w.load()
replicas = collection_w.get_replicas()[0]
replica_num = len(replicas.groups)
segment_info = self.utility_wrap.get_query_segment_info(collection_w.name)[0] segment_info = self.utility_wrap.get_query_segment_info(collection_w.name)[0]
assert len(segment_info) == 1 assert len(segment_info) == 1*replica_num
@pytest.mark.skip(reason="TODO") @pytest.mark.skip(reason="TODO")
@pytest.mark.tags(CaseLabel.L2) @pytest.mark.tags(CaseLabel.L2)
@ -763,8 +765,10 @@ class TestCompactionOperation(TestcaseBase):
collection_w.get_compaction_plans(check_task=CheckTasks.check_merge_compact, check_items={"segment_num": 2}) collection_w.get_compaction_plans(check_task=CheckTasks.check_merge_compact, check_items={"segment_num": 2})
collection_w.load() collection_w.load()
replicas = collection_w.get_replicas()[0]
replica_num = len(replicas.groups)
segments_info = self.utility_wrap.get_query_segment_info(collection_w.name)[0] segments_info = self.utility_wrap.get_query_segment_info(collection_w.name)[0]
assert len(segments_info) == 1 assert len(segments_info) == 1*replica_num
@pytest.mark.tags(CaseLabel.L1) @pytest.mark.tags(CaseLabel.L1)
def test_compact_merge_multi_segments(self): def test_compact_merge_multi_segments(self):
@ -790,8 +794,10 @@ class TestCompactionOperation(TestcaseBase):
target = c_plans.plans[0].target target = c_plans.plans[0].target
collection_w.load() collection_w.load()
replicas = collection_w.get_replicas()[0]
replica_num = len(replicas.groups)
segments_info = self.utility_wrap.get_query_segment_info(collection_w.name)[0] segments_info = self.utility_wrap.get_query_segment_info(collection_w.name)[0]
assert len(segments_info) == 1 assert len(segments_info) == 1*replica_num
assert segments_info[0].segmentID == target assert segments_info[0].segmentID == target
@pytest.mark.tags(CaseLabel.L2) @pytest.mark.tags(CaseLabel.L2)
@ -845,13 +851,15 @@ class TestCompactionOperation(TestcaseBase):
# Estimated auto-merging takes 30s # Estimated auto-merging takes 30s
cost = 60 cost = 60
collection_w.load() collection_w.load()
replicas = collection_w.get_replicas()[0]
replica_num = len(replicas.groups)
start = time() start = time()
while True: while True:
sleep(5) sleep(5)
segments_info = self.utility_wrap.get_query_segment_info(collection_w.name)[0] segments_info = self.utility_wrap.get_query_segment_info(collection_w.name)[0]
# verify segments reaches threshold, auto-merge ten segments into one # verify segments reaches threshold, auto-merge ten segments into one
if len(segments_info) == 1: if len(segments_info) == 1*replica_num:
break break
end = time() end = time()
if end - start > cost: if end - start > cost:
@ -874,8 +882,10 @@ class TestCompactionOperation(TestcaseBase):
# load and verify no auto-merge # load and verify no auto-merge
collection_w.load() collection_w.load()
replicas = collection_w.get_replicas()[0]
replica_num = len(replicas.groups)
segments_info = self.utility_wrap.get_query_segment_info(collection_w.name)[0] segments_info = self.utility_wrap.get_query_segment_info(collection_w.name)[0]
assert len(segments_info) == less_threshold assert len(segments_info) == less_threshold*replica_num
@pytest.mark.skip(reason="Todo") @pytest.mark.skip(reason="Todo")
@pytest.mark.tags(CaseLabel.L2) @pytest.mark.tags(CaseLabel.L2)
@ -1042,14 +1052,16 @@ class TestCompactionOperation(TestcaseBase):
t.join() t.join()
collection_w.load() collection_w.load()
replicas = collection_w.get_replicas()[0]
replica_num = len(replicas.groups)
seg_info = self.utility_wrap.get_query_segment_info(collection_w.name)[0] seg_info = self.utility_wrap.get_query_segment_info(collection_w.name)[0]
assert len(seg_info) == 2 assert len(seg_info) == 2*replica_num
@pytest.mark.tags(CaseLabel.L2) @pytest.mark.tags(CaseLabel.L2)
def test_compact_during_index(self): def test_compact_during_index(self):
""" """
target: test compact during index target: test compact during index
method: while compact collection start a thread to creat index method: while compact collection start a thread to create index
expected: No exception expected: No exception
""" """
collection_w = self.collection_insert_multi_segments_one_shard(prefix, nb_of_segment=ct.default_nb, collection_w = self.collection_insert_multi_segments_one_shard(prefix, nb_of_segment=ct.default_nb,
@ -1068,8 +1080,10 @@ class TestCompactionOperation(TestcaseBase):
t.join() t.join()
collection_w.load() collection_w.load()
replicas = collection_w.get_replicas()[0]
replica_num = len(replicas.groups)
seg_info = self.utility_wrap.get_query_segment_info(collection_w.name)[0] seg_info = self.utility_wrap.get_query_segment_info(collection_w.name)[0]
assert len(seg_info) == 1 assert len(seg_info) == 1*replica_num
def test_compact_during_search(self): def test_compact_during_search(self):
""" """