mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-07 01:28:27 +08:00
Update simd compatibility test (#27880)
Signed-off-by: yanliang567 <yanliang.qiao@zilliz.com>
This commit is contained in:
parent
de26231976
commit
8b5b33fce0
@ -58,7 +58,7 @@ class MilvusOperator(object):
|
|||||||
Return: custom resource object instance
|
Return: custom resource object instance
|
||||||
"""
|
"""
|
||||||
new_configs = self._update_configs(configs, template)
|
new_configs = self._update_configs(configs, template)
|
||||||
print(new_configs)
|
log.debug(new_configs)
|
||||||
namespace = new_configs['metadata'].get('namespace', 'default')
|
namespace = new_configs['metadata'].get('namespace', 'default')
|
||||||
# apply custom resource object to deploy milvus
|
# apply custom resource object to deploy milvus
|
||||||
cus_res = CusResource(kind=self.plural, group=self.group,
|
cus_res = CusResource(kind=self.plural, group=self.group,
|
||||||
|
|||||||
@ -1,29 +1,32 @@
|
|||||||
apiVersion: milvus.io/v1alpha1
|
apiVersion: milvus.io/v1beta1
|
||||||
kind: MilvusCluster
|
kind: Milvus
|
||||||
metadata:
|
metadata:
|
||||||
name: my-release
|
name: my-release
|
||||||
|
namespace: chaos-testing
|
||||||
labels:
|
labels:
|
||||||
app: milvus
|
app: milvus
|
||||||
spec:
|
spec:
|
||||||
|
config:
|
||||||
|
log:
|
||||||
|
level: debug
|
||||||
|
common:
|
||||||
|
simdType: avx
|
||||||
|
components: {}
|
||||||
dependencies:
|
dependencies:
|
||||||
etcd:
|
etcd:
|
||||||
inCluster:
|
|
||||||
deletionPolicy: Delete
|
|
||||||
pvcDeletion: true
|
|
||||||
pulsar:
|
|
||||||
inCluster:
|
inCluster:
|
||||||
deletionPolicy: Delete
|
deletionPolicy: Delete
|
||||||
pvcDeletion: true
|
pvcDeletion: true
|
||||||
values:
|
values:
|
||||||
proxy:
|
metrics:
|
||||||
configData:
|
podMonitor:
|
||||||
httpNumThreads: "100"
|
enabled: true
|
||||||
storage:
|
storage:
|
||||||
inCluster:
|
inCluster:
|
||||||
deletionPolicy: Delete
|
deletionPolicy: Delete
|
||||||
pvcDeletion: true
|
pvcDeletion: true
|
||||||
config:
|
values:
|
||||||
log:
|
metrics:
|
||||||
level: debug
|
podMonitor:
|
||||||
components: {}
|
enabled: true
|
||||||
|
|
||||||
@ -24,11 +24,10 @@ namespace = 'chaos-testing'
|
|||||||
|
|
||||||
def _install_milvus(simd):
|
def _install_milvus(simd):
|
||||||
release_name = f"mil-{simd.replace('_','-')}-" + cf.gen_digits_by_length(6)
|
release_name = f"mil-{simd.replace('_','-')}-" + cf.gen_digits_by_length(6)
|
||||||
cus_configs = {'spec.components.image': 'milvusdb/milvus:master-latest',
|
cus_configs = {'spec.components.image': 'harbor.milvus.io/milvus/milvus:master-latest',
|
||||||
'metadata.namespace': namespace,
|
'metadata.namespace': namespace,
|
||||||
'metadata.name': release_name,
|
'metadata.name': release_name,
|
||||||
'spec.components.proxy.serviceType': 'LoadBalancer',
|
'spec.config.common.simdType': simd
|
||||||
'spec.config.knowhere.simdType': simd
|
|
||||||
}
|
}
|
||||||
milvus_op = MilvusOperator()
|
milvus_op = MilvusOperator()
|
||||||
log.info(f"install milvus with configs: {cus_configs}")
|
log.info(f"install milvus with configs: {cus_configs}")
|
||||||
@ -52,17 +51,17 @@ class TestSimdCompatibility:
|
|||||||
milvus_op.uninstall(self.release_name, namespace)
|
milvus_op.uninstall(self.release_name, namespace)
|
||||||
|
|
||||||
@pytest.mark.tags(CaseLabel.L3)
|
@pytest.mark.tags(CaseLabel.L3)
|
||||||
@pytest.mark.parametrize('simd_id', [i for i in range(len(supported_simd_types))])
|
@pytest.mark.parametrize('simd', supported_simd_types)
|
||||||
def test_simd_compat_e2e(self, simd_id):
|
def test_simd_compat_e2e(self, simd):
|
||||||
"""
|
"""
|
||||||
steps
|
steps
|
||||||
1. [test_milvus_install]: set up milvus with customized simd configured
|
1. [test_milvus_install]: set up milvus with customized simd configured
|
||||||
2. [test_simd_compat_e2e]: verify milvus is working well
|
2. [test_simd_compat_e2e]: verify milvus is working well
|
||||||
4. [test_milvus_cleanup]: delete milvus instances in teardown
|
4. [test_milvus_cleanup]: delete milvus instances in teardown
|
||||||
"""
|
"""
|
||||||
simd = supported_simd_types[simd_id]
|
|
||||||
log.info(f"start to install milvus with simd {simd}")
|
log.info(f"start to install milvus with simd {simd}")
|
||||||
release_name, host, port = _install_milvus(simd)
|
release_name, host, port = _install_milvus(simd)
|
||||||
|
time.sleep(10)
|
||||||
self.release_name = release_name
|
self.release_name = release_name
|
||||||
assert host is not None
|
assert host is not None
|
||||||
conn = connections.connect("default", host=host, port=port)
|
conn = connections.connect("default", host=host, port=port)
|
||||||
@ -70,38 +69,55 @@ class TestSimdCompatibility:
|
|||||||
mil = MilvusSys(alias="default")
|
mil = MilvusSys(alias="default")
|
||||||
log.info(f"milvus build version: {mil.build_version}")
|
log.info(f"milvus build version: {mil.build_version}")
|
||||||
log.info(f"milvus simdType: {mil.simd_type}")
|
log.info(f"milvus simdType: {mil.simd_type}")
|
||||||
assert str(mil.simd_type).lower() in [simd_type.lower() for simd_type in supported_simd_types[simd_id:]]
|
assert str(mil.simd_type).lower() == simd.lower()
|
||||||
|
|
||||||
log.info(f"start to e2e verification: {simd}")
|
log.info(f"start to e2e verification: {simd}")
|
||||||
# create
|
# create
|
||||||
name = cf.gen_unique_str("compat")
|
prefix = "simd_"
|
||||||
|
name = cf.gen_unique_str(prefix)
|
||||||
t0 = time.time()
|
t0 = time.time()
|
||||||
collection_w = ApiCollectionWrapper()
|
collection_w = ApiCollectionWrapper()
|
||||||
collection_w.init_collection(name=name,
|
collection_w.init_collection_wrap(name=name)
|
||||||
schema=cf.gen_default_collection_schema(),
|
|
||||||
timeout=40)
|
|
||||||
tt = time.time() - t0
|
tt = time.time() - t0
|
||||||
assert collection_w.name == name
|
assert collection_w.name == name
|
||||||
entities = collection_w.num_entities
|
entities = collection_w.num_entities
|
||||||
log.info(f"assert create collection: {tt}, init_entities: {entities}")
|
log.info(f"assert create collection: {tt}, init_entities: {entities}")
|
||||||
|
|
||||||
# insert
|
# insert
|
||||||
data = cf.gen_default_list_data()
|
for _ in range(10):
|
||||||
t0 = time.time()
|
data = cf.gen_default_list_data(nb=300)
|
||||||
_, res = collection_w.insert(data)
|
t0 = time.time()
|
||||||
tt = time.time() - t0
|
_, res = collection_w.insert(data)
|
||||||
log.info(f"assert insert: {tt}")
|
tt = time.time() - t0
|
||||||
assert res
|
log.info(f"assert insert: {tt}")
|
||||||
|
assert res
|
||||||
|
|
||||||
# flush
|
# flush
|
||||||
t0 = time.time()
|
t0 = time.time()
|
||||||
|
_, check_result = collection_w.flush(timeout=180)
|
||||||
|
assert check_result
|
||||||
assert collection_w.num_entities == len(data[0]) + entities
|
assert collection_w.num_entities == len(data[0]) + entities
|
||||||
tt = time.time() - t0
|
tt = time.time() - t0
|
||||||
entities = collection_w.num_entities
|
entities = collection_w.num_entities
|
||||||
log.info(f"assert flush: {tt}, entities: {entities}")
|
log.info(f"assert flush: {tt}, entities: {entities}")
|
||||||
|
|
||||||
# search
|
# index
|
||||||
|
index_params = {"index_type": "IVF_SQ8", "params": {"nlist": 64}, "metric_type": "L2"}
|
||||||
|
t0 = time.time()
|
||||||
|
index, _ = collection_w.create_index(field_name=ct.default_float_vec_field_name,
|
||||||
|
index_params=index_params,
|
||||||
|
index_name=cf.gen_unique_str())
|
||||||
|
index, _ = collection_w.create_index(field_name=ct.default_string_field_name,
|
||||||
|
index_params={},
|
||||||
|
index_name=cf.gen_unique_str())
|
||||||
|
tt = time.time() - t0
|
||||||
|
log.info(f"assert index: {tt}")
|
||||||
|
assert len(collection_w.indexes) == 2
|
||||||
|
|
||||||
|
# load
|
||||||
collection_w.load()
|
collection_w.load()
|
||||||
|
|
||||||
|
# search
|
||||||
search_vectors = cf.gen_vectors(1, ct.default_dim)
|
search_vectors = cf.gen_vectors(1, ct.default_dim)
|
||||||
search_params = {"metric_type": "L2", "params": {"nprobe": 16}}
|
search_params = {"metric_type": "L2", "params": {"nprobe": 16}}
|
||||||
t0 = time.time()
|
t0 = time.time()
|
||||||
@ -111,37 +127,35 @@ class TestSimdCompatibility:
|
|||||||
tt = time.time() - t0
|
tt = time.time() - t0
|
||||||
log.info(f"assert search: {tt}")
|
log.info(f"assert search: {tt}")
|
||||||
assert len(res_1) == 1
|
assert len(res_1) == 1
|
||||||
|
|
||||||
|
# release
|
||||||
collection_w.release()
|
collection_w.release()
|
||||||
|
|
||||||
# index
|
# insert
|
||||||
d = cf.gen_default_list_data()
|
d = cf.gen_default_list_data()
|
||||||
collection_w.insert(d)
|
collection_w.insert(d)
|
||||||
log.info(f"assert index entities: {collection_w.num_entities}")
|
|
||||||
_index_params = {"index_type": "IVF_SQ8", "params": {"nlist": 64}, "metric_type": "L2"}
|
|
||||||
t0 = time.time()
|
|
||||||
index, _ = collection_w.create_index(field_name=ct.default_float_vec_field_name,
|
|
||||||
index_params=_index_params,
|
|
||||||
name=cf.gen_unique_str())
|
|
||||||
tt = time.time() - t0
|
|
||||||
log.info(f"assert index: {tt}")
|
|
||||||
assert len(collection_w.indexes) == 1
|
|
||||||
|
|
||||||
# search
|
# search
|
||||||
t0 = time.time()
|
t0 = time.time()
|
||||||
collection_w.load()
|
collection_w.load()
|
||||||
tt = time.time() - t0
|
tt = time.time() - t0
|
||||||
log.info(f"assert load: {tt}")
|
log.info(f"assert load: {tt}")
|
||||||
search_vectors = cf.gen_vectors(1, ct.default_dim)
|
nq = 5
|
||||||
|
topk = 5
|
||||||
|
search_vectors = cf.gen_vectors(nq, ct.default_dim)
|
||||||
t0 = time.time()
|
t0 = time.time()
|
||||||
res_1, _ = collection_w.search(data=search_vectors,
|
res, _ = collection_w.search(data=search_vectors,
|
||||||
anns_field=ct.default_float_vec_field_name,
|
anns_field=ct.default_float_vec_field_name,
|
||||||
param=search_params, limit=1)
|
param=search_params, limit=topk)
|
||||||
tt = time.time() - t0
|
tt = time.time() - t0
|
||||||
log.info(f"assert search: {tt}")
|
log.info(f"assert search: {tt}")
|
||||||
|
assert len(res) == nq
|
||||||
|
assert len(res[0]) <= topk
|
||||||
# query
|
# query
|
||||||
term_expr = f'{ct.default_int64_field_name} in [1001,1201,4999,2999]'
|
term_expr = f'{ct.default_int64_field_name} in [1, 2, 3, 4]'
|
||||||
t0 = time.time()
|
t0 = time.time()
|
||||||
res, _ = collection_w.query(term_expr)
|
res, _ = collection_w.query(term_expr)
|
||||||
tt = time.time() - t0
|
tt = time.time() - t0
|
||||||
log.info(f"assert query result {len(res)}: {tt}")
|
log.info(f"assert query result {len(res)}: {tt}")
|
||||||
|
assert len(res) >= 4
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user