colibri.qdrant / tests /openapi /test_payload_operations.py
Gouzi Mohaled
Ajout du dossier tests
3932407
import pytest
from .helpers.collection_setup import basic_collection_setup, drop_collection
from .helpers.helpers import request_with_validation
@pytest.fixture(autouse=True)
def setup(on_disk_vectors, collection_name):
basic_collection_setup(collection_name=collection_name, on_disk_vectors=on_disk_vectors)
yield
drop_collection(collection_name=collection_name)
def test_payload_operations(collection_name):
# create payload
response = request_with_validation(
api='/collections/{collection_name}/points/payload',
method="POST",
path_params={'collection_name': collection_name},
query_params={'wait': 'true'},
body={
"payload": {"test_payload": "keyword"},
"points": [6]
}
)
assert response.ok
# check payload
response = request_with_validation(
api='/collections/{collection_name}/points/{id}',
method="GET",
path_params={'collection_name': collection_name, 'id': 6},
)
assert response.ok
assert len(response.json()['result']['payload']) == 1
# clean payload by filter
response = request_with_validation(
api='/collections/{collection_name}/points/payload/clear',
method="POST",
path_params={'collection_name': collection_name},
query_params={'wait': 'true'},
body={
"filter": {
"must": [
{"has_id": [6]}
]
}
}
)
assert response.ok
# check payload
response = request_with_validation(
api='/collections/{collection_name}/points/{id}',
method="GET",
path_params={'collection_name': collection_name, 'id': 6},
)
assert response.ok
assert len(response.json()['result']['payload']) == 0
# create payload
response = request_with_validation(
api='/collections/{collection_name}/points/payload',
method="POST",
path_params={'collection_name': collection_name},
query_params={'wait': 'true'},
body={
"payload": {"test_payload": "keyword"},
"points": [6]
}
)
assert response.ok
# delete payload by id
response = request_with_validation(
api='/collections/{collection_name}/points/payload/delete',
method="POST",
path_params={'collection_name': collection_name},
query_params={'wait': 'true'},
body={
"keys": ["test_payload"],
"points": [6]
}
)
assert response.ok
# check payload
response = request_with_validation(
api='/collections/{collection_name}/points/{id}',
method="GET",
path_params={'collection_name': collection_name, 'id': 6},
)
assert response.ok
assert len(response.json()['result']['payload']) == 0
#
# test PUT vs POST of the payload - set vs overwrite
#
response = request_with_validation(
api='/collections/{collection_name}/points/payload',
method="PUT",
path_params={'collection_name': collection_name},
body={
"payload": {"key1": "aaa", "key2": "bbb"},
"points": [6]
}
)
assert response.ok
# check payload
response = request_with_validation(
api='/collections/{collection_name}/points/{id}',
method="GET",
path_params={'collection_name': collection_name, 'id': 6},
)
assert response.ok
assert len(response.json()['result']['payload']) == 2
response = request_with_validation(
api='/collections/{collection_name}/points/payload',
method="POST",
path_params={'collection_name': collection_name},
body={
"payload": {"key1": "ccc"},
"points": [6]
}
)
assert response.ok
# check payload
response = request_with_validation(
api='/collections/{collection_name}/points/{id}',
method="GET",
path_params={'collection_name': collection_name, 'id': 6},
)
assert response.ok
assert len(response.json()['result']['payload']) == 2
assert response.json()['result']['payload']["key1"] == "ccc"
assert response.json()['result']['payload']["key2"] == "bbb"
response = request_with_validation(
api='/collections/{collection_name}/points/payload',
method="PUT",
path_params={'collection_name': collection_name},
body={
"payload": {"key2": "eee"},
"points": [6]
}
)
assert response.ok
# check payload
response = request_with_validation(
api='/collections/{collection_name}/points/{id}',
method="GET",
path_params={'collection_name': collection_name, 'id': 6},
)
assert response.ok
assert len(response.json()['result']['payload']) == 1
assert response.json()['result']['payload']["key2"] == "eee"
#
# Check set and update of payload by filter
#
response = request_with_validation(
api='/collections/{collection_name}/points/payload',
method="POST",
path_params={'collection_name': collection_name},
body={
"payload": {"key4": "aaa"},
"points": [1, 2, 3]
}
)
assert response.ok
response = request_with_validation(
api='/collections/{collection_name}/points/scroll',
method="POST",
path_params={'collection_name': collection_name},
body={
"filter": {
"must": [
{
"key": "key4",
"match": {
"value": "aaa"
}
}
]
}
}
)
assert response.ok
assert len(response.json()['result']['points']) == 3
response = request_with_validation(
api='/collections/{collection_name}/points/payload',
method="POST",
path_params={'collection_name': collection_name},
body={
"payload": {"key5": "bbb"},
"filter": {
"must": [
{
"key": "key4",
"match": {
"value": "aaa"
}
}
]
}
}
)
assert response.ok
response = request_with_validation(
api='/collections/{collection_name}/points/scroll',
method="POST",
path_params={'collection_name': collection_name},
body={
"filter": {
"must": [
{
"key": "key5",
"match": {
"value": "bbb"
}
}
]
}
}
)
assert response.ok
assert len(response.json()['result']['points']) == 3
# set property of payload by empty key
response = request_with_validation(
api='/collections/{collection_name}/points/payload',
method="POST",
path_params={'collection_name': collection_name},
query_params={'wait': 'true'},
body={
"payload": {"key6": "xxx"},
"points": [1],
"key": None,
}
)
assert response.ok
response = request_with_validation(
api='/collections/{collection_name}/points/{id}',
method="GET",
path_params={'collection_name': collection_name, 'id': 1},
)
assert response.ok
assert len(response.json()['result']['payload']) == 5
assert response.json()['result']['payload']['key6'] == "xxx"
# set property of payload with top level
response = request_with_validation(
api='/collections/{collection_name}/points/payload',
method="POST",
path_params={'collection_name': collection_name},
body={
"payload": {"key6": {"subkey": "xxx", "arraykey": [{"a1": {"a1k": "xxx"}}, {"a2": {"a2k": "xxx"}}], "subkey2": {"subkey3": "xxx"}}},
"points": [1],
}
)
assert response.ok
# set property of payload with top level key
response = request_with_validation(
api='/collections/{collection_name}/points/payload',
method="POST",
path_params={'collection_name': collection_name},
body={
"payload": {"subkey": "yyy"},
"points": [1],
"key": "key6",
}
)
assert response.ok
response = request_with_validation(
api='/collections/{collection_name}/points/{id}',
method="GET",
path_params={'collection_name': collection_name, 'id': 1},
)
assert response.ok
assert len(response.json()['result']['payload']) == 5
assert response.json()['result']['payload']["key6"]["subkey"] == "yyy"
# set property of payload with nested key
response = request_with_validation(
api='/collections/{collection_name}/points/payload',
method="POST",
path_params={'collection_name': collection_name},
body={
"payload": {"subkey3": "yyy"},
"points": [1],
"key": "key6.subkey2",
}
)
assert response.ok
response = request_with_validation(
api='/collections/{collection_name}/points/{id}',
method="GET",
path_params={'collection_name': collection_name, 'id': 1},
)
assert response.ok
assert len(response.json()['result']['payload']) == 5
assert response.json()['result']['payload']["key6"]["subkey2"]["subkey3"] == "yyy"
# set property of payload with array index
response = request_with_validation(
api='/collections/{collection_name}/points/payload',
method="POST",
path_params={'collection_name': collection_name},
body={
"payload": {"a1k": "yyy"},
"points": [1],
"key": "key6.arraykey[0].a1",
}
)
assert response.ok
response = request_with_validation(
api='/collections/{collection_name}/points/{id}',
method="GET",
path_params={'collection_name': collection_name, 'id': 1},
)
assert response.ok
assert len(response.json()['result']['payload']) == 5
assert response.json()['result']['payload']["key6"]["arraykey"][0]["a1"]["a1k"] == "yyy"
# set property of payload with array full index
response = request_with_validation(
api='/collections/{collection_name}/points/payload',
method="POST",
path_params={'collection_name': collection_name},
body={
"payload": {"a2k": "yyy"},
"points": [1],
"key": "key6.arraykey[].a2",
}
)
assert response.ok
response = request_with_validation(
api='/collections/{collection_name}/points/{id}',
method="GET",
path_params={'collection_name': collection_name, 'id': 1},
)
assert response.ok
assert len(response.json()['result']['payload']) == 5
assert response.json()['result']['payload']["key6"]["arraykey"][1]["a2"]["a2k"] == "yyy"
# set property of payload with not exists key
response = request_with_validation(
api='/collections/{collection_name}/points/payload',
method="POST",
path_params={'collection_name': collection_name},
body={
"payload": {"key": "xxx"},
"points": [1],
"key": "key6.subkey7",
}
)
assert response.ok
response = request_with_validation(
api='/collections/{collection_name}/points/{id}',
method="GET",
path_params={'collection_name': collection_name, 'id': 1},
)
assert response.ok
assert len(response.json()['result']['payload']) == 5
assert response.json()['result']['payload']["key6"]["subkey7"]["key"] == "xxx"
# Idempotence test.
response = request_with_validation(
api='/collections/{collection_name}/points/payload',
method="POST",
path_params={'collection_name': collection_name},
query_params={'wait': 'true'},
body={
"payload": {"key": "xxx"},
"points": [9],
"key": "key",
}
)
assert response.ok
response = request_with_validation(
api='/collections/{collection_name}/points/{id}',
method="GET",
path_params={'collection_name': collection_name, 'id': 9},
)
assert response.ok
assert len(response.json()['result']['payload']) == 1
assert response.json()['result']['payload']["key"] == {"key": "xxx"}
response = request_with_validation(
api='/collections/{collection_name}/points/payload',
method="POST",
path_params={'collection_name': collection_name},
query_params={'wait': 'true'},
body={
"payload": {"key": "xxx"},
"points": [9],
"key": "key",
}
)
assert response.ok
response = request_with_validation(
api='/collections/{collection_name}/points/{id}',
method="GET",
path_params={'collection_name': collection_name, 'id': 9},
)
assert response.ok
assert len(response.json()['result']['payload']) == 1
assert response.json()['result']['payload']["key"] == {"key": "xxx"}
response = request_with_validation(
api='/collections/{collection_name}/points/payload/delete',
method="POST",
path_params={'collection_name': collection_name},
body={
"keys": ["key5"],
"filter": {
"must": [
{
"key": "key5",
"match": {
"value": "bbb"
}
}
]
}
}
)
assert response.ok
response = request_with_validation(
api='/collections/{collection_name}/points/scroll',
method="POST",
path_params={'collection_name': collection_name},
body={
"filter": {
"must": [
{
"key": "key5",
"match": {
"value": "bbb"
}
}
]
}
}
)
assert response.ok
assert len(response.json()['result']['points']) == 0
def test_payload_index_overwrite(collection_name):
drop_collection(collection_name)
response = request_with_validation(
api="/collections/{collection_name}",
method="PUT",
path_params={"collection_name": collection_name},
body={
"vectors": {
"size": 4,
"distance": "Dot",
},
},
)
assert response.ok
for field in ["a.x", "a.y", "b", "nested.a.x", "nested.a.y", "nested.b"]:
response = request_with_validation(
api="/collections/{collection_name}/index",
method="PUT",
path_params={"collection_name": collection_name},
query_params={"wait": "true"},
body={
"field_name": field,
"field_schema": "integer",
},
)
assert response.ok
response = request_with_validation(
api="/collections/{collection_name}/points",
method="PUT",
path_params={"collection_name": collection_name},
query_params={"wait": "true"},
body={
"points": [
{
"id": 1,
"vector": [1, 2, 3, 4],
"payload": {
"a": {"x": 1},
"b": 1,
"nested": {
"a": {"x": 1},
"b": 1,
},
},
},
]
},
)
assert response.ok
response = request_with_validation(
api="/collections/{collection_name}/points/payload",
method="POST",
path_params={"collection_name": collection_name},
body={
"payload": {"a": {"y": 1}},
"points": [1],
},
)
assert response.ok
response = request_with_validation(
api="/collections/{collection_name}/points/scroll",
method="POST",
path_params={"collection_name": collection_name},
body={
"with_payload": True,
"filter": {"must": [{"key": "a.x", "match": {"value": 1}}]},
},
)
assert response.ok
assert len(response.json()["result"]["points"]) == 0
response = request_with_validation(
api="/collections/{collection_name}/points/scroll",
method="POST",
path_params={"collection_name": collection_name},
body={
"with_payload": True,
"filter": {"must": [{"key": "a.y", "match": {"value": 1}}]},
},
)
assert response.ok
assert len(response.json()["result"]["points"]) == 1
response = request_with_validation(
api="/collections/{collection_name}/points/payload",
method="POST",
path_params={"collection_name": collection_name},
body={
"payload": {"a": {"y": 1}},
"points": [1],
"key": "nested",
},
)
assert response.ok
response = request_with_validation(
api="/collections/{collection_name}/points/scroll",
method="POST",
path_params={"collection_name": collection_name},
body={
"with_payload": True,
"filter": {"must": [{"key": "nested.a.x", "match": {"value": 1}}]},
},
)
assert response.ok
assert len(response.json()["result"]["points"]) == 0
response = request_with_validation(
api="/collections/{collection_name}/points/scroll",
method="POST",
path_params={"collection_name": collection_name},
body={
"with_payload": True,
"filter": {"must": [{"key": "nested.a.y", "match": {"value": 1}}]},
},
)
assert response.ok
assert len(response.json()["result"]["points"]) == 1