diff --git a/chromadb/test/property/invariants.py b/chromadb/test/property/invariants.py index c731b4c3049..a7bd2c6cade 100644 --- a/chromadb/test/property/invariants.py +++ b/chromadb/test/property/invariants.py @@ -1,5 +1,6 @@ import gc import math +from time import sleep import psutil @@ -174,8 +175,17 @@ def fd_not_exceeding_threadpool_size(threadpool_size: int) -> None: """ current_process = psutil.Process() open_files = current_process.open_files() - if len([p.path for p in open_files if "sqlite3" in p.path]) - 1 <= threadpool_size: + max_retries = 5 + retry_count = 0 + # we probably don't need the below but we keep it to avoid flaky tests. + while ( + len([p.path for p in open_files if "sqlite3" in p.path]) - 1 > threadpool_size + and retry_count < max_retries + ): gc.collect() # GC to collect the orphaned TLS objects + open_files = current_process.open_files() + retry_count += 1 + sleep(1) assert ( len([p.path for p in open_files if "sqlite3" in p.path]) - 1 <= threadpool_size ) diff --git a/chromadb/test/test_multithreaded.py b/chromadb/test/test_multithreaded.py index 8673809f62a..a2d6f2e1ba5 100644 --- a/chromadb/test/test_multithreaded.py +++ b/chromadb/test/test_multithreaded.py @@ -194,7 +194,9 @@ def perform_operation( exception = future.exception() if exception is not None: raise exception - if isinstance(api, SegmentAPI): # we can't check invariants for FastAPI + if ( + isinstance(api, SegmentAPI) and api.get_settings().is_persistent is True + ): # we can't check invariants for FastAPI invariants.fd_not_exceeding_threadpool_size(num_workers) # Check that invariants hold invariants.count(coll, records_set)