2021-12-17 00:53:26 +00:00
|
|
|
import os
|
|
|
|
|
2022-05-09 06:51:52 +00:00
|
|
|
from pymilvus import connections, Index, MilvusException
|
2021-07-28 09:01:22 +00:00
|
|
|
|
2021-07-26 07:17:20 +00:00
|
|
|
from utils.util_log import test_log as log
|
2021-07-28 09:01:22 +00:00
|
|
|
from base.collection_wrapper import ApiCollectionWrapper
|
|
|
|
from common import common_func as cf
|
|
|
|
from common import common_type as ct
|
2021-07-26 07:17:20 +00:00
|
|
|
|
|
|
|
|
2021-12-13 13:29:24 +00:00
|
|
|
def e2e_milvus(host, c_name):
|
2022-05-09 06:51:52 +00:00
|
|
|
""" e2e milvus """
|
2021-12-17 00:53:26 +00:00
|
|
|
log.debug(f'pid: {os.getpid()}')
|
2021-07-28 09:01:22 +00:00
|
|
|
# connect
|
|
|
|
connections.add_connection(default={"host": host, "port": 19530})
|
|
|
|
connections.connect(alias='default')
|
|
|
|
|
|
|
|
# create
|
|
|
|
collection_w = ApiCollectionWrapper()
|
2021-12-13 13:29:24 +00:00
|
|
|
collection_w.init_collection(name=c_name, schema=cf.gen_default_collection_schema())
|
2021-07-28 09:01:22 +00:00
|
|
|
|
|
|
|
# insert
|
2021-12-17 00:53:26 +00:00
|
|
|
df = cf.gen_default_dataframe_data()
|
|
|
|
mutation_res, _ = collection_w.insert(df)
|
2021-07-28 09:01:22 +00:00
|
|
|
assert mutation_res.insert_count == ct.default_nb
|
2021-08-24 08:07:52 +00:00
|
|
|
log.debug(collection_w.num_entities)
|
2021-07-28 09:01:22 +00:00
|
|
|
|
|
|
|
# create index
|
|
|
|
collection_w.create_index(ct.default_float_vec_field_name, ct.default_index)
|
|
|
|
assert collection_w.has_index()[0]
|
|
|
|
assert collection_w.index()[0] == Index(collection_w.collection, ct.default_float_vec_field_name,
|
|
|
|
ct.default_index)
|
|
|
|
|
|
|
|
# search
|
|
|
|
collection_w.load()
|
2021-12-17 00:53:26 +00:00
|
|
|
search_res, _ = collection_w.search(cf.gen_vectors(1, dim=ct.default_dim), ct.default_float_vec_field_name,
|
2021-07-28 09:01:22 +00:00
|
|
|
ct.default_search_params, ct.default_limit)
|
|
|
|
assert len(search_res[0]) == ct.default_limit
|
2021-12-17 00:53:26 +00:00
|
|
|
log.debug(search_res[0].ids)
|
2021-07-28 09:01:22 +00:00
|
|
|
|
|
|
|
# query
|
|
|
|
ids = search_res[0].ids[0]
|
|
|
|
term_expr = f'{ct.default_int64_field_name} in [{ids}]'
|
|
|
|
query_res, _ = collection_w.query(term_expr, output_fields=["*", "%"])
|
2022-05-09 06:51:52 +00:00
|
|
|
assert query_res[0][ct.default_int64_field_name] == ids
|
|
|
|
|
|
|
|
|
|
|
|
def check_succ_rate(func_obj):
|
|
|
|
""" check func succ rate"""
|
|
|
|
log.debug(f"{func_obj.name} total: {func_obj.total}, succ: {func_obj.succ}, fail: {func_obj.fail}")
|
|
|
|
if func_obj.total == 0:
|
|
|
|
raise MilvusException(0, f"{func_obj.name} request total 0")
|
|
|
|
assert func_obj.fail == 0 and func_obj.succ // func_obj.total == 1
|