2021-12-02 14:49:52 +00:00
|
|
|
from time import sleep
|
2021-12-06 13:12:01 +00:00
|
|
|
from pymilvus import connections, list_collections, utility
|
2023-12-14 11:38:45 +00:00
|
|
|
from chaos.checker import (CollectionCreateChecker, InsertFlushChecker,
|
|
|
|
SearchChecker, QueryChecker, IndexCreateChecker, Op)
|
2021-12-02 14:49:52 +00:00
|
|
|
from common.milvus_sys import MilvusSys
|
|
|
|
from utils.util_log import test_log as log
|
|
|
|
from chaos import chaos_commons as cc
|
2022-06-30 03:34:18 +00:00
|
|
|
from chaos.chaos_commons import assert_statistic
|
2021-12-02 14:49:52 +00:00
|
|
|
from common.common_type import CaseLabel
|
2021-12-06 13:12:01 +00:00
|
|
|
from common import common_func as cf
|
2021-12-02 14:49:52 +00:00
|
|
|
from chaos import constants
|
|
|
|
from customize.milvus_operator import MilvusOperator
|
|
|
|
|
|
|
|
from delayed_assert import assert_expectations
|
|
|
|
|
|
|
|
namespace = "chaos-testing"
|
|
|
|
|
|
|
|
|
|
|
|
def install_milvus(release_name):
|
2022-06-30 07:20:22 +00:00
|
|
|
cus_configs = {'spec.components.image': 'milvusdb/milvus:master-20211206-b20a238',
|
2021-12-02 14:49:52 +00:00
|
|
|
'metadata.namespace': namespace,
|
2021-12-06 13:12:01 +00:00
|
|
|
'metadata.name': release_name,
|
|
|
|
'spec.components.proxy.serviceType': 'LoadBalancer'
|
2021-12-02 14:49:52 +00:00
|
|
|
}
|
|
|
|
milvus_op = MilvusOperator()
|
|
|
|
log.info(f"install milvus with configs: {cus_configs}")
|
|
|
|
milvus_op.install(cus_configs)
|
|
|
|
healthy = milvus_op.wait_for_healthy(release_name, namespace, timeout=1200)
|
|
|
|
log.info(f"milvus healthy: {healthy}")
|
|
|
|
if healthy:
|
|
|
|
endpoint = milvus_op.endpoint(release_name, namespace).split(':')
|
|
|
|
log.info(f"milvus endpoint: {endpoint}")
|
|
|
|
host = endpoint[0]
|
|
|
|
port = endpoint[1]
|
|
|
|
return release_name, host, port
|
|
|
|
else:
|
|
|
|
return release_name, None, None
|
|
|
|
|
|
|
|
|
|
|
|
def scale_up_milvus(release_name):
|
2021-12-06 13:12:01 +00:00
|
|
|
cus_configs = {
|
2021-12-02 14:49:52 +00:00
|
|
|
'spec.components.queryNode.replicas': 2
|
2021-12-06 13:12:01 +00:00
|
|
|
}
|
2021-12-02 14:49:52 +00:00
|
|
|
milvus_op = MilvusOperator()
|
|
|
|
log.info(f"scale up milvus with configs: {cus_configs}")
|
2021-12-06 13:12:01 +00:00
|
|
|
milvus_op.upgrade(release_name, cus_configs, namespace=namespace)
|
2021-12-02 14:49:52 +00:00
|
|
|
healthy = milvus_op.wait_for_healthy(release_name, namespace, timeout=1200)
|
|
|
|
log.info(f"milvus healthy: {healthy}")
|
|
|
|
if healthy:
|
|
|
|
endpoint = milvus_op.endpoint(release_name, namespace).split(':')
|
|
|
|
log.info(f"milvus endpoint: {endpoint}")
|
|
|
|
host = endpoint[0]
|
|
|
|
port = endpoint[1]
|
|
|
|
return release_name, host, port
|
|
|
|
else:
|
|
|
|
return release_name, None, None
|
|
|
|
|
|
|
|
|
|
|
|
class TestAutoLoadBalance(object):
|
|
|
|
|
|
|
|
|
2021-12-06 13:12:01 +00:00
|
|
|
def teardown_method(self):
|
|
|
|
milvus_op = MilvusOperator()
|
|
|
|
milvus_op.uninstall(self.release_name, namespace)
|
2021-12-02 14:49:52 +00:00
|
|
|
|
|
|
|
def test_auto_load_balance(self):
|
|
|
|
"""
|
|
|
|
|
|
|
|
"""
|
|
|
|
log.info(f"start to install milvus")
|
|
|
|
release_name, host, port = install_milvus("test-auto-load-balance") # todo add release name
|
|
|
|
self.release_name = release_name
|
|
|
|
assert host is not None
|
|
|
|
conn = connections.connect("default", host=host, port=port)
|
|
|
|
assert conn is not None
|
|
|
|
self.health_checkers = {
|
2023-12-14 11:38:45 +00:00
|
|
|
Op.create: CollectionCreateChecker(),
|
2021-12-02 14:49:52 +00:00
|
|
|
Op.insert: InsertFlushChecker(),
|
|
|
|
Op.flush: InsertFlushChecker(flush=True),
|
2023-12-14 11:38:45 +00:00
|
|
|
Op.index: IndexCreateChecker(),
|
2021-12-02 14:49:52 +00:00
|
|
|
Op.search: SearchChecker(),
|
|
|
|
Op.query: QueryChecker()
|
|
|
|
}
|
|
|
|
cc.start_monitor_threads(self.health_checkers)
|
2023-12-14 11:38:45 +00:00
|
|
|
# wait
|
2021-12-06 13:12:01 +00:00
|
|
|
sleep(constants.WAIT_PER_OP * 10)
|
|
|
|
all_collections = list_collections()
|
|
|
|
for c in all_collections:
|
|
|
|
seg_info = utility.get_query_segment_info(c)
|
|
|
|
seg_distribution = cf.get_segment_distribution(seg_info)
|
|
|
|
for k in seg_distribution.keys():
|
|
|
|
log.info(f"collection {c}'s segment distribution in node {k} is {seg_distribution[k]['sealed']}")
|
2021-12-02 14:49:52 +00:00
|
|
|
# first assert
|
2021-12-06 13:12:01 +00:00
|
|
|
log.info("first assert")
|
2021-12-02 14:49:52 +00:00
|
|
|
assert_statistic(self.health_checkers)
|
|
|
|
|
|
|
|
# scale up
|
2021-12-06 13:12:01 +00:00
|
|
|
log.info("scale up milvus")
|
2021-12-02 14:49:52 +00:00
|
|
|
scale_up_milvus(self.release_name)
|
|
|
|
# reset counting
|
|
|
|
cc.reset_counting(self.health_checkers)
|
2021-12-06 13:12:01 +00:00
|
|
|
sleep(constants.WAIT_PER_OP * 10)
|
|
|
|
all_collections = list_collections()
|
|
|
|
for c in all_collections:
|
|
|
|
seg_info = utility.get_query_segment_info(c)
|
|
|
|
seg_distribution = cf.get_segment_distribution(seg_info)
|
|
|
|
for k in seg_distribution.keys():
|
|
|
|
log.info(f"collection {c}'s sealed segment distribution in node {k} is {seg_distribution[k]['sealed']}")
|
2021-12-02 14:49:52 +00:00
|
|
|
# second assert
|
2021-12-06 13:12:01 +00:00
|
|
|
log.info("second assert")
|
2021-12-02 14:49:52 +00:00
|
|
|
assert_statistic(self.health_checkers)
|
|
|
|
|
|
|
|
# TODO assert segment distribution
|
2021-12-06 13:12:01 +00:00
|
|
|
|
2021-12-02 14:49:52 +00:00
|
|
|
# assert all expectations
|
|
|
|
assert_expectations()
|