2021-11-29 11:56:01 +00:00
|
|
|
from datetime import datetime
|
2022-05-06 01:51:51 +00:00
|
|
|
import time
|
2021-08-20 03:00:56 +00:00
|
|
|
from pymilvus import utility
|
2021-05-11 09:59:29 +00:00
|
|
|
import sys
|
|
|
|
|
|
|
|
sys.path.append("..")
|
2021-09-30 11:52:16 +00:00
|
|
|
from check.func_check import ResponseChecker
|
2021-06-07 04:15:35 +00:00
|
|
|
from utils.api_request import api_request
|
2022-10-18 09:21:26 +00:00
|
|
|
from pymilvus import BulkInsertState
|
2023-06-26 07:28:44 +00:00
|
|
|
from pymilvus.orm.role import Role
|
2022-10-18 09:21:26 +00:00
|
|
|
from utils.util_log import test_log as log
|
2023-04-20 08:37:02 +00:00
|
|
|
|
2021-08-03 03:01:25 +00:00
|
|
|
TIMEOUT = 20
|
2021-07-26 07:51:20 +00:00
|
|
|
|
|
|
|
|
2021-06-04 01:35:34 +00:00
|
|
|
class ApiUtilityWrapper:
|
2021-05-11 09:59:29 +00:00
|
|
|
""" Method of encapsulating utility files """
|
|
|
|
|
|
|
|
ut = utility
|
2022-08-26 02:08:54 +00:00
|
|
|
role = None
|
2021-05-11 09:59:29 +00:00
|
|
|
|
2022-11-02 12:35:35 +00:00
|
|
|
def do_bulk_insert(self, collection_name, files="", partition_name=None, timeout=None,
|
|
|
|
using="default", check_task=None, check_items=None, **kwargs):
|
2022-10-18 09:21:26 +00:00
|
|
|
working_tasks = self.get_bulk_insert_working_list()
|
|
|
|
log.info(f"before bulk load, there are {len(working_tasks)} working tasks")
|
|
|
|
log.info(f"files to load: {files}")
|
2022-05-06 01:51:51 +00:00
|
|
|
func_name = sys._getframe().f_code.co_name
|
2022-11-02 12:35:35 +00:00
|
|
|
res, is_succ = api_request([self.ut.do_bulk_insert, collection_name,
|
2022-10-18 09:21:26 +00:00
|
|
|
files, partition_name, timeout, using], **kwargs)
|
2022-05-06 01:51:51 +00:00
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
collection_name=collection_name, using=using).run()
|
2022-10-18 09:21:26 +00:00
|
|
|
time.sleep(1)
|
|
|
|
working_tasks = self.get_bulk_insert_working_list()
|
|
|
|
log.info(f"after bulk load, there are {len(working_tasks)} working tasks")
|
2022-05-06 01:51:51 +00:00
|
|
|
return res, check_result
|
|
|
|
|
2023-04-20 08:37:02 +00:00
|
|
|
def get_bulk_insert_state(self, task_id, timeout=None, using="default", check_task=None, check_items=None,
|
|
|
|
**kwargs):
|
2022-05-06 01:51:51 +00:00
|
|
|
func_name = sys._getframe().f_code.co_name
|
2022-10-18 09:21:26 +00:00
|
|
|
res, is_succ = api_request([self.ut.get_bulk_insert_state, task_id, timeout, using], **kwargs)
|
2022-05-06 01:51:51 +00:00
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
task_id=task_id, using=using).run()
|
|
|
|
return res, check_result
|
|
|
|
|
2023-04-20 08:37:02 +00:00
|
|
|
def list_bulk_insert_tasks(self, limit=0, collection_name=None, timeout=None, using="default", check_task=None,
|
|
|
|
check_items=None, **kwargs):
|
2022-10-18 09:21:26 +00:00
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, is_succ = api_request([self.ut.list_bulk_insert_tasks, limit, collection_name, timeout, using], **kwargs)
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
limit=limit, collection_name=collection_name, using=using).run()
|
|
|
|
return res, check_result
|
|
|
|
|
|
|
|
def get_bulk_insert_pending_list(self):
|
|
|
|
tasks = {}
|
|
|
|
for task in self.ut.list_bulk_insert_tasks():
|
|
|
|
if task.state == BulkInsertState.ImportPending:
|
|
|
|
tasks[task.task_id] = task
|
|
|
|
return tasks
|
|
|
|
|
|
|
|
def get_bulk_insert_working_list(self):
|
|
|
|
tasks = {}
|
|
|
|
for task in self.ut.list_bulk_insert_tasks():
|
|
|
|
if task.state in [BulkInsertState.ImportStarted]:
|
|
|
|
tasks[task.task_id] = task
|
|
|
|
return tasks
|
|
|
|
|
|
|
|
def list_all_bulk_insert_tasks(self, limit=0):
|
|
|
|
tasks, _ = self.list_bulk_insert_tasks(limit=limit)
|
|
|
|
pending = 0
|
|
|
|
started = 0
|
|
|
|
persisted = 0
|
|
|
|
completed = 0
|
|
|
|
failed = 0
|
|
|
|
failed_and_cleaned = 0
|
|
|
|
unknown = 0
|
|
|
|
for task in tasks:
|
|
|
|
print(task)
|
|
|
|
if task.state == BulkInsertState.ImportPending:
|
|
|
|
pending = pending + 1
|
|
|
|
elif task.state == BulkInsertState.ImportStarted:
|
|
|
|
started = started + 1
|
|
|
|
elif task.state == BulkInsertState.ImportPersisted:
|
|
|
|
persisted = persisted + 1
|
|
|
|
elif task.state == BulkInsertState.ImportCompleted:
|
|
|
|
completed = completed + 1
|
|
|
|
elif task.state == BulkInsertState.ImportFailed:
|
|
|
|
failed = failed + 1
|
|
|
|
elif task.state == BulkInsertState.ImportFailedAndCleaned:
|
|
|
|
failed_and_cleaned = failed_and_cleaned + 1
|
|
|
|
else:
|
|
|
|
unknown = unknown + 1
|
|
|
|
|
|
|
|
log.info("There are", len(tasks), "bulkload tasks.", pending, "pending,", started, "started,", persisted,
|
2023-04-20 08:37:02 +00:00
|
|
|
"persisted,", completed, "completed,", failed, "failed", failed_and_cleaned, "failed_and_cleaned",
|
2022-10-18 09:21:26 +00:00
|
|
|
unknown, "unknown")
|
|
|
|
|
|
|
|
def wait_for_bulk_insert_tasks_completed(self, task_ids, target_state=BulkInsertState.ImportCompleted,
|
2023-07-31 04:45:03 +00:00
|
|
|
timeout=None, using="default", **kwargs):
|
2022-10-18 09:21:26 +00:00
|
|
|
tasks_state_distribution = {
|
|
|
|
"success": set(),
|
|
|
|
"failed": set(),
|
|
|
|
"in_progress": set()
|
|
|
|
}
|
|
|
|
tasks_state = {}
|
2022-05-06 01:51:51 +00:00
|
|
|
if timeout is not None:
|
2022-10-18 09:21:26 +00:00
|
|
|
task_timeout = timeout
|
2022-05-06 01:51:51 +00:00
|
|
|
else:
|
|
|
|
task_timeout = TIMEOUT
|
2022-10-18 09:21:26 +00:00
|
|
|
start = time.time()
|
|
|
|
end = time.time()
|
|
|
|
log.info(f"wait bulk load timeout is {task_timeout}")
|
|
|
|
pending_tasks = self.get_bulk_insert_pending_list()
|
|
|
|
log.info(f"before waiting, there are {len(pending_tasks)} pending tasks")
|
2023-04-20 08:37:02 +00:00
|
|
|
while len(tasks_state_distribution["success"]) + len(tasks_state_distribution["failed"]) < len(
|
|
|
|
task_ids) and end - start <= task_timeout:
|
2022-10-18 09:21:26 +00:00
|
|
|
time.sleep(2)
|
|
|
|
|
2022-05-06 01:51:51 +00:00
|
|
|
for task_id in task_ids:
|
2022-10-18 09:21:26 +00:00
|
|
|
if task_id in tasks_state_distribution["success"] or task_id in tasks_state_distribution["failed"]:
|
2022-05-06 01:51:51 +00:00
|
|
|
continue
|
|
|
|
else:
|
2022-10-18 09:21:26 +00:00
|
|
|
state, _ = self.get_bulk_insert_state(task_id, task_timeout, using, **kwargs)
|
|
|
|
tasks_state[task_id] = state
|
|
|
|
|
|
|
|
if target_state == BulkInsertState.ImportPersisted:
|
|
|
|
if state.state in [BulkInsertState.ImportPersisted, BulkInsertState.ImportCompleted]:
|
|
|
|
if task_id in tasks_state_distribution["in_progress"]:
|
|
|
|
tasks_state_distribution["in_progress"].remove(task_id)
|
|
|
|
tasks_state_distribution["success"].add(task_id)
|
|
|
|
elif state.state in [BulkInsertState.ImportPending, BulkInsertState.ImportStarted]:
|
|
|
|
tasks_state_distribution["in_progress"].add(task_id)
|
2022-06-16 13:14:10 +00:00
|
|
|
else:
|
2022-10-18 09:21:26 +00:00
|
|
|
tasks_state_distribution["failed"].add(task_id)
|
|
|
|
|
|
|
|
if target_state == BulkInsertState.ImportCompleted:
|
|
|
|
if state.state in [BulkInsertState.ImportCompleted]:
|
|
|
|
if task_id in tasks_state_distribution["in_progress"]:
|
|
|
|
tasks_state_distribution["in_progress"].remove(task_id)
|
|
|
|
tasks_state_distribution["success"].add(task_id)
|
2023-04-20 08:37:02 +00:00
|
|
|
elif state.state in [BulkInsertState.ImportPending, BulkInsertState.ImportStarted,
|
|
|
|
BulkInsertState.ImportPersisted]:
|
2022-10-18 09:21:26 +00:00
|
|
|
tasks_state_distribution["in_progress"].add(task_id)
|
2022-06-16 13:14:10 +00:00
|
|
|
else:
|
2022-10-18 09:21:26 +00:00
|
|
|
tasks_state_distribution["failed"].add(task_id)
|
2023-04-20 08:37:02 +00:00
|
|
|
|
2022-05-06 01:51:51 +00:00
|
|
|
end = time.time()
|
2022-10-18 09:21:26 +00:00
|
|
|
pending_tasks = self.get_bulk_insert_pending_list()
|
|
|
|
log.info(f"after waiting, there are {len(pending_tasks)} pending tasks")
|
|
|
|
log.info(f"task state distribution: {tasks_state_distribution}")
|
2022-12-05 01:01:17 +00:00
|
|
|
log.info(tasks_state)
|
2022-10-18 09:21:26 +00:00
|
|
|
if len(tasks_state_distribution["success"]) == len(task_ids):
|
2023-04-20 08:37:02 +00:00
|
|
|
log.info(f"wait for bulk load tasks completed successfully, cost time: {end - start}")
|
2022-10-18 09:21:26 +00:00
|
|
|
return True, tasks_state
|
2022-05-06 01:51:51 +00:00
|
|
|
else:
|
2023-04-20 08:37:02 +00:00
|
|
|
log.info(f"wait for bulk load tasks completed failed, cost time: {end - start}")
|
2022-10-18 09:21:26 +00:00
|
|
|
return False, tasks_state
|
|
|
|
|
|
|
|
def wait_all_pending_tasks_finished(self):
|
|
|
|
task_states_map = {}
|
|
|
|
all_tasks, _ = self.list_bulk_insert_tasks()
|
|
|
|
# log.info(f"all tasks: {all_tasks}")
|
|
|
|
for task in all_tasks:
|
|
|
|
if task.state in [BulkInsertState.ImportStarted, BulkInsertState.ImportPersisted]:
|
|
|
|
task_states_map[task.task_id] = task.state
|
|
|
|
|
|
|
|
log.info(f"current tasks states: {task_states_map}")
|
|
|
|
pending_tasks = self.get_bulk_insert_pending_list()
|
|
|
|
working_tasks = self.get_bulk_insert_working_list()
|
2023-04-20 08:37:02 +00:00
|
|
|
log.info(
|
|
|
|
f"in the start, there are {len(working_tasks)} working tasks, {working_tasks} {len(pending_tasks)} pending tasks, {pending_tasks}")
|
2022-10-18 09:21:26 +00:00
|
|
|
time_cnt = 0
|
|
|
|
pending_task_ids = set()
|
|
|
|
while len(pending_tasks) > 0:
|
|
|
|
time.sleep(5)
|
|
|
|
time_cnt += 5
|
|
|
|
pending_tasks = self.get_bulk_insert_pending_list()
|
|
|
|
working_tasks = self.get_bulk_insert_working_list()
|
|
|
|
cur_pending_task_ids = []
|
|
|
|
for task_id in pending_tasks.keys():
|
|
|
|
cur_pending_task_ids.append(task_id)
|
|
|
|
pending_task_ids.add(task_id)
|
2023-04-20 08:37:02 +00:00
|
|
|
log.info(
|
|
|
|
f"after {time_cnt}, there are {len(working_tasks)} working tasks, {len(pending_tasks)} pending tasks")
|
2022-10-18 09:21:26 +00:00
|
|
|
log.debug(f"total pending tasks: {pending_task_ids} current pending tasks: {cur_pending_task_ids}")
|
|
|
|
log.info(f"after {time_cnt}, all pending tasks are finished")
|
|
|
|
all_tasks, _ = self.list_bulk_insert_tasks()
|
|
|
|
for task in all_tasks:
|
|
|
|
if task.task_id in pending_task_ids:
|
|
|
|
log.info(f"task {task.task_id} state transfer from pending to {task.state_name}")
|
2022-05-06 01:51:51 +00:00
|
|
|
|
2023-09-26 10:43:32 +00:00
|
|
|
def wait_index_build_completed(self, collection_name, timeout=None):
|
|
|
|
start = time.time()
|
|
|
|
if timeout is not None:
|
|
|
|
task_timeout = timeout
|
|
|
|
else:
|
|
|
|
task_timeout = TIMEOUT
|
|
|
|
end = time.time()
|
|
|
|
while end - start <= task_timeout:
|
|
|
|
time.sleep(0.5)
|
|
|
|
index_states, _ = self.index_building_progress(collection_name)
|
|
|
|
log.debug(f"index states: {index_states}")
|
|
|
|
if index_states["total_rows"] == index_states["indexed_rows"]:
|
|
|
|
log.info(f"index build completed")
|
|
|
|
return True
|
|
|
|
end = time.time()
|
|
|
|
log.info(f"index build timeout")
|
|
|
|
return False
|
|
|
|
|
2021-11-08 12:46:26 +00:00
|
|
|
def get_query_segment_info(self, collection_name, timeout=None, using="default", check_task=None, check_items=None):
|
|
|
|
timeout = TIMEOUT if timeout is None else timeout
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, is_succ = api_request([self.ut.get_query_segment_info, collection_name, timeout, using])
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
2021-12-23 06:23:30 +00:00
|
|
|
collection_name=collection_name, timeout=timeout, using=using).run()
|
2021-11-08 12:46:26 +00:00
|
|
|
return res, check_result
|
|
|
|
|
2021-09-10 02:36:00 +00:00
|
|
|
def loading_progress(self, collection_name, partition_names=None,
|
2021-06-17 03:49:57 +00:00
|
|
|
using="default", check_task=None, check_items=None):
|
2021-05-11 09:59:29 +00:00
|
|
|
func_name = sys._getframe().f_code.co_name
|
2021-06-09 06:23:48 +00:00
|
|
|
res, is_succ = api_request([self.ut.loading_progress, collection_name, partition_names, using])
|
2021-06-17 03:49:57 +00:00
|
|
|
check_result = ResponseChecker(res, func_name, check_task,
|
|
|
|
check_items, is_succ, collection_name=collection_name,
|
2021-06-05 02:25:34 +00:00
|
|
|
partition_names=partition_names, using=using).run()
|
2021-05-11 09:59:29 +00:00
|
|
|
return res, check_result
|
|
|
|
|
2021-09-10 02:36:00 +00:00
|
|
|
def wait_for_loading_complete(self, collection_name, partition_names=None, timeout=None, using="default",
|
2021-06-17 03:49:57 +00:00
|
|
|
check_task=None, check_items=None):
|
2021-07-26 07:51:20 +00:00
|
|
|
timeout = TIMEOUT if timeout is None else timeout
|
|
|
|
|
2021-05-11 09:59:29 +00:00
|
|
|
func_name = sys._getframe().f_code.co_name
|
2021-06-17 03:49:57 +00:00
|
|
|
res, is_succ = api_request([self.ut.wait_for_loading_complete, collection_name,
|
|
|
|
partition_names, timeout, using])
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
collection_name=collection_name, partition_names=partition_names,
|
|
|
|
timeout=timeout, using=using).run()
|
2021-05-11 09:59:29 +00:00
|
|
|
return res, check_result
|
|
|
|
|
2021-06-17 03:49:57 +00:00
|
|
|
def index_building_progress(self, collection_name, index_name="", using="default",
|
|
|
|
check_task=None, check_items=None):
|
2021-05-11 09:59:29 +00:00
|
|
|
func_name = sys._getframe().f_code.co_name
|
2021-06-09 06:23:48 +00:00
|
|
|
res, is_succ = api_request([self.ut.index_building_progress, collection_name, index_name, using])
|
2021-06-17 03:49:57 +00:00
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
collection_name=collection_name, index_name=index_name,
|
2021-06-05 02:25:34 +00:00
|
|
|
using=using).run()
|
2021-05-11 09:59:29 +00:00
|
|
|
return res, check_result
|
|
|
|
|
2021-06-17 03:49:57 +00:00
|
|
|
def wait_for_index_building_complete(self, collection_name, index_name="", timeout=None, using="default",
|
|
|
|
check_task=None, check_items=None):
|
2021-07-26 07:51:20 +00:00
|
|
|
timeout = TIMEOUT if timeout is None else timeout
|
|
|
|
|
2021-05-11 09:59:29 +00:00
|
|
|
func_name = sys._getframe().f_code.co_name
|
2021-07-05 09:18:03 +00:00
|
|
|
res, is_succ = api_request([self.ut.wait_for_index_building_complete, collection_name,
|
2021-06-17 03:49:57 +00:00
|
|
|
index_name, timeout, using])
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
collection_name=collection_name, index_name=index_name,
|
2021-06-05 02:25:34 +00:00
|
|
|
timeout=timeout, using=using).run()
|
2021-05-11 09:59:29 +00:00
|
|
|
return res, check_result
|
|
|
|
|
2021-06-09 06:23:48 +00:00
|
|
|
def has_collection(self, collection_name, using="default", check_task=None, check_items=None):
|
2021-05-11 09:59:29 +00:00
|
|
|
func_name = sys._getframe().f_code.co_name
|
2021-06-09 06:23:48 +00:00
|
|
|
res, is_succ = api_request([self.ut.has_collection, collection_name, using])
|
2021-06-17 03:49:57 +00:00
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
collection_name=collection_name, using=using).run()
|
2021-05-11 09:59:29 +00:00
|
|
|
return res, check_result
|
|
|
|
|
2021-06-17 03:49:57 +00:00
|
|
|
def has_partition(self, collection_name, partition_name, using="default",
|
|
|
|
check_task=None, check_items=None):
|
2021-05-11 09:59:29 +00:00
|
|
|
func_name = sys._getframe().f_code.co_name
|
2021-06-09 06:23:48 +00:00
|
|
|
res, is_succ = api_request([self.ut.has_partition, collection_name, partition_name, using])
|
2021-06-17 03:49:57 +00:00
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
collection_name=collection_name,
|
2021-06-05 02:25:34 +00:00
|
|
|
partition_name=partition_name, using=using).run()
|
2021-05-11 09:59:29 +00:00
|
|
|
return res, check_result
|
|
|
|
|
2021-09-10 02:36:00 +00:00
|
|
|
def drop_collection(self, collection_name, timeout=None, using="default", check_task=None, check_items=None):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
2021-09-10 10:34:02 +00:00
|
|
|
res, is_succ = api_request([self.ut.drop_collection, collection_name, timeout, using])
|
2021-09-10 02:36:00 +00:00
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
collection_name=collection_name,
|
|
|
|
timeout=timeout, using=using).run()
|
|
|
|
return res, check_result
|
|
|
|
|
2021-06-09 06:23:48 +00:00
|
|
|
def list_collections(self, timeout=None, using="default", check_task=None, check_items=None):
|
2021-07-26 07:51:20 +00:00
|
|
|
timeout = TIMEOUT if timeout is None else timeout
|
|
|
|
|
2021-05-11 09:59:29 +00:00
|
|
|
func_name = sys._getframe().f_code.co_name
|
2021-06-09 06:23:48 +00:00
|
|
|
res, is_succ = api_request([self.ut.list_collections, timeout, using])
|
2021-06-17 03:49:57 +00:00
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
timeout=timeout, using=using).run()
|
2021-05-11 09:59:29 +00:00
|
|
|
return res, check_result
|
2021-08-12 10:12:10 +00:00
|
|
|
|
|
|
|
def calc_distance(self, vectors_left, vectors_right, params=None, timeout=None,
|
|
|
|
using="default", check_task=None, check_items=None):
|
|
|
|
timeout = TIMEOUT if timeout is None else timeout
|
|
|
|
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, is_succ = api_request([self.ut.calc_distance, vectors_left, vectors_right,
|
|
|
|
params, timeout, using])
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
timeout=timeout, using=using).run()
|
|
|
|
return res, check_result
|
2021-11-08 12:48:34 +00:00
|
|
|
|
2022-04-26 10:35:45 +00:00
|
|
|
def load_balance(self, collection_name, src_node_id, dst_node_ids, sealed_segment_ids, timeout=None,
|
2021-11-08 12:48:34 +00:00
|
|
|
using="default", check_task=None, check_items=None):
|
|
|
|
timeout = TIMEOUT if timeout is None else timeout
|
|
|
|
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
2022-04-26 10:35:45 +00:00
|
|
|
res, is_succ = api_request([self.ut.load_balance, collection_name, src_node_id, dst_node_ids,
|
2021-11-08 12:48:34 +00:00
|
|
|
sealed_segment_ids, timeout, using])
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
timeout=timeout, using=using).run()
|
|
|
|
return res, check_result
|
2021-11-29 11:56:01 +00:00
|
|
|
|
2021-12-17 12:46:15 +00:00
|
|
|
def create_alias(self, collection_name, alias, timeout=None, using="default", check_task=None, check_items=None):
|
|
|
|
timeout = TIMEOUT if timeout is None else timeout
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, is_succ = api_request([self.ut.create_alias, collection_name, alias, timeout, using])
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
timeout=timeout, using=using).run()
|
|
|
|
return res, check_result
|
|
|
|
|
|
|
|
def drop_alias(self, alias, timeout=None, using="default", check_task=None, check_items=None):
|
|
|
|
timeout = TIMEOUT if timeout is None else timeout
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, is_succ = api_request([self.ut.drop_alias, alias, timeout, using])
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
timeout=timeout, using=using).run()
|
|
|
|
return res, check_result
|
|
|
|
|
|
|
|
def alter_alias(self, collection_name, alias, timeout=None, using="default", check_task=None, check_items=None):
|
|
|
|
timeout = TIMEOUT if timeout is None else timeout
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, is_succ = api_request([self.ut.alter_alias, collection_name, alias, timeout, using])
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
timeout=timeout, using=using).run()
|
|
|
|
return res, check_result
|
|
|
|
|
|
|
|
def list_aliases(self, collection_name, timeout=None, using="default", check_task=None, check_items=None):
|
|
|
|
timeout = TIMEOUT if timeout is None else timeout
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, is_succ = api_request([self.ut.list_aliases, collection_name, timeout, using])
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
timeout=timeout, using=using).run()
|
|
|
|
return res, check_result
|
|
|
|
|
2021-11-29 11:56:01 +00:00
|
|
|
def mkts_from_datetime(self, d_time=None, milliseconds=0., delta=None):
|
|
|
|
d_time = datetime.now() if d_time is None else d_time
|
2021-11-30 12:11:44 +00:00
|
|
|
res, _ = api_request([self.ut.mkts_from_datetime, d_time, milliseconds, delta])
|
|
|
|
return res
|
|
|
|
|
|
|
|
def mkts_from_hybridts(self, hybridts, milliseconds=0., delta=None):
|
|
|
|
res, _ = api_request([self.ut.mkts_from_hybridts, hybridts, milliseconds, delta])
|
2021-11-29 11:56:01 +00:00
|
|
|
return res
|
2022-05-06 01:51:51 +00:00
|
|
|
|
2022-08-16 06:42:48 +00:00
|
|
|
def create_user(self, user, password, using="default", check_task=None, check_items=None):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, is_succ = api_request([self.ut.create_user, user, password, using])
|
2023-04-20 08:37:02 +00:00
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ, using=using).run()
|
2022-08-16 06:42:48 +00:00
|
|
|
return res, check_result
|
|
|
|
|
|
|
|
def list_usernames(self, using="default", check_task=None, check_items=None):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, is_succ = api_request([self.ut.list_usernames, using])
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
using=using).run()
|
|
|
|
return res, check_result
|
2022-06-16 13:14:10 +00:00
|
|
|
|
2022-08-16 06:42:48 +00:00
|
|
|
def reset_password(self, user, old_password, new_password, check_task=None, check_items=None):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, is_succ = api_request([self.ut.reset_password, user, old_password, new_password])
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ).run()
|
|
|
|
return res, check_result
|
|
|
|
|
2022-09-08 01:44:35 +00:00
|
|
|
def update_password(self, user, old_password, new_password, check_task=None, check_items=None):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, is_succ = api_request([self.ut.update_password, user, old_password, new_password])
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ).run()
|
|
|
|
return res, check_result
|
|
|
|
|
2022-08-16 06:42:48 +00:00
|
|
|
def delete_user(self, user, using="default", check_task=None, check_items=None):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, is_succ = api_request([self.ut.delete_user, user, using])
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
using=using).run()
|
|
|
|
return res, check_result
|
2022-08-26 02:08:54 +00:00
|
|
|
|
|
|
|
def list_roles(self, include_user_info: bool, using="default", check_task=None, check_items=None):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, is_succ = api_request([self.ut.list_roles, include_user_info, using])
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ, using=using).run()
|
|
|
|
return res, check_result
|
|
|
|
|
|
|
|
def list_user(self, username: str, include_role_info: bool, using="default", check_task=None, check_items=None):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, is_succ = api_request([self.ut.list_user, username, include_role_info, using])
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ, using=using).run()
|
|
|
|
return res, check_result
|
|
|
|
|
|
|
|
def list_users(self, include_role_info: bool, using="default", check_task=None, check_items=None):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, is_succ = api_request([self.ut.list_users, include_role_info, using])
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ, using=using).run()
|
|
|
|
return res, check_result
|
|
|
|
|
2023-06-26 07:28:44 +00:00
|
|
|
def init_role(self, name, using="default", check_task=None, check_items=None, **kwargs):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, is_succ = api_request([Role, name, using], **kwargs)
|
|
|
|
self.role = res if is_succ else None
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
name=name, **kwargs).run()
|
|
|
|
return res, check_result
|
|
|
|
|
|
|
|
def create_role(self, check_task=None, check_items=None, **kwargs):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, is_succ = api_request([self.role.create], **kwargs)
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, is_succ,
|
|
|
|
**kwargs).run()
|
|
|
|
return res, check_result
|
|
|
|
|
2022-08-26 02:08:54 +00:00
|
|
|
def role_drop(self, check_task=None, check_items=None, **kwargs):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, check = api_request([self.role.drop], **kwargs)
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, check, **kwargs).run()
|
|
|
|
return res, check_result
|
|
|
|
|
|
|
|
def role_is_exist(self, check_task=None, check_items=None, **kwargs):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, check = api_request([self.role.is_exist], **kwargs)
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, check, **kwargs).run()
|
|
|
|
return res, check_result
|
|
|
|
|
|
|
|
def role_add_user(self, username: str, check_task=None, check_items=None, **kwargs):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, check = api_request([self.role.add_user, username], **kwargs)
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, check, **kwargs).run()
|
|
|
|
return res, check_result
|
|
|
|
|
|
|
|
def role_remove_user(self, username: str, check_task=None, check_items=None, **kwargs):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, check = api_request([self.role.remove_user, username], **kwargs)
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, check, **kwargs).run()
|
|
|
|
return res, check_result
|
|
|
|
|
|
|
|
def role_get_users(self, check_task=None, check_items=None, **kwargs):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, check = api_request([self.role.get_users], **kwargs)
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, check, **kwargs).run()
|
|
|
|
return res, check_result
|
|
|
|
|
|
|
|
@property
|
|
|
|
def role_name(self):
|
|
|
|
return self.role.name
|
|
|
|
|
2023-06-29 07:38:23 +00:00
|
|
|
def role_grant(self, object: str, object_name: str, privilege: str, db_name: str = "default", check_task=None, check_items=None, **kwargs):
|
2022-08-26 02:08:54 +00:00
|
|
|
func_name = sys._getframe().f_code.co_name
|
2023-06-26 07:28:44 +00:00
|
|
|
res, check = api_request([self.role.grant, object, object_name, privilege, db_name], **kwargs)
|
2022-08-26 02:08:54 +00:00
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, check, **kwargs).run()
|
|
|
|
return res, check_result
|
|
|
|
|
2023-06-29 07:38:23 +00:00
|
|
|
def role_revoke(self, object: str, object_name: str, privilege: str, db_name: str = "default", check_task=None, check_items=None, **kwargs):
|
2022-08-26 02:08:54 +00:00
|
|
|
func_name = sys._getframe().f_code.co_name
|
2023-06-26 07:28:44 +00:00
|
|
|
res, check = api_request([self.role.revoke, object, object_name, privilege, db_name], **kwargs)
|
2022-08-26 02:08:54 +00:00
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, check, **kwargs).run()
|
|
|
|
return res, check_result
|
|
|
|
|
2023-06-29 07:38:23 +00:00
|
|
|
def role_list_grant(self, object: str, object_name: str, db_name: str = "default", check_task=None, check_items=None, **kwargs):
|
2022-08-26 02:08:54 +00:00
|
|
|
func_name = sys._getframe().f_code.co_name
|
2023-06-26 07:28:44 +00:00
|
|
|
res, check = api_request([self.role.list_grant, object, object_name, db_name], **kwargs)
|
2022-08-26 02:08:54 +00:00
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, check, **kwargs).run()
|
|
|
|
return res, check_result
|
|
|
|
|
2023-06-29 07:38:23 +00:00
|
|
|
def role_list_grants(self, db_name: str = "default", check_task=None, check_items=None, **kwargs):
|
2022-08-26 02:08:54 +00:00
|
|
|
func_name = sys._getframe().f_code.co_name
|
2023-06-26 07:28:44 +00:00
|
|
|
res, check = api_request([self.role.list_grants, db_name], **kwargs)
|
2022-08-26 02:08:54 +00:00
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, check, **kwargs).run()
|
2023-02-10 03:50:31 +00:00
|
|
|
return res, check_result
|
|
|
|
|
|
|
|
def create_resource_group(self, name, using="default", timeout=None, check_task=None, check_items=None, **kwargs):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, check = api_request([self.ut.create_resource_group, name, using, timeout], **kwargs)
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, check, **kwargs).run()
|
|
|
|
return res, check_result
|
|
|
|
|
|
|
|
def drop_resource_group(self, name, using="default", timeout=None, check_task=None, check_items=None, **kwargs):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, check = api_request([self.ut.drop_resource_group, name, using, timeout], **kwargs)
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, check, **kwargs).run()
|
|
|
|
return res, check_result
|
|
|
|
|
|
|
|
def list_resource_groups(self, using="default", timeout=None, check_task=None, check_items=None, **kwargs):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, check = api_request([self.ut.list_resource_groups, using, timeout], **kwargs)
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, check, **kwargs).run()
|
|
|
|
return res, check_result
|
|
|
|
|
|
|
|
def describe_resource_group(self, name, using="default", timeout=None, check_task=None, check_items=None, **kwargs):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, check = api_request([self.ut.describe_resource_group, name, using, timeout], **kwargs)
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, check, **kwargs).run()
|
|
|
|
return res, check_result
|
|
|
|
|
2023-04-20 08:37:02 +00:00
|
|
|
def transfer_node(self, source, target, num_node, using="default", timeout=None, check_task=None, check_items=None,
|
|
|
|
**kwargs):
|
2023-02-10 03:50:31 +00:00
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, check = api_request([self.ut.transfer_node, source, target, num_node, using, timeout], **kwargs)
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, check, **kwargs).run()
|
|
|
|
return res, check_result
|
|
|
|
|
2023-04-20 08:37:02 +00:00
|
|
|
def transfer_replica(self, source, target, collection_name, num_replica, using="default", timeout=None,
|
|
|
|
check_task=None, check_items=None, **kwargs):
|
2023-02-10 03:50:31 +00:00
|
|
|
func_name = sys._getframe().f_code.co_name
|
2023-04-20 08:37:02 +00:00
|
|
|
res, check = api_request(
|
|
|
|
[self.ut.transfer_replica, source, target, collection_name, num_replica, using, timeout], **kwargs)
|
2023-02-10 03:50:31 +00:00
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, check, **kwargs).run()
|
|
|
|
return res, check_result
|
|
|
|
|
2023-10-20 02:42:07 +00:00
|
|
|
def rename_collection(self, old_collection_name, new_collection_name, new_db_name="", timeout=None,
|
|
|
|
check_task=None, check_items=None, **kwargs):
|
2023-02-23 09:59:46 +00:00
|
|
|
func_name = sys._getframe().f_code.co_name
|
2023-10-20 02:42:07 +00:00
|
|
|
res, check = api_request([self.ut.rename_collection, old_collection_name, new_collection_name, new_db_name,
|
|
|
|
timeout], **kwargs)
|
2023-02-23 09:59:46 +00:00
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, check,
|
|
|
|
old_collection_name=old_collection_name, new_collection_name=new_collection_name,
|
2023-10-20 02:42:07 +00:00
|
|
|
new_db_name=new_db_name, timeout=timeout, **kwargs).run()
|
2023-02-23 09:59:46 +00:00
|
|
|
return res, check_result
|
|
|
|
|
2023-04-20 08:37:02 +00:00
|
|
|
def flush_all(self, using="default", timeout=None, check_task=None, check_items=None, **kwargs):
|
|
|
|
func_name = sys._getframe().f_code.co_name
|
|
|
|
res, check = api_request([self.ut.flush_all, using, timeout], **kwargs)
|
|
|
|
check_result = ResponseChecker(res, func_name, check_task, check_items, check,
|
|
|
|
using=using, timeout=timeout, **kwargs).run()
|
|
|
|
return res, check_result
|
|
|
|
|