-
Notifications
You must be signed in to change notification settings - Fork 1.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Loading status checks…
[ENH] cluster sanity test (#2087)
- latest
- js_release_1.10.3
- js_release_1.10.2
- js_release_1.10.0
- js_release_1.9.4
- js_release_1.9.3
- js_release_1.9.2
- js_release_1.9.1
- js_release_alpha_1.9.1
- 0.6.3
- 0.6.2
- 0.6.1
- 0.6.0
- 0.5.23
- 0.5.21
- 0.5.20
- 0.5.19
- 0.5.18
- 0.5.17
- 0.5.16
- 0.5.15
- 0.5.14
- 0.5.13
- 0.5.12
- 0.5.11
- 0.5.10
- 0.5.9
- 0.5.7
- 0.5.6
- 0.5.5
- 0.5.4
- 0.5.3
- 0.5.2
- 0.5.1
Showing
7 changed files
with
75 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
# This folder holds basic sanity checks for the distributed version of chromadb | ||
# while it is in development. In the future, it may hold more extensive tests | ||
# in tandem with the main test suite, targeted at the distributed version. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
# This tests a very minimal of test_add in test_add.py as a example based test | ||
# instead of a property based test. We can use the delta to get the property | ||
# test working and then enable | ||
import random | ||
from chromadb.api import ServerAPI | ||
import time | ||
|
||
EPS = 1e-6 | ||
SLEEP = 5 | ||
|
||
|
||
def test_add( | ||
api: ServerAPI, | ||
) -> None: | ||
api.reset() | ||
|
||
# Once we reset, we have to wait for sometime to let the memberlist on the frontends | ||
# propagate, there isn't a clean way to do this so we sleep for a configured amount of time | ||
# to ensure that the memberlist has propagated | ||
time.sleep(SLEEP) | ||
|
||
collection = api.create_collection( | ||
name="test", | ||
) | ||
|
||
# Add 1000 records, where each embedding has 3 dimensions randomly generated | ||
# between 0 and 1 | ||
ids = [] | ||
embeddings = [] | ||
for i in range(1000): | ||
ids.append(str(i)) | ||
embeddings.append([random.random(), random.random(), random.random()]) | ||
collection.add( | ||
ids=[str(i)], | ||
embeddings=[embeddings[-1]], # type: ignore | ||
) | ||
|
||
random_query = [random.random(), random.random(), random.random()] | ||
|
||
# Query the collection with a random query | ||
results = collection.query( | ||
query_embeddings=[random_query], # type: ignore | ||
n_results=10, | ||
) | ||
|
||
# Check that the distances are correct in l2 | ||
ground_truth_distances = [ | ||
sum((a - b) ** 2 for a, b in zip(embedding, random_query)) | ||
for embedding in embeddings | ||
] | ||
ground_truth_distances.sort() | ||
retrieved_distances = results["distances"][0] # type: ignore | ||
|
||
# Check that the query results are sorted by distance | ||
for i in range(1, len(retrieved_distances)): | ||
assert retrieved_distances[i - 1] <= retrieved_distances[i] | ||
|
||
for i in range(len(retrieved_distances)): | ||
assert abs(ground_truth_distances[i] - retrieved_distances[i]) < EPS |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters