Version: 1.0.0
Git ref: refs/tags/1.0.0
Build Date: 2025-04-03T20:35
PIP Package: chroma-1.0.0.tar.gz
Github Container Registry Image: :1.0.0
DockerHub Image: :1.0.0
What's Changed
- [ENH] Add tracing to intermediate methods between sysdb and fastapi. by @rescrv in #3487
- [ENH] Improve the grpc used to contact knn. by @rescrv in #3490
- [ENH] Increase Sysdb GRPC max concurrent stream by @Sicheng-Pan in #3491
- [RELEASE] JS-Client 1.10.3 by @itaismith in #3488
- [ENH] Add node name to memberlist by @HammadB in #3450
- [ENH] Use node name for routing by @HammadB in #3452
- [BUG]:
BlockManager::cached()
should not always return true by @codetheweb in #3480 - [ENH] Round robin grpc connections amongst N query nodes by @HammadB in #3454
- [BUG]: fix binary search impl of
LimitOperator
by @codetheweb in #3489 - [ENH] Move sysdb client into its own crate + background poller for GC by @sanketkedia in #3492
- [ENH] Add num_records_last_compaction to sysdb by @drewkim in #3463
- [ENH] Update compactor to flush total records upon compaction by @drewkim in #3483
- [ENH] Update DBConfig to take read address by @drewkim in #3499
- [BUG] fix bad OpenAPI docs by @tazarov in #3500
- [ENH] Add collection_id param to QuotaEnforcer enforce func by @drewkim in #3497
- [BUG]: Removing numpy pinning from python client by @tazarov in #3495
- [ENH] GetCollectionSize on SysDB read replica by @drewkim in #3503
- [ENH] Update Python SysDB to support get_collection_size by @drewkim in #3507
- [DOC] Update docs getting started links for hosted waitlist by @itaismith in #3511
- [DOC] Fix install command in Getting Started doc: Replace 'yarn/pnpm install' with 'yarn/pnpm add' by @Rezve in #3506
- [ENH]: Switching to official Ollama python client by @tazarov in #2946
- [ENH]: fix typings on JS client by @codetheweb in #3501
- [ENH] RoundRobin across tiny-stories data sets. by @rescrv in #3519
- [ENH] Implement Get collections to GC + add to rust sysdb client by @sanketkedia in #3508
- [ENH] Implement compactor server interface by @Sicheng-Pan in #3375
- [ENH] Handle one-off compaction message in compaction manager by @Sicheng-Pan in #3379
- [ENH] Implement compaction client by @Sicheng-Pan in #3465
- [ENH]: fix dynamic span names in Jaeger by @codetheweb in #3517
- [RELEASE] JS-Client 1.10.4 by @codetheweb in #3532
- [BLD]: allow manual dispatch of JS release workflow by @codetheweb in #3536
- [ENH] Add collection_id to quota_enforcer calls by @drewkim in #3537
- [ENH] Create VersionFiles in S3 from Sysdb. GI#822 by @rohitcpbot in #3475
- [CLN] Move segment module out of worker crate by @Sicheng-Pan in #3538
- [CLN] Deprecate segment module in worker crate by @Sicheng-Pan in #3540
- [DOC] Making git clone command more accessible in Docker container instructions by @tazarov in #3513
- [ENH]: Switching Ollama JS EF to ollama js client by @tazarov in #2948
- [ENH] GC orchestrator + Fetch version file operator by @sanketkedia in #3544
- [TST] Add test coverage for compaction that deletes everything by @HammadB in #3543
- [ENH] Add rust frontend stub by @HammadB in #3549
- [BUG]: keep track of current span if task must be queued by @codetheweb in #3548
- [PERF] prefetch blocks for fulltext index writer by @codetheweb in #3370
- [ENH] Bump helm chart for rust fe by @HammadB in #3554
- [CLN] Move log module outside of worker crate by @Sicheng-Pan in #3547
- [CLN] Move memberlist and assignment module out of worker crate by @Sicheng-Pan in #3552
- [ENH] Implement multiple member assignment by @Sicheng-Pan in #3553
- [BUG]: FastAPI operations id are now unique by @tazarov in #3522
- [ENH] Add basic rust bindings stub by @HammadB in #3557
- [ENH] Create database flow e2e by @sanketkedia in #3558
- [ENH] Define query operators and plan in rust types by @Sicheng-Pan in #3559
- [ENH] Get database e2e by @sanketkedia in #3563
- [ENH] Rust mypy stubs for precommit by @HammadB in #3564
- [BUG] Fix failing JS CI due to ollama import by @tazarov in #3555
- [ENH] Balance gRPC channels by @HammadB in #3568
- [ENH] Serialize Where clause to protobuf by @Sicheng-Pan in #3565
- [ENH] Serialize/Deserialize query plan to/from ProtoBuf by @Sicheng-Pan in #3569
- [BUG] Clean up delete_segments. by @rohitcpbot in #3570
- [ENH] Add GRPCs in SysDB to help with garbage collection by @rohitcpbot in #3539
- [ENH] Rust<>Python proxy calls back into python by @HammadB in #3571
- [BLD]: test Rust stub bindings in CI by @codetheweb in #3561
- [ENH] Implement distributed executor for Rust frontend by @Sicheng-Pan in #3572
- [ENH] Implement SysDB get_collection_with_segments endpoint by @Sicheng-Pan in #3574
- [ENH] Add query route by @sanketkedia in #3573
- [ENH] Update rust ml with extra fields by @HammadB in #3583
- [ENH] Multi-dimensional admission control. by @rescrv in #3579
- [ENH] LIFO->FIFO for the dispatcher. by @rescrv in #3584
- [ENH] Metrics for circuit breaker in mdac. by @rescrv in #3581
- [ENH]: better error handlilng for Axum routes by @codetheweb in #3585
- [ENH] Add parsers by @sanketkedia in #3582
- [ENH] Add cache for FE with no invalidation by @sanketkedia in #3587
- [CLN]: split up log impls into separate files by @codetheweb in #3575
- [ENH] Frontend tracing. by @rescrv in #3586
- [ENH] More endpoints on rust frontend by @Sicheng-Pan in #3589
- [ENH]: add
push_logs()
to log interface by @codetheweb in #3576 - [ENH]: add
/add
route to Rust frontend by @codetheweb in #3590 - [ENH] Update rust ml with extra fields by @HammadB in #3594
- [ENH] Plumb ML into fe by @HammadB in #3595
- [BUG] Fix recursion in auth_and_get_tenant_and_database_for_request by @tazarov in #3514
- [ENH] Implement read endpoints for collection by @Sicheng-Pan in #3603
- [ENH] Wire up config to scorecard with default rules by @rescrv in #3600
- [ENH]: add route-level tracing to Rust frontend by @codetheweb in #3605
- [CLN]: split where parsing into new file by @codetheweb in #3592
- [TST]: add basic tests for where parsing by @codetheweb in #3593
- [CLN]: derive Deserialization for get and query payloads by @codetheweb in #3610
- [ENH] Partitioned mutex + hnsw load uses this mutex by @sanketkedia in #3607
- [ENH] Dedup get_collections_with_segments sysdb rpc by @sanketkedia in #3612
- [ENH] More routes in rust FE by @Sicheng-Pan in #3609
- [ENH] Bound the number of enqueued tasks in executor by aborting any task above the limit. by @rescrv in #3604
- [ENH] FE<>Query retries load balance by @HammadB in #3615
- [ENH]: support collection updates on Rust frontend by @codetheweb in #3613
- [CLN] Add traces and minor cleanups by @Sicheng-Pan in #3619
- [ENH]: add /upsert & /update to Rust frontend by @codetheweb in #3608
- [ENH] Nop cache for FE + Rwlock for memberlist by @sanketkedia in #3618
- [ENH]: add /delete to Rust frontend by @codetheweb in #3611
- [BUG] Fix Figment-based tests. by @rescrv in #3620
- [BUG] Building and running tests builds twice. by @rescrv in #3621
- [ENH]: support collection creation and deletion on Rust frontend by @codetheweb in #3617
- [BUG] Fix missing config default by @HammadB in #3623
- [ENH] Bump load to new rust client by @rescrv in #3630
- [ENH]: hook up /reset for Rust frontend by @codetheweb in #3627
- [ENH] Implement validators for Rust FE by @Sicheng-Pan in #3624
- [TST]: run tests against Rust frontend by @codetheweb in #3622
- [ENH]: fixes for creating collections through the Rust frontend by @codetheweb in #3628
- [ENH]: fix tracing path for query service from Rust frontend by @codetheweb in #3631
- [PERF] Use dimension cache in rust front by @HammadB in #3634
- [DOC] Update embedding-functions.md by @rohitcpbot in #3633
- [ENH] Add cache invalidation by @sanketkedia in #3625
- [ENH] Bump chroma-load dep on client to avoid connection pooling and be open loop by @rescrv in #3641
- [ENH]: better Rust gRPC client tracing by @codetheweb in #3640
- [ENH] Misc cleanup for Rust FE by @Sicheng-Pan in #3642
- [CHORE] remove sensitive/big field from frontend log. by @rescrv in #3639
- [ENH] Invalidate collection cache appropriately by @sanketkedia in #3645
- [TST]: Rust frontend fixes for test_sanity by @codetheweb in #3643
- [TST]: fix Rust frontend for test_logservice.py by @codetheweb in #3648
- [BUG] Fixes for test_filtering by @sanketkedia in #3652
- [ENH] Add failure and latency to chroma-load by @rescrv in #3650
- [BUG] Set old ML in ml processor by @HammadB in #3654
- [BUG] Match Rust FE error types with python client by @Sicheng-Pan in #3655
- [CLN] Cleanup Ruet FE error types by @Sicheng-Pan in #3659
- [BUG] Fix hang in ml by @HammadB in #3658
- [ENH] Rust Sqlite migrations by @HammadB in #3599
- [ENH] Rust sqlite sysdb scaffold by @HammadB in #3663
- [ENH] Bound the IO queue to some number of active tasks by @rescrv in #3606
- [ENH]: add ready probe to Rust frontend by @codetheweb in #3657
- [ENH]: add/upsert/update Vecs should take optional elements by @codetheweb in #3649
- [ENH]: suppress prefetch errors when the sender no longer exists by @codetheweb in #3664
- [TST]: fixes for test_add.py against Rust frontend by @codetheweb in #3653
- [BUG] Using
export
instead ofexport type
for CommonJS compat by @tazarov in #3666 - [BLD]: always run Rust frontend tests by @codetheweb in #3667
- [ENH] Move scorecard from frontend to server. by @rescrv in #3665
- [ENH] Add OTEL metrics to frontend. by @rescrv in #3672
- [ENH]: panic during splitting when keys are unordered by @codetheweb in #3677
- [ENH] Implement sqlite metadata segment reader by @Sicheng-Pan in #3668
- [ENH] Implement local executor by @Sicheng-Pan in #3678
- [DOC] document the active_io_tasks spin loop by @rescrv in #3674
- [ENH] Make our config push-safe. by @rescrv in #3629
- [CHORE] Fix broken main. by @rescrv in #3682
- [ENH] Add a single qps counter to chroma-load. by @rescrv in #3675
- [TST]: add proptest Arbitrary impl for OperationRecord and UpdateMetadata by @codetheweb in #3669
- [ENH]: add Rust SQLite impl of log by @codetheweb in #3577
- [ENH] Add all config to wire up sysdb in bindings by @HammadB in #3683
- [BUG] If ssl is set, we overwrite headers. by @rescrv in #3685
- [ENH] Allow reference work loads. by @rescrv in #3681
- [ENH] Improve the interactive pages for chroma-load to make them more readable. by @rescrv in #3691
- [ENH] GC - compute versions and mark for deletion. by @rohitcpbot in #3597
- [ENH] Local hnsw segment reader and writer by @sanketkedia in #3689
- [ENH] FD pool + Local segment manager by @sanketkedia in #3693
- [ENH] Basic compaction manager scaffold by @sanketkedia in #3696
- [ENH] The otel metrics for chroma-load (no longer)show up as unknown-dataset. by @rescrv in #3697
- [ENH] Implement metadata segment writer by @Sicheng-Pan in #3686
- [ENH] Implement reference segment by @Sicheng-Pan in #3698
- Enhanced reader + writer by @sanketkedia in #3700
- [ENH] Add env overrides to rust-frontend-service chart. by @rescrv in #3699
- [ENH] Python bindings for add() call by @HammadB in #3692
- [ENH] Local compaction manager apply logs by @sanketkedia in #3702
- [ENH] Setup log in bindings by @HammadB in #3704
- [ENH] Start compactor component by @sanketkedia in #3703
- [ENH] Implement get embedding for local hnsw reader by @Sicheng-Pan in #3701
- [ENH] Implement query for local executor by @Sicheng-Pan in #3705
- [ENH] call compactor in the write path by @sanketkedia in #3708
- [ENH] Rust bindings where clause parsing by @HammadB in #3709
- [ENH]: error helpers & common WrappedSqlxError type by @codetheweb in #3706
- [ENH]: put metadata update logic in shared helpers by @codetheweb in #3707
- [ENH]: add Rust SQLite impls for database and tenant methods by @codetheweb in #3694
- [ENH]: add Rust SQLite impls for collection create and get by @codetheweb in #3695
- [ENH]: add Rust sysdb impl for get_collection_with_segments() by @codetheweb in #3710
- [ENH] Add support to chroma-load for custom data sets. by @rescrv in #3712
- [ENH] chroma-load runs load workloads. by @rescrv in #3716
- [BUG] Misc bug fixes for local Rust impl by @Sicheng-Pan in #3717
- [ENH]: add update_collection() SQLite impl for Rust frontend by @codetheweb in #3713
- [PERF] Rust local impl query filter bypass by @Sicheng-Pan in #3718
- [ENH]: unified frontend request validation by @codetheweb in #3720
- [ENH]: add Rust SQLite impl of delete_collection() and get_segments() by @codetheweb in #3714
- [ENH] Parse where clause across ffi as json, Add GetResponse by @HammadB in #3722
- [TST] Proptest for get and count by @Sicheng-Pan in #3724
- [ENH] wire up query by @HammadB in #3726
- [PERF] Override cache size limit from config by @Sicheng-Pan in #3727
- [ENH] Backfill segments from log by @sanketkedia in #3725
- [ENH][HACK] Add a cache for zipf distributions to chroma load. by @rescrv in #3721
- [BUG] Misc bug fix for Rust impl by @Sicheng-Pan in #3734
- [DOC] Adding updates section by @itaismith in #3505
- [ENH]: add error handling for Rust -> Python bindings & hook up create_collection() by @codetheweb in #3715
- [ENH]: hook up database and tenant methods to Rust bindings by @codetheweb in #3738
- [ENH] Log gc by @sanketkedia in #3728
- [BUG] Misc bug fixes for Rust impl by @Sicheng-Pan in #3736
- [ENH]: use Rust SQLite impl for collection methods in bindings by @codetheweb in #3739
- [ENH]: connect reset() to Rust bindings by @codetheweb in #3740
- [BUG] Misc bug fixes for Rust impl by @Sicheng-Pan in #3742
- [ENH]: hook up
get_version()
to Rust bindings by @codetheweb in #3741 - [ENH]: impl component start/stop for Rust bindings by @codetheweb in #3743
- [ENH]: hook up collection.modify() to Rust bindings by @codetheweb in #3745
- [TST] Test local rust impl by @Sicheng-Pan in #3744
- [BUG] Check both int and float value for numerical filter by @Sicheng-Pan in #3748
- [CLN] Deprecate v1 api by @HammadB in #3751
- [TST] Implement prop test for where by @Sicheng-Pan in #3754
- [TST] Add tests for numpy input types by @HammadB in #3753
- [BUG] Fix JS tests by @Sicheng-Pan in #3756
- [CHORE] Update tantivy so hosted-chroma doesn't have conflicting zstd versions. by @rescrv in #3752
- [CHORE] Tonic should always be enabled. by @rescrv in #3757
- [BUG]: Delete collection resource leak (single-node Chroma) by @tazarov in #3297
- [ENH] Add frontend auth support to rust frontend. by @rescrv in #3750
- [ENH] Adding initial Rust CLI by @itaismith in #3761
- [ENH] Implement ephemeral Rust Client by @Sicheng-Pan in #3759
- [DOC] Add client for R to the documentation by @christophsax in #3760
- [ENH] Use registry everywhere by @HammadB in #3763
- Update introduction.md by @garbles in #3768
- [ENH] Add default single node config and add to CLI by @HammadB in #3767
- [ENH]: add seq ID migration to Python by @codetheweb in #3765
- [ENH] Integrate quota by @sanketkedia in #3771
- [ENH] Revised quota enforcer trait by @sanketkedia in #3772
- [ENH] Implement GetCollectionSize in rust sysdb client by @sanketkedia in #3773
- [BUG] Don't add + Sync to futures. Bad habit. by @rescrv in #3774
- [ENH] Per-request-type retry counters. by @rescrv in #3719
- [ENH] Add GHA for CLI release and install scripts by @itaismith in #3775
- [ENH] Plumb MAX_CONNS in from the environment for go pgxpool. by @rescrv in #3733
- [CHORE] Add every frontend variant for logging so our tracing will "just work" without RUST_LOG env var. by @rescrv in #3781
- [BUG] serveral routes were missed in the original auth code. by @rescrv in #3784
- [TST] Enable legacy tests by @Sicheng-Pan in #3764
- [BUG] Migrate max_seq_id in pickle if present by @Sicheng-Pan in #3777
- [ENH] Count collections implementation by @sanketkedia in #3785
- [BUG]: fix FTS out-of-order writing bug by @codetheweb in #3790
- [TST]: add invaariant assertions for ordered blockfile writing by @codetheweb in #3786
- [DOC] update embedding function doc referencing texts -> input by @jairad26 in #3796
- [BLD]: improve layer ordering in Rust Dockerfiles by @codetheweb in #3799
- [ENH]: push down
validate_embeddings()
into Frontend by @codetheweb in #3800 - [ENH] GC Tool - Tilt based tests. by @rohitcpbot in #3749
- [CLN] Remove spurious foyer traces by @HammadB in #3787
- [ENH] Fix type in exception message by @SiboVG in #3803
- [DOC] fix inconsistent variable names for the Python HttpClient by @mollycarroll in #3515
- [DOC] Fix minor typos by @amygori in #3598
- [TST] Enable rust single node tests by @HammadB in #3770
- [DOC] Fix another small typo by @eculver in #3471
- [ENH]: use new hnswlib crate by @codetheweb in #3782
- [ENH] update docs by @jeffchuber in #3807
- [BLD]: switch to Maturin for build, bundle Rust code with package by @codetheweb in #3766
- [TST] Enable legacy tests for ephemeral Rust impl by @Sicheng-Pan in #3789
- [ENH] Make rust cache hash deterministic by default by @HammadB in #3809
- [ENH] Optimize GetCollections by @sanketkedia in #3802
- [TST] Enable windows tests for rust impl by @Sicheng-Pan in #3808
- [ENH] Use legacy posthog impl for rust client by @Sicheng-Pan in #3816
- [TST] Test foyer cache can close file descriptor by @Sicheng-Pan in #3817
- [DOC] Add cloud docs placeholder by @itaismith in #3820
- [ENH] Go version file config should not be enabled by @HammadB in #3823
- [ENH] Add OpenAPI spec to Rust server by @philipithomas in #3815
- [DOC] DeepEval Integration by @kritinv in #3811
- [ENH] More legible quota message by @sanketkedia in #3829
- [BLD]: fix artifact path during release job by @codetheweb in #3832
- [ENH] PyO3 feature flag by @itaismith in #3776
- [DOC] add anthropic mcp docs by @jairad26 in #3824
- [BUG] Update [tool.maturin] section to add include protos. by @rohitcpbot in #3833
- [ENH] Implement meter trace layer by @Sicheng-Pan in #3821
- [BUG] Remove auto fail from CLI install script by @itaismith in #3836
- [BLD] add token to setup-protoc action to avoid rate limiting by @codetheweb in #3839
- [BLD] pin Rust version in workflows by @codetheweb in #3841
- [ENH]: add config for Rust HTTP server by @codetheweb in #3837
- [BUG] Gracefully handle merge operator task error by @Sicheng-Pan in #3844
- [ENH] Unify persist path config by @Sicheng-Pan in #3847
- [BUG] chroma-load has an oob access by @rescrv in #3846
- [ENH]: consistent config field casing, add default and debug impls by @codetheweb in #3838
- [BUG]: fix docs build issue by @codetheweb in #3850
- [ENH] Return NOT FOUND grpc err code for non-existent db in create coll. by @rohitcpbot in #3840
- [BUG] Use the returned key set, not the queried key set. by @rescrv in #3852
- [ENH]: make config field renames backwards compatible by @codetheweb in #3849
- [ENH]: publish image with Rust CLI, update sample configs by @codetheweb in #3843
- [ENH]: fix container signal handling & use Debian in published image by @codetheweb in #3854
- [ENH] Update all Chroma-provided Python embedding functions to conform to new interface by @jairad26 in #3845
- [DOC] Add cpp client by @BlackyDrum in #3857
- [ENH] Remove retry log line in RFE by @sanketkedia in #3862
- [ENH] Enable version file for Tilt only. by @rohitcpbot in #3858
- [TST]: Rust cluster tests were using wrong port by @codetheweb in #3865
- [DOC] switch from yarn to pnpm by @philipithomas in #3863
- [ENH]: add Rust server config option for CORS allowed origins by @codetheweb in #3861
- [TST] Test rust client backward compatibility by @Sicheng-Pan in #3867
- [ENH] Add in parallel to local hsnw by @HammadB in #3866
- [BUG]: pin fastapi version by @codetheweb in #3872
- [ENH]: use Rust bindings by default in Python package by @codetheweb in #3864
- [ENH]: consume and populate the embeddings_queue_config from Rust log impl by @codetheweb in #3819
- [ENH] Free the GIL by @HammadB in #3873
- [ENH]: update docs & deployment templates for Rust server by @codetheweb in #3853
- [ENH] Add schema and validation for embedding functions by @jairad26 in #3859
- [TST]: fix Hypothesis filter generation for floats by @codetheweb in #3868
- [BLD]: allow manual release of container image by @codetheweb in #3875
- [PERF]: improve insert throughput by ~20% via BufWriter by @codetheweb in #3876
- [BUG] Json schema missing from deps by @HammadB in #3877
- [RELEASE] 1.0.0b0 by @HammadB in #3878
- [DOC]: add migration guide for v1 by @codetheweb in #3874
- [DOC]: add note to migration guide about container data directory change by @codetheweb in #3880
- [CHORE] Set soft delete flag to true by default. by @rohitcpbot in #3401
- [ENH] Garbage Collection property tests. by @rohitcpbot in #3881
- [ENH] Intercept GRPC status code by @Sicheng-Pan in #3884
- [BUG] Remove new EmbeddingFunction interface & modify existing interface by @jairad26 in #3885
- [ENH] Update meter event definition by @Sicheng-Pan in #3888
- [ENH] In JS frontends, fall back to hosted chroma package instead of third-party package by @philipithomas in #3890
- [ENH] Add traces to debug compactor issue by @sanketkedia in #3896
- [ENH]: update JS EFs to conform to new interface by @codetheweb in #3894
- [ENH] Wal3 README.md that outlines the design. by @rescrv in #3889
- [BUG] revert ollama import by @jairad26 in #3900
- [ENH] Replace global event sender channel with
ReceiverForMessage<MeterEvent>
by @Sicheng-Pan in #3898 - [ENH] Support if-not-exists and if-match for putting objects to S3. by @rescrv in #3904
- [ENH] Add size_bytes_post_compaction and last_compaction_time_secs to SysDB collection by @drewkim in #3886
- [CLN] Remove meter init in frontend startup by @Sicheng-Pan in #3905
- [ENH] Basic types for wal3 with documentation. by @rescrv in #3891
- [ENH] Allow passing system and registry into FE entrypoint by @HammadB in #3908
- [ENH] Implement graceful shutdown for component and axum server by @Sicheng-Pan in #3910
- [CHORE] Remove frontend env config from rust frontend env config by @eculver in #3913
- [ENH] Make PutOptions part of the storage API. by @rescrv in #3912
- [BUG] Fixes for dockerfile, tilt, config management by @HammadB in #3919
- [ENH] Service account for rust frontend service by @HammadB in #3922
- [BLD]: only publish Helm chart on pushes to main by @codetheweb in #3923
- [ENH] Bind service account to RFE by @HammadB in #3924
- [ENH] Add quota overrage details in the error string by @sanketkedia in #3925
- [BUG] Need podwatcher role on rust-fe by @HammadB in #3926
- [BUG]: empty list of IDs on query should return nothing by @codetheweb in #3918
- [ENH] CLI - python and js distribution and other improvements by @itaismith in #3842
- Revert "[ENH] CLI - python and js distribution and other improvements" by @itaismith in #3935
- [ENH] Update test runner to ubunto-latest and rename cli crate by @itaismith in #3938
- [ENH] Update runners for all python tests by @itaismith in #3939
- [ENH] Migrations for sysdb, needed for GC. GHI #1527 by @rohitcpbot in #3933
- [ENH] SPANN: Add rust integrity tests by @sanketkedia in #3929
- [ENH] Rust Log Service Stub by @HammadB in #3934
- [ENH] Bundle CLI in python chromadb by @itaismith in #3940
- Revert "[ENH] Bundle CLI in python chromadb" by @itaismith in #3951
- [BUG]: return correct tenant class in Python from Rust bindings by @codetheweb in #3952
- [ENH]: default content-type to application/json if not provided by @codetheweb in #3954
- [ENH] Refactor clients/js to a multi-package by @philipithomas in #3903
- [ENH] Bump js package version to test deploys by @philipithomas in #3957
- [ENH] Spann works e2e on local tilt by @sanketkedia in #3944
- [BUG] Fix rust status code by @Sicheng-Pan in #3956
- [TST]: use Depot runners in Python/Rust tests by @codetheweb in #3958
- [CHORE] move embedding function schemas to higher level by @jairad26 in #3959
- [ENH] SPANN: Resize Hnsw appropriately by @sanketkedia in #3962
- [ENH] Add BillingLimitExceeded error and NumDatabases quota rule by @drewkim in #3960
- [ENH] Generic quota error by @drewkim in #3966
- [ENH] Add test sysdb impls for a few methods by @sanketkedia in #3871
- [ENH] Have one error type for Storage. by @rescrv in #3914
- [CHORE] improve CI tests to run subset when only js or go changes are made by @jairad26 in #3964
- [BUG] fix test to mock sentence transformer to stop pull from huggingface by @jairad26 in #3968
- [ENH] Return the ETag for a successful PUT. by @rescrv in #3915
- [ENH] Add manifest and snapshot types. by @rescrv in #3893
- [BUG]: supress not found error on temporary HNSW file removal by @codetheweb in #3969
- [ENH] Add log bytes pulled as part of query result by @Sicheng-Pan in #3972
- [ENH] add JS client embedding function schema validation by @jairad26 in #3963
- [ENH] Flesh out the skeleton for the write path. by @rescrv in #3909
- [ENH] Add the number of bytes written to the log to the manifest. by @rescrv in #3930
- [ENH] Non-caching reader for wal3. by @rescrv in #3931
- [BUG]: correctly handle replays on local HNSW writer by @codetheweb in #3936
- [ENH] GC deletion mode. by @rohitcpbot in #3946
- [TST] A test for the manager in wal3. by @rescrv in #3932
- [BUG] Update CLI install script to version 1.0.0 by @jasonvigil in #3973
- [BUG] Add helm tool requirement for local dev by @jasonvigil in #3981
- [ENH] Add list_databases to TestSysDB by @drewkim in #3976
- [ENH] Refactor CLI by command by @itaismith in #3977
- [ENH] Support batching for wal3. by @rescrv in #3955
- [ENH] Remove timestamp_us from wal3 LogPosition. by @rescrv in #3980
- [ENH]: don't throw error in Python client for unknown field in collection response by @codetheweb in #3989
- [ENH]: add user-agent header to clients by @codetheweb in #3988
- [ENH] Bundle CLI in python package by @itaismith in #3986
- [TST] Clean up tests in a post-rust chroma world by @HammadB in #3990
- [TST] Use depot builds for tilt ci by @HammadB in #3995
- [ENH] Upgrade Foyer + Foyer config fix by @sanketkedia in #3985
- [ENH] Unify images by @HammadB in #3997
- [ENH] CLI vacuum command by @itaismith in #3991
- [ENH]: bump the max response payload size limit for query service clients by @codetheweb in #3975
- [ENH] Update OpenAPI spec for new endpoints by @philipithomas in #4003
- [ENH] Pretty print trace in stdout by @Sicheng-Pan in #4005
- [ENH]: add readiness probes to all services by @codetheweb in #4006
- [ENH] Spann: remove duplicates + not prune in query by @sanketkedia in #4009
- [DOC] Add ask ai button by @itaismith in #4004
- [ENH] GC - Fix the extra fetch of sparse index file by @rohitcpbot in #3953
- [ENH] Make SysDb return eligible collections to GC. by @rohitcpbot in #3916
- [CLN] Cleanup some prints by @HammadB in #4012
- [ENH] Update metering event by @Sicheng-Pan in #3982
- [ENH] Spann: config for GC policy + introduce spann provider + implement GC policy by @sanketkedia in #3999
- [ENH]: better axum errors by @codetheweb in #4007
- [CHORE] rename inner_product to IP & remove error raise on legacy embedding functions by @jairad26 in #4017
- [ENH] HNSW Garbage Collection by @sanketkedia in #4014
- [ENH] Handle empty PL during GC by @sanketkedia in #4022
- [ENH] docs visual improvements by @jeffchuber in #4021
- [BUG] bump to make vercel build run by @jeffchuber in #4026
- [TST]: fix stack overflow in test_blockfile_shuttle by @codetheweb in #3927
- [TST]: enable Rust backtraces in Tilt services by @codetheweb in #4029
- [CLN] Some large traces by @HammadB in #4013
- [ENH] chroma-load potpourri by @rescrv in #4034
- [TST] mock all embedding functions in prop tests by @jairad26 in #4047
- [BUG] don't write to disk cache by @codetheweb in #4032
- [TST]: enable "normal" property testing preset in PRs by @codetheweb in #4031
- [TST] Run benchmark in CI by @Sicheng-Pan in #4046
- Fix Docker image name in server startup command by @abrahammathews2000 in #4043
- [ENH]: rename DistributedSpannParameters -> SpannConfiguration by @codetheweb in #3983
- [TST] remove conftest installs and simplify ef tests by @jairad26 in #4054
- [ENH]: add Default impl for Collection type by @codetheweb in #3984
- [TST] Fix hnsw degradation for small test cases by @HammadB in #4025
- [ENH]: consume config from collection config field in Rust by @codetheweb in #3961
- [BUG]: Correctly set trace id for debugging using honeycomb by @sanketkedia in #4055
- [ENH]: increase SQLite busy timeout by @codetheweb in #4060
- [ENH]: Remove spann min param validations by @sanketkedia in #4064
- [CLN] Revise component method naming by @Sicheng-Pan in #4063
- [ENH] Calculate and update collection logical size during compaction by @Sicheng-Pan in #4019
- Revert "[ENH] Calculate and update collection logical size during compaction" by @Sicheng-Pan in #4070
- [ENH]: improve interface for
load_blocks_for_keys()
by @codetheweb in #3534 - [ENH] Calculate and update collection logical size during compaction by @Sicheng-Pan in #4071
- [ENH] CLI Profile and DB management by @itaismith in #4056
- [DOC] fixed image name typo by @me-tusharchandra in #4069
- [BLD]: report test results to Datadog by @codetheweb in #4075
- [ENH] Add client collection config changes by @jairad26 in #4027
- [ENH] Regenerate JS client library from Chroma 1.0.0 openapi spec - @chromadb and @chromadb-client v2.1.0 by @philipithomas in #3967
- [ENH]: write to Foyer disk cache at insert time, fix host path binding for cache volumes in CI by @codetheweb in #4079
- [ENH] State machine based property tests for GC. by @rohitcpbot in #4057
- [ENH] add update collection config by @jairad26 in #4028
- [BLD]: add
rust-toolchain.toml
, call rustup directly in CI by @codetheweb in #4053 - [ENH]: add in-memory frontend impl by @codetheweb in #3902
- [ENH]: Rust frontend proptest for collection operations against SQLite impl by @codetheweb in #3814
- [BUG] Handle request to root in RFE server by @Sicheng-Pan in #4091
- [ENH] CLI login command by @itaismith in #4082
- [ENH] CLI - Update command updated by @itaismith in #4093
- [ENH] Add tenant to SysDB collections table by @drewkim in #4094
- [BUG] Pass down ef_search from collection config to hnsw load by @sanketkedia in #4097
- [CHORE] Allow generic embedding function for type safety, make Space literal by @jairad26 in #4090
- [ENH] Wire up remaining meter attributes by @Sicheng-Pan in #4052
- [ENH] Include enum -> list of literals for type safety by @jairad26 in #4098
- [TST] Start of tests for wal3. by @rescrv in #3949
- [ENH] Wire up the push_logs call to the new log service. by @rescrv in #3971
- [ENH] Every wal3 fragment can optionally mark itself dirty. by @rescrv in #4030
- [CLN]: remove Python tests for unused impls by @codetheweb in #4035
- [ENH] Wal3 scrub tool and feature. by @rescrv in #4065
- [CHORE] Add service account for rust log service by @HammadB in #4106
- [ENH] Spann miscellanous fixes by @sanketkedia in #4108
- [ENH]: stop/kill worker threads when dispatcher is stopped by @codetheweb in #4102
- [BUG] Fix query/compaction sset definitions by @jasonvigil in #4110
- [BUG]: fix metadata key delete bug in test segment by @codetheweb in #4112
- [CHORE] Revert list collections to return collection object by @jairad26 in #4103
- [DOC] add logical operation section in fts docs by @jairad26 in #4111
- [ENH] Delete version files in GC. by @rohitcpbot in #4068
- [ENH] Add GC service to Tilt. by @rohitcpbot in #4067
- [ENH]:
DeleteVersionsAtSysDbOperator
should only delete files marked for deletion by @codetheweb in #4120 - [BUG]: SysDb should update
TotalRecordsPostCompaction
andSizeBytesPostCompaction
when flushing with GC enabled by @codetheweb in #4131 - [BUG] Fix import openai error caused by bundling Node-native modules in noExternal by @philipithomas in #4133
- [ENH] Add tracing instrumentation to spann fetch PL operator by @sanketkedia in #4139
- [ENH] Record insertion time/count for wal3 dirty log. by @rescrv in #4050
- [ENH] wal3 cursor store by @rescrv in #4051
- [BUG] Fix metrics counting for get_user_identity by @jasonvigil in #4137
- [RELEASE] 1.0.0 by @itaismith in #4143
New Contributors
- @Rezve made their first contribution in #3506
- @christophsax made their first contribution in #3760
- @garbles made their first contribution in #3768
- @jairad26 made their first contribution in #3796
- @SiboVG made their first contribution in #3803
- @mollycarroll made their first contribution in #3515
- @amygori made their first contribution in #3598
- @philipithomas made their first contribution in #3815
- @kritinv made their first contribution in #3811
- @BlackyDrum made their first contribution in #3857
- @jasonvigil made their first contribution in #3973
- @abrahammathews2000 made their first contribution in #4043
- @me-tusharchandra made their first contribution in #4069
Full Changelog: 0.6.3...1.0.0