mirror of
				https://github.com/meta-llama/llama-stack.git
				synced 2025-10-25 09:05:37 +00:00 
			
		
		
		
	
		
			Some checks failed
		
		
	
	Integration Auth Tests / test-matrix (oauth2_token) (push) Failing after 1s
				
			Integration Tests / test-matrix (library, 3.12, datasets) (push) Failing after 4s
				
			Integration Tests / test-matrix (library, 3.12, agents) (push) Failing after 7s
				
			Integration Tests / test-matrix (library, 3.12, scoring) (push) Failing after 5s
				
			Integration Tests / test-matrix (library, 3.13, post_training) (push) Failing after 4s
				
			Integration Tests / test-matrix (library, 3.12, inference) (push) Failing after 10s
				
			Integration Tests / test-matrix (library, 3.12, vector_io) (push) Failing after 9s
				
			Integration Tests / test-matrix (library, 3.13, providers) (push) Failing after 8s
				
			Integration Tests / test-matrix (library, 3.12, tool_runtime) (push) Failing after 6s
				
			Integration Tests / test-matrix (library, 3.12, post_training) (push) Failing after 13s
				
			SqlStore Integration Tests / test-postgres (3.13) (push) Failing after 16s
				
			SqlStore Integration Tests / test-postgres (3.12) (push) Failing after 19s
				
			Integration Tests / test-matrix (library, 3.13, datasets) (push) Failing after 15s
				
			Integration Tests / test-matrix (server, 3.12, datasets) (push) Failing after 8s
				
			Integration Tests / test-matrix (library, 3.12, inspect) (push) Failing after 12s
				
			Integration Tests / test-matrix (server, 3.13, inference) (push) Failing after 9s
				
			Integration Tests / test-matrix (library, 3.13, tool_runtime) (push) Failing after 13s
				
			Integration Tests / test-matrix (library, 3.13, scoring) (push) Failing after 12s
				
			Integration Tests / test-matrix (server, 3.12, providers) (push) Failing after 8s
				
			Integration Tests / test-matrix (library, 3.13, vector_io) (push) Failing after 10s
				
			Integration Tests / test-matrix (server, 3.12, agents) (push) Failing after 12s
				
			Integration Tests / test-matrix (library, 3.13, inspect) (push) Failing after 14s
				
			Integration Tests / test-matrix (server, 3.12, tool_runtime) (push) Failing after 10s
				
			Integration Tests / test-matrix (server, 3.13, datasets) (push) Failing after 8s
				
			Integration Tests / test-matrix (server, 3.13, inspect) (push) Failing after 12s
				
			Integration Tests / test-matrix (server, 3.12, inference) (push) Failing after 6s
				
			Integration Tests / test-matrix (server, 3.13, providers) (push) Failing after 10s
				
			Integration Tests / test-matrix (server, 3.13, scoring) (push) Failing after 9s
				
			Integration Tests / test-matrix (library, 3.13, inference) (push) Failing after 11s
				
			Integration Tests / test-matrix (server, 3.12, inspect) (push) Failing after 12s
				
			Integration Tests / test-matrix (server, 3.12, scoring) (push) Failing after 11s
				
			Integration Tests / test-matrix (library, 3.12, providers) (push) Failing after 13s
				
			Integration Tests / test-matrix (server, 3.13, agents) (push) Failing after 10s
				
			Vector IO Integration Tests / test-matrix (3.12, inline::faiss) (push) Failing after 8s
				
			Integration Tests / test-matrix (server, 3.13, post_training) (push) Failing after 11s
				
			Integration Tests / test-matrix (server, 3.13, vector_io) (push) Failing after 7s
				
			Vector IO Integration Tests / test-matrix (3.12, inline::milvus) (push) Failing after 8s
				
			Integration Tests / test-matrix (library, 3.13, agents) (push) Failing after 13s
				
			Integration Tests / test-matrix (server, 3.12, vector_io) (push) Failing after 14s
				
			Integration Tests / test-matrix (server, 3.12, post_training) (push) Failing after 14s
				
			Integration Tests / test-matrix (server, 3.13, tool_runtime) (push) Failing after 8s
				
			Vector IO Integration Tests / test-matrix (3.12, inline::sqlite-vec) (push) Failing after 25s
				
			Vector IO Integration Tests / test-matrix (3.12, remote::chromadb) (push) Failing after 23s
				
			Vector IO Integration Tests / test-matrix (3.12, remote::pgvector) (push) Failing after 28s
				
			Vector IO Integration Tests / test-matrix (3.13, inline::faiss) (push) Failing after 27s
				
			Vector IO Integration Tests / test-matrix (3.13, inline::milvus) (push) Failing after 12s
				
			Vector IO Integration Tests / test-matrix (3.13, inline::sqlite-vec) (push) Failing after 10s
				
			Vector IO Integration Tests / test-matrix (3.13, remote::chromadb) (push) Failing after 6s
				
			Vector IO Integration Tests / test-matrix (3.13, remote::pgvector) (push) Failing after 5s
				
			Test Llama Stack Build / generate-matrix (push) Successful in 5s
				
			Python Package Build Test / build (3.12) (push) Failing after 1s
				
			Test External Providers / test-external-providers (venv) (push) Failing after 3s
				
			Python Package Build Test / build (3.13) (push) Failing after 3s
				
			Update ReadTheDocs / update-readthedocs (push) Failing after 3s
				
			Test Llama Stack Build / build (push) Failing after 4s
				
			Unit Tests / unit-tests (3.12) (push) Failing after 4s
				
			Unit Tests / unit-tests (3.13) (push) Failing after 7s
				
			Test Llama Stack Build / build-single-provider (push) Failing after 44s
				
			Test Llama Stack Build / build-ubi9-container-distribution (push) Failing after 41s
				
			Test Llama Stack Build / build-custom-container-distribution (push) Failing after 43s
				
			Pre-commit / pre-commit (push) Successful in 1m34s
				
			# What does this PR do? postgres has different json extract syntax from sqlite ## Test Plan added integration test
		
			
				
	
	
		
			116 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # Copyright (c) Meta Platforms, Inc. and affiliates.
 | |
| # All rights reserved.
 | |
| #
 | |
| # This source code is licensed under the terms described in the LICENSE file in
 | |
| # the root directory of this source tree.
 | |
| 
 | |
| from abc import abstractmethod
 | |
| from enum import StrEnum
 | |
| from pathlib import Path
 | |
| from typing import Annotated, Literal
 | |
| 
 | |
| from pydantic import BaseModel, Field
 | |
| 
 | |
| from llama_stack.distribution.utils.config_dirs import RUNTIME_BASE_DIR
 | |
| 
 | |
| from .api import SqlStore
 | |
| 
 | |
| sql_store_pip_packages = ["sqlalchemy[asyncio]", "aiosqlite", "asyncpg"]
 | |
| 
 | |
| 
 | |
| class SqlStoreType(StrEnum):
 | |
|     sqlite = "sqlite"
 | |
|     postgres = "postgres"
 | |
| 
 | |
| 
 | |
| class SqlAlchemySqlStoreConfig(BaseModel):
 | |
|     @property
 | |
|     @abstractmethod
 | |
|     def engine_str(self) -> str: ...
 | |
| 
 | |
|     # TODO: move this when we have a better way to specify dependencies with internal APIs
 | |
|     @classmethod
 | |
|     def pip_packages(cls) -> list[str]:
 | |
|         return ["sqlalchemy[asyncio]"]
 | |
| 
 | |
| 
 | |
| class SqliteSqlStoreConfig(SqlAlchemySqlStoreConfig):
 | |
|     type: Literal[SqlStoreType.sqlite] = SqlStoreType.sqlite
 | |
|     db_path: str = Field(
 | |
|         default=(RUNTIME_BASE_DIR / "sqlstore.db").as_posix(),
 | |
|         description="Database path, e.g. ~/.llama/distributions/ollama/sqlstore.db",
 | |
|     )
 | |
| 
 | |
|     @property
 | |
|     def engine_str(self) -> str:
 | |
|         return "sqlite+aiosqlite:///" + Path(self.db_path).expanduser().as_posix()
 | |
| 
 | |
|     @classmethod
 | |
|     def sample_run_config(cls, __distro_dir__: str, db_name: str = "sqlstore.db"):
 | |
|         return {
 | |
|             "type": "sqlite",
 | |
|             "db_path": "${env.SQLITE_STORE_DIR:=" + __distro_dir__ + "}/" + db_name,
 | |
|         }
 | |
| 
 | |
|     @classmethod
 | |
|     def pip_packages(cls) -> list[str]:
 | |
|         return super().pip_packages() + ["aiosqlite"]
 | |
| 
 | |
| 
 | |
| class PostgresSqlStoreConfig(SqlAlchemySqlStoreConfig):
 | |
|     type: Literal[SqlStoreType.postgres] = SqlStoreType.postgres
 | |
|     host: str = "localhost"
 | |
|     port: int = 5432
 | |
|     db: str = "llamastack"
 | |
|     user: str
 | |
|     password: str | None = None
 | |
| 
 | |
|     @property
 | |
|     def engine_str(self) -> str:
 | |
|         return f"postgresql+asyncpg://{self.user}:{self.password}@{self.host}:{self.port}/{self.db}"
 | |
| 
 | |
|     @classmethod
 | |
|     def pip_packages(cls) -> list[str]:
 | |
|         return super().pip_packages() + ["asyncpg"]
 | |
| 
 | |
|     @classmethod
 | |
|     def sample_run_config(cls, **kwargs):
 | |
|         return {
 | |
|             "type": "postgres",
 | |
|             "host": "${env.POSTGRES_HOST:=localhost}",
 | |
|             "port": "${env.POSTGRES_PORT:=5432}",
 | |
|             "db": "${env.POSTGRES_DB:=llamastack}",
 | |
|             "user": "${env.POSTGRES_USER:=llamastack}",
 | |
|             "password": "${env.POSTGRES_PASSWORD:=llamastack}",
 | |
|         }
 | |
| 
 | |
| 
 | |
| SqlStoreConfig = Annotated[
 | |
|     SqliteSqlStoreConfig | PostgresSqlStoreConfig,
 | |
|     Field(discriminator="type", default=SqlStoreType.sqlite.value),
 | |
| ]
 | |
| 
 | |
| 
 | |
| def get_pip_packages(store_config: dict | SqlStoreConfig) -> list[str]:
 | |
|     """Get pip packages for SQL store config, handling both dict and object cases."""
 | |
|     if isinstance(store_config, dict):
 | |
|         store_type = store_config.get("type")
 | |
|         if store_type == "sqlite":
 | |
|             return SqliteSqlStoreConfig.pip_packages()
 | |
|         elif store_type == "postgres":
 | |
|             return PostgresSqlStoreConfig.pip_packages()
 | |
|         else:
 | |
|             raise ValueError(f"Unknown SQL store type: {store_type}")
 | |
|     else:
 | |
|         return store_config.pip_packages()
 | |
| 
 | |
| 
 | |
| def sqlstore_impl(config: SqlStoreConfig) -> SqlStore:
 | |
|     if config.type in [SqlStoreType.sqlite, SqlStoreType.postgres]:
 | |
|         from .sqlalchemy_sqlstore import SqlAlchemySqlStoreImpl
 | |
| 
 | |
|         impl = SqlAlchemySqlStoreImpl(config)
 | |
|     else:
 | |
|         raise ValueError(f"Unknown sqlstore type {config.type}")
 | |
| 
 | |
|     return impl
 |