colibri.qdrant / tests /basic_sparse_grpc_test.sh
Gouzi Mohaled
Ajout du dossier tests
3932407
#!/usr/bin/env bash
# This test checks that Qdrant answers to all API mentioned in README.md as expected
set -ex
# Ensure current path is project root
cd "$(dirname "$0")/../"
QDRANT_HOST=${QDRANT_HOST:-'localhost:6334'}
docker_grpcurl=("docker" "run" "--rm" "--network=host" "-v" "${PWD}/lib/api/src/grpc/proto:/proto" "fullstorydev/grpcurl" "-plaintext" "-import-path" "/proto" "-proto" "qdrant.proto")
if [ -n "${QDRANT_HOST_HEADERS}" ]; then
while read h; do
docker_grpcurl+=("-H" "$h")
done <<< $(echo "${QDRANT_HOST_HEADERS}" | jq -r 'to_entries|map("\(.key): \(.value)")[]')
fi
"${docker_grpcurl[@]}" -d '{
"collection_name": "test_sparse_collection"
}' $QDRANT_HOST qdrant.Collections/Delete
"${docker_grpcurl[@]}" -d '{
"collection_name": "test_sparse_collection",
"sparse_vectors_config": {
"map": {
"test": { }
}
}
}' $QDRANT_HOST qdrant.Collections/Create
"${docker_grpcurl[@]}" -d '{}' $QDRANT_HOST qdrant.Collections/List
"${docker_grpcurl[@]}" -d '{
"collection_name": "test_sparse_collection",
"wait": true,
"ordering": null,
"points": [
{
"id": { "num": 1 },
"vectors": {
"vectors": {
"vectors": {
"test": { "data": [0.05, 0.61, 0.76, 0.74], "indices": { "data": [0,1,2,3] }}
}
}
},
"payload": {
"city": { "string_value": "Berlin" },
"country": { "string_value": "Germany" },
"population": { "integer_value": 1000000 },
"square": { "double_value": 12.5 },
"coords": { "struct_value": { "fields": { "lat": { "double_value": 1.0 }, "lon": { "double_value": 2.0 } } } }
}
},
{
"id": { "num": 2 },
"vectors": {
"vectors": {
"vectors": {
"test": { "data": [0.19, 0.81, 0.75, 0.11], "indices": { "data": [0,1,2,3] }}
}
}
},
"payload": {"city": {"list_value": {"values": [{ "string_value": "Berlin" }, { "string_value": "London" }]}}}
},
{
"id": { "num": 3 },
"vectors": {
"vectors": {
"vectors": {
"test": { "data": [0.36, 0.55, 0.47, 0.94], "indices": { "data": [0,1,2,3] }}
}
}
},
"payload": {"city": {"list_value": {"values": [{ "string_value": "Berlin" }, { "string_value": "Moscow" }]}}}
},
{
"id": { "num": 4 },
"vectors": {
"vectors": {
"vectors": {
"test": {"data": [0.18, 0.01, 0.85, 0.80], "indices": { "data": [0,1,2,3] }}
}
}
},
"payload": {"city": {"list_value": {"values": [{ "string_value": "London" }, { "string_value": "Moscow" }]}}}
},
{
"id": { "uuid": "98a9a4b1-4ef2-46fb-8315-a97d874fe1d7" },
"vectors": {
"vectors": {
"vectors": {
"test": {"data": [0.24, 0.18, 0.22, 0.44], "indices": { "data": [0,1,2,3] }}
}
}
},
"payload": {"count":{"list_value": {"values": [{ "integer_value": 0 }]}}}
},
{
"id": { "uuid": "f0e09527-b096-42a8-94e9-ea94d342b925" },
"vectors": {
"vectors": {
"vectors": {
"test": {"data": [0.35, 0.08, 0.11, 0.44], "indices": { "data": [0,1,2,3] }}
}
}
}
}
]
}' $QDRANT_HOST qdrant.Points/Upsert
"${docker_grpcurl[@]}" -d '{ "collection_name": "test_sparse_collection" }' $QDRANT_HOST qdrant.Collections/Get
"${docker_grpcurl[@]}" -d '{
"collection_name": "test_sparse_collection",
"vector": [0.2,0.1,0.9,0.7],
"sparse_indices": { "data": [0,1,2,3] },
"vector_name": "test",
"limit": 3
}' $QDRANT_HOST qdrant.Points/Search
"${docker_grpcurl[@]}" -d '{
"collection_name": "test_sparse_collection",
"filter": {
"should": [
{
"field": {
"key": "city",
"match": {
"keyword": "London"
}
}
}
]
},
"vector": [0.2,0.1,0.9,0.7],
"sparse_indices": { "data": [0,1,2,3] },
"vector_name": "test",
"limit": 3
}' $QDRANT_HOST qdrant.Points/Search
"${docker_grpcurl[@]}" -d '{
"collection_name": "test_sparse_collection",
"limit": 2,
"with_vectors": {"enable": true},
"filter": {
"should": [
{
"field": {
"key": "city",
"match": {
"keyword": "London"
}
}
}
]
}
}' $QDRANT_HOST qdrant.Points/Scroll
"${docker_grpcurl[@]}" -d '{
"collection_name": "test_sparse_collection",
"with_vectors": {"enable": true},
"ids": [{ "num": 2 }, { "num": 3 }, { "num": 4 }]
}' $QDRANT_HOST qdrant.Points/Get
# validate search request when vector and indices have different sizes
set +e
response=$(
"${docker_grpcurl[@]}" -d '{
"collection_name": "test_sparse_collection",
"vector": [0.2,0.1],
"sparse_indices": { "data": [0,1,2,3] },
"vector_name": "test",
"limit": 3
}' $QDRANT_HOST qdrant.Points/Search 2>&1
)
if [[ $response != *"Sparse indices does not match sparse vector conditions"* ]]; then
echo Unexpected response, expected validation error: $response
exit 1
fi
response=$(
"${docker_grpcurl[@]}" -d '{
"collection_name": "test_sparse_collection",
"wait": true,
"ordering": null,
"points": [
{
"id": { "uuid": "f0e09527-b096-42a8-94e9-ea94d342b885" },
"vectors": {
"vectors": {
"vectors": {
"test": {"data": [0.35, 0.08], "indices": { "data": [0,1,2,3] }}
}
}
}
}
]
}' $QDRANT_HOST qdrant.Points/Upsert 2>&1
)
if [[ $response != *"Validation error in body: [points[0].vectors.vectors_options.vectors.[].values: Validation error: must be the same length as indices [{}]]"* ]]; then
echo Unexpected response, expected validation error: $response
exit 1
fi
set -e