mirror of
				https://github.com/meta-llama/llama-stack.git
				synced 2025-10-26 09:15:40 +00:00 
			
		
		
		
	
		
			Some checks failed
		
		
	
	SqlStore Integration Tests / test-postgres (3.13) (push) Failing after 0s
				
			Integration Auth Tests / test-matrix (oauth2_token) (push) Failing after 2s
				
			Test Llama Stack Build / generate-matrix (push) Successful in 3s
				
			Integration Tests (Replay) / Integration Tests (, , , client=, ) (push) Failing after 4s
				
			Test Llama Stack Build / build-custom-container-distribution (push) Failing after 3s
				
			SqlStore Integration Tests / test-postgres (3.12) (push) Failing after 7s
				
			Python Package Build Test / build (3.13) (push) Failing after 0s
				
			Test External Providers Installed via Module / test-external-providers-from-module (venv) (push) Has been skipped
				
			Test Llama Stack Build / build-single-provider (push) Failing after 4s
				
			Vector IO Integration Tests / test-matrix (push) Failing after 6s
				
			Test llama stack list-deps / generate-matrix (push) Successful in 4s
				
			Test llama stack list-deps / show-single-provider (push) Failing after 4s
				
			Test llama stack list-deps / list-deps-from-config (push) Failing after 4s
				
			Test External API and Providers / test-external (venv) (push) Failing after 4s
				
			API Conformance Tests / check-schema-compatibility (push) Successful in 12s
				
			Unit Tests / unit-tests (3.12) (push) Failing after 3s
				
			Test Llama Stack Build / build (push) Failing after 5s
				
			Unit Tests / unit-tests (3.13) (push) Failing after 6s
				
			Python Package Build Test / build (3.12) (push) Failing after 25s
				
			Test llama stack list-deps / list-deps (push) Failing after 24s
				
			UI Tests / ui-tests (22) (push) Successful in 52s
				
			Test Llama Stack Build / build-ubi9-container-distribution (push) Failing after 30s
				
			Pre-commit / pre-commit (push) Successful in 1m59s
				
			
		
			
				
	
	
		
			332 lines
		
	
	
	
		
			12 KiB
		
	
	
	
		
			TOML
		
	
	
	
	
	
			
		
		
	
	
			332 lines
		
	
	
	
		
			12 KiB
		
	
	
	
		
			TOML
		
	
	
	
	
	
| [build-system]
 | |
| requires = ["setuptools>=61.0"]
 | |
| build-backend = "setuptools.build_meta"
 | |
| 
 | |
| [tool.uv]
 | |
| required-version = ">=0.7.0"
 | |
| 
 | |
| [project]
 | |
| name = "llama_stack"
 | |
| version = "0.3.0"
 | |
| authors = [{ name = "Meta Llama", email = "llama-oss@meta.com" }]
 | |
| description = "Llama Stack"
 | |
| readme = "README.md"
 | |
| requires-python = ">=3.12"
 | |
| license = { "text" = "MIT" }
 | |
| classifiers = [
 | |
|     "License :: OSI Approved :: MIT License",
 | |
|     "Programming Language :: Python :: 3",
 | |
|     "Operating System :: OS Independent",
 | |
|     "Intended Audience :: Developers",
 | |
|     "Intended Audience :: Information Technology",
 | |
|     "Intended Audience :: Science/Research",
 | |
|     "Topic :: Scientific/Engineering :: Artificial Intelligence",
 | |
|     "Topic :: Scientific/Engineering :: Information Analysis",
 | |
| ]
 | |
| dependencies = [
 | |
|     "aiohttp",
 | |
|     "fastapi>=0.115.0,<1.0",                          # server
 | |
|     "fire",                                           # for MCP in LLS client
 | |
|     "httpx",
 | |
|     "jinja2>=3.1.6",
 | |
|     "jsonschema",
 | |
|     "llama-stack-client>=0.3.0",
 | |
|     "openai>=1.107",                                  # for expires_after support
 | |
|     "prompt-toolkit",
 | |
|     "python-dotenv",
 | |
|     "pyjwt[crypto]>=2.10.0",                          # Pull crypto to support RS256 for jwt. Requires 2.10.0+ for ssl_context support.
 | |
|     "pydantic>=2.11.9",
 | |
|     "rich",
 | |
|     "starlette",
 | |
|     "termcolor",
 | |
|     "tiktoken",
 | |
|     "pillow",
 | |
|     "h11>=0.16.0",
 | |
|     "python-multipart>=0.0.20",                       # For fastapi Form
 | |
|     "uvicorn>=0.34.0",                                # server
 | |
|     "opentelemetry-sdk>=1.30.0",                      # server
 | |
|     "opentelemetry-exporter-otlp-proto-http>=1.30.0", # server
 | |
|     "aiosqlite>=0.21.0",                              # server - for metadata store
 | |
|     "asyncpg",                                        # for metadata store
 | |
|     "sqlalchemy[asyncio]>=2.0.41",                    # server - for conversations
 | |
| ]
 | |
| 
 | |
| [project.optional-dependencies]
 | |
| ui = [
 | |
|     "streamlit",
 | |
|     "pandas",
 | |
|     "llama-stack-client>=0.3.0",
 | |
|     "streamlit-option-menu",
 | |
| ]
 | |
| 
 | |
| [dependency-groups]
 | |
| dev = [
 | |
|     "pytest>=8.4",
 | |
|     "pytest-timeout",
 | |
|     "pytest-asyncio>=1.0",
 | |
|     "pytest-cov",
 | |
|     "pytest-html",
 | |
|     "pytest-json-report",
 | |
|     "pytest-socket",       # For blocking network access in unit tests
 | |
|     "nbval",               # For notebook testing
 | |
|     "black",
 | |
|     "ruff",
 | |
|     "types-requests",
 | |
|     "types-setuptools",
 | |
|     "pre-commit",
 | |
|     "ruamel.yaml",         # needed for openapi generator
 | |
| ]
 | |
| # These are the dependencies required for running unit tests.
 | |
| unit = [
 | |
|     "sqlite-vec",
 | |
|     "ollama",
 | |
|     "aiosqlite",
 | |
|     "aiohttp",
 | |
|     "psycopg2-binary>=2.9.0",
 | |
|     "pypdf",
 | |
|     "mcp",
 | |
|     "chardet",
 | |
|     "sqlalchemy",
 | |
|     "sqlalchemy[asyncio]>=2.0.41",
 | |
|     "blobfile",
 | |
|     "faiss-cpu",
 | |
|     "litellm",
 | |
|     "together",
 | |
|     "coverage",
 | |
|     "moto[s3]>=5.1.10",
 | |
| ]
 | |
| # These are the core dependencies required for running integration tests. They are shared across all
 | |
| # providers. If a provider requires additional dependencies, please add them to your environment
 | |
| # separately. If you are using "uv" to execute your tests, you can use the "--group" flag to specify extra
 | |
| # dependencies.
 | |
| test = [
 | |
|     "aiosqlite",
 | |
|     "aiohttp",
 | |
|     "torch>=2.6.0",
 | |
|     "torchvision>=0.21.0",
 | |
|     "chardet",
 | |
|     "psycopg2-binary>=2.9.0",
 | |
|     "pypdf",
 | |
|     "mcp",
 | |
|     "datasets>=4.0.0",
 | |
|     "autoevals",
 | |
|     "transformers",
 | |
|     "sqlalchemy",
 | |
|     "sqlalchemy[asyncio]>=2.0.41",
 | |
|     "requests",
 | |
|     "chromadb>=1.0.15",
 | |
|     "qdrant-client",
 | |
|     "pymilvus>=2.6.1",
 | |
|     "milvus-lite>=2.5.0",
 | |
|     "weaviate-client>=4.16.4",
 | |
| ]
 | |
| docs = [
 | |
|     "setuptools",
 | |
|     "sphinx-autobuild",
 | |
|     "myst-parser",
 | |
|     "sphinx",
 | |
|     "sphinx-rtd-theme",
 | |
|     "sphinx_rtd_dark_mode",
 | |
|     "sphinx-copybutton",
 | |
|     "sphinx-tabs",
 | |
|     "sphinx-design",
 | |
|     "sphinxcontrib.redoc",
 | |
|     "sphinxcontrib.video",
 | |
|     "sphinxcontrib.mermaid",
 | |
|     "sphinx-reredirects",
 | |
|     "tomli",
 | |
|     "linkify",
 | |
|     "sphinxcontrib.openapi",
 | |
|     "requests",
 | |
| ]
 | |
| codegen = ["rich", "pydantic>=2.11.9", "jinja2>=3.1.6"]
 | |
| benchmark = ["locust>=2.39.1"]
 | |
| 
 | |
| [project.urls]
 | |
| Homepage = "https://github.com/llamastack/llama-stack"
 | |
| 
 | |
| [project.scripts]
 | |
| llama = "llama_stack.cli.llama:main"
 | |
| install-wheel-from-presigned = "llama_stack.cli.scripts.run:install_wheel_from_presigned"
 | |
| 
 | |
| [tool.setuptools.packages.find]
 | |
| where = ["."]
 | |
| include = ["llama_stack", "llama_stack.*"]
 | |
| 
 | |
| [[tool.uv.index]]
 | |
| name = "pytorch-cpu"
 | |
| url = "https://download.pytorch.org/whl/cpu"
 | |
| explicit = true
 | |
| 
 | |
| [tool.uv.sources]
 | |
| torch = [{ index = "pytorch-cpu" }]
 | |
| torchvision = [{ index = "pytorch-cpu" }]
 | |
| 
 | |
| [tool.ruff]
 | |
| line-length = 120
 | |
| exclude = [
 | |
|     "./.git",
 | |
|     "./docs/*",
 | |
|     "./build",
 | |
|     "./venv",
 | |
|     "*.pyi",
 | |
|     ".pre-commit-config.yaml",
 | |
|     "*.md",
 | |
|     ".flake8",
 | |
|     "benchmarking/k8s-benchmark/results",
 | |
| ]
 | |
| 
 | |
| [tool.ruff.lint]
 | |
| select = [
 | |
|     "UP",      # pyupgrade
 | |
|     "B",       # flake8-bugbear
 | |
|     "B9",      # flake8-bugbear subset
 | |
|     "C",       # comprehensions
 | |
|     "E",       # pycodestyle
 | |
|     "F",       # Pyflakes
 | |
|     "N",       # Naming
 | |
|     "W",       # Warnings
 | |
|     "DTZ",     # datetime rules
 | |
|     "I",       # isort (imports order)
 | |
|     "RUF001",  # Checks for ambiguous Unicode characters in strings
 | |
|     "RUF002",  # Checks for ambiguous Unicode characters in docstrings
 | |
|     "RUF003",  # Checks for ambiguous Unicode characters in comments
 | |
|     "PLC2401", # Checks for the use of non-ASCII characters in variable names
 | |
|     "PLC2403", # Checks for the use of non-ASCII characters in import statements
 | |
|     "PLE2510", # Checks for strings that contain the control character BS.
 | |
|     "PLE2512", # Checks for strings that contain the raw control character SUB.
 | |
|     "PLE2513", # Checks for strings that contain the raw control character ESC.
 | |
|     "PLE2514", # Checks for strings that contain the raw control character NUL (0 byte).
 | |
|     "PLE2515", # Checks for strings that contain the zero width space character.
 | |
| ]
 | |
| ignore = [
 | |
|     # The following ignores are desired by the project maintainers.
 | |
|     "E402", # Module level import not at top of file
 | |
|     "E501", # Line too long
 | |
|     "F405", # Maybe undefined or defined from star import
 | |
|     "C408", # Ignored because we like the dict keyword argument syntax
 | |
|     "N812", # Ignored because import torch.nn.functional as F is PyTorch convention
 | |
| 
 | |
|     # These are the additional ones we started ignoring after moving to ruff. We should look into each one of them later.
 | |
|     "C901", # Complexity of the function is too high
 | |
| ]
 | |
| unfixable = [
 | |
|     "PLE2515",
 | |
| ] # Do not fix this automatically since ruff will replace the zero-width space with \u200b - let's do it manually
 | |
| 
 | |
| # Ignore the following errors for the following files
 | |
| [tool.ruff.lint.per-file-ignores]
 | |
| "tests/**/*.py" = ["DTZ"] # Ignore datetime rules for tests
 | |
| "llama_stack/providers/inline/scoring/basic/utils/ifeval_utils.py" = ["RUF001"]
 | |
| "llama_stack/providers/inline/scoring/basic/scoring_fn/fn_defs/regex_parser_multiple_choice_answer.py" = [
 | |
|     "RUF001",
 | |
|     "PLE2515",
 | |
| ]
 | |
| "llama_stack/apis/**/__init__.py" = [
 | |
|     "F403",
 | |
| ] # Using import * is acceptable (or at least tolerated) in an __init__.py of a package API
 | |
| 
 | |
| [tool.mypy]
 | |
| mypy_path = ["llama_stack"]
 | |
| packages = ["llama_stack"]
 | |
| plugins = ['pydantic.mypy']
 | |
| disable_error_code = []
 | |
| warn_return_any = true
 | |
| # # honor excludes by not following there through imports
 | |
| follow_imports = "silent"
 | |
| # Note: some entries are directories, not files. This is because mypy doesn't
 | |
| # respect __init__.py excludes, so the only way to suppress these right now is
 | |
| # to exclude the entire directory.
 | |
| exclude = [
 | |
|     # As we fix more and more of these, we should remove them from the list
 | |
|     "^llama_stack.core/build\\.py$",
 | |
|     "^llama_stack.core/client\\.py$",
 | |
|     "^llama_stack.core/request_headers\\.py$",
 | |
|     "^llama_stack.core/routers/",
 | |
|     "^llama_stack.core/routing_tables/",
 | |
|     "^llama_stack.core/server/endpoints\\.py$",
 | |
|     "^llama_stack.core/server/server\\.py$",
 | |
|     "^llama_stack.core/stack\\.py$",
 | |
|     "^llama_stack.core/store/registry\\.py$",
 | |
|     "^llama_stack.core/utils/exec\\.py$",
 | |
|     "^llama_stack.core/utils/prompt_for_config\\.py$",
 | |
|     "^llama_stack/models/llama/llama3/interface\\.py$",
 | |
|     "^llama_stack/models/llama/llama3/tokenizer\\.py$",
 | |
|     "^llama_stack/models/llama/llama3/tool_utils\\.py$",
 | |
|     "^llama_stack/providers/inline/agents/meta_reference/",
 | |
|     "^llama_stack/providers/inline/datasetio/localfs/",
 | |
|     "^llama_stack/providers/inline/eval/meta_reference/eval\\.py$",
 | |
|     "^llama_stack/providers/inline/inference/meta_reference/inference\\.py$",
 | |
|     "^llama_stack/models/llama/llama3/generation\\.py$",
 | |
|     "^llama_stack/models/llama/llama3/multimodal/model\\.py$",
 | |
|     "^llama_stack/models/llama/llama4/",
 | |
|     "^llama_stack/providers/inline/inference/sentence_transformers/sentence_transformers\\.py$",
 | |
|     "^llama_stack/providers/inline/post_training/common/validator\\.py$",
 | |
|     "^llama_stack/providers/inline/safety/code_scanner/",
 | |
|     "^llama_stack/providers/inline/safety/llama_guard/",
 | |
|     "^llama_stack/providers/inline/scoring/basic/",
 | |
|     "^llama_stack/providers/inline/scoring/braintrust/",
 | |
|     "^llama_stack/providers/inline/scoring/llm_as_judge/",
 | |
|     "^llama_stack/providers/remote/agents/sample/",
 | |
|     "^llama_stack/providers/remote/datasetio/huggingface/",
 | |
|     "^llama_stack/providers/remote/datasetio/nvidia/",
 | |
|     "^llama_stack/providers/remote/inference/bedrock/",
 | |
|     "^llama_stack/providers/remote/inference/nvidia/",
 | |
|     "^llama_stack/providers/remote/inference/passthrough/",
 | |
|     "^llama_stack/providers/remote/inference/runpod/",
 | |
|     "^llama_stack/providers/remote/inference/tgi/",
 | |
|     "^llama_stack/providers/remote/inference/watsonx/",
 | |
|     "^llama_stack/providers/remote/safety/bedrock/",
 | |
|     "^llama_stack/providers/remote/safety/nvidia/",
 | |
|     "^llama_stack/providers/remote/safety/sambanova/",
 | |
|     "^llama_stack/providers/remote/safety/sample/",
 | |
|     "^llama_stack/providers/remote/tool_runtime/bing_search/",
 | |
|     "^llama_stack/providers/remote/tool_runtime/brave_search/",
 | |
|     "^llama_stack/providers/remote/tool_runtime/model_context_protocol/",
 | |
|     "^llama_stack/providers/remote/tool_runtime/tavily_search/",
 | |
|     "^llama_stack/providers/remote/tool_runtime/wolfram_alpha/",
 | |
|     "^llama_stack/providers/remote/post_training/nvidia/",
 | |
|     "^llama_stack/providers/remote/vector_io/chroma/",
 | |
|     "^llama_stack/providers/remote/vector_io/milvus/",
 | |
|     "^llama_stack/providers/remote/vector_io/pgvector/",
 | |
|     "^llama_stack/providers/remote/vector_io/qdrant/",
 | |
|     "^llama_stack/providers/remote/vector_io/sample/",
 | |
|     "^llama_stack/providers/remote/vector_io/weaviate/",
 | |
|     "^llama_stack/providers/utils/bedrock/client\\.py$",
 | |
|     "^llama_stack/providers/utils/bedrock/refreshable_boto_session\\.py$",
 | |
|     "^llama_stack/providers/utils/inference/embedding_mixin\\.py$",
 | |
|     "^llama_stack/providers/utils/inference/litellm_openai_mixin\\.py$",
 | |
|     "^llama_stack/providers/utils/inference/model_registry\\.py$",
 | |
|     "^llama_stack/providers/utils/inference/openai_compat\\.py$",
 | |
|     "^llama_stack/providers/utils/inference/prompt_adapter\\.py$",
 | |
|     "^llama_stack/providers/utils/kvstore/kvstore\\.py$",
 | |
|     "^llama_stack/providers/utils/kvstore/postgres/postgres\\.py$",
 | |
|     "^llama_stack/providers/utils/kvstore/redis/redis\\.py$",
 | |
|     "^llama_stack/providers/utils/memory/vector_store\\.py$",
 | |
|     "^llama_stack/providers/utils/scoring/aggregation_utils\\.py$",
 | |
|     "^llama_stack/providers/utils/scoring/base_scoring_fn\\.py$",
 | |
|     "^llama_stack/providers/utils/telemetry/dataset_mixin\\.py$",
 | |
|     "^llama_stack/providers/utils/telemetry/trace_protocol\\.py$",
 | |
|     "^llama_stack/providers/utils/telemetry/tracing\\.py$",
 | |
|     "^llama_stack/strong_typing/auxiliary\\.py$",
 | |
|     "^llama_stack/distributions/template\\.py$",
 | |
| ]
 | |
| 
 | |
| [[tool.mypy.overrides]]
 | |
| # packages that lack typing annotations, do not have stubs, or are unavailable.
 | |
| module = ["yaml", "fire"]
 | |
| ignore_missing_imports = true
 | |
| 
 | |
| [tool.pydantic-mypy]
 | |
| init_forbid_extra = true
 | |
| init_typed = true
 | |
| warn_required_dynamic_aliases = true
 | |
| 
 | |
| [tool.ruff.lint.pep8-naming]
 | |
| classmethod-decorators = ["classmethod", "pydantic.field_validator"]
 | |
| 
 | |
| [tool.pytest.ini_options]
 | |
| addopts = ["--durations=10"]
 | |
| asyncio_mode = "auto"
 | |
| markers = ["allow_network: Allow network access for specific unit tests"]
 | |
| filterwarnings = "ignore::DeprecationWarning"
 |