mirror of
https://github.com/meta-llama/llama-stack.git
synced 2025-08-21 01:15:10 +00:00
Some checks failed
Test External Providers Installed via Module / test-external-providers-from-module (venv) (push) Has been skipped
SqlStore Integration Tests / test-postgres (3.12) (push) Failing after 21s
Test Llama Stack Build / build-single-provider (push) Failing after 23s
SqlStore Integration Tests / test-postgres (3.13) (push) Failing after 28s
Test Llama Stack Build / generate-matrix (push) Successful in 25s
Python Package Build Test / build (3.13) (push) Failing after 25s
Test Llama Stack Build / build-custom-container-distribution (push) Failing after 34s
Integration Tests (Replay) / Integration Tests (, , , client=, vision=) (push) Failing after 37s
Test External API and Providers / test-external (venv) (push) Failing after 33s
Unit Tests / unit-tests (3.13) (push) Failing after 33s
Test Llama Stack Build / build-ubi9-container-distribution (push) Failing after 38s
Python Package Build Test / build (3.12) (push) Failing after 1m0s
Integration Auth Tests / test-matrix (oauth2_token) (push) Failing after 1m4s
Unit Tests / unit-tests (3.12) (push) Failing after 59s
Test Llama Stack Build / build (push) Failing after 50s
Vector IO Integration Tests / test-matrix (push) Failing after 1m48s
UI Tests / ui-tests (22) (push) Successful in 2m12s
Pre-commit / pre-commit (push) Successful in 2m41s
I started this PR trying to unbreak a newly broken test `test_agent_name`. This test was broken all along but did not show up because during testing we were pulling the "non-updated" llama stack client. See this comment: https://github.com/llamastack/llama-stack/pull/3119#discussion_r2270988205 While fixing this, I encountered a large amount of badness in our CI workflow definitions. - We weren't passing `LLAMA_STACK_DIR` or `LLAMA_STACK_CLIENT_DIR` overrides to `llama stack build` at all in some cases. - Even when we did, we used `uv run` liberally. The first thing `uv run` does is "syncs" the project environment. This means, it is going to undo any mutations we might have done ourselves. But we make many mutations in our CI runners to these environments. The most important of which is why `llama stack build` where we install distro dependencies. As a result, when you tried to run the integration tests, you would see old, strange versions. ## Test Plan Re-record using: ``` sh scripts/integration-tests.sh --stack-config ci-tests \ --provider ollama --test-pattern test_agent_name --inference-mode record ``` Then re-run with `--inference-mode replay`. But: Eventually, this test turned out to be quite flaky for telemetry reasons. I haven't investigated it for now and just disabled it sadly since we have a release to push out.
220 lines
6.6 KiB
Bash
Executable file
220 lines
6.6 KiB
Bash
Executable file
#!/bin/bash
|
|
|
|
# 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.
|
|
|
|
LLAMA_STACK_DIR=${LLAMA_STACK_DIR:-}
|
|
LLAMA_STACK_CLIENT_DIR=${LLAMA_STACK_CLIENT_DIR:-}
|
|
TEST_PYPI_VERSION=${TEST_PYPI_VERSION:-}
|
|
# This timeout (in seconds) is necessary when installing PyTorch via uv since it's likely to time out
|
|
# Reference: https://github.com/astral-sh/uv/pull/1694
|
|
UV_HTTP_TIMEOUT=${UV_HTTP_TIMEOUT:-500}
|
|
UV_SYSTEM_PYTHON=${UV_SYSTEM_PYTHON:-}
|
|
VIRTUAL_ENV=${VIRTUAL_ENV:-}
|
|
|
|
set -euo pipefail
|
|
|
|
# Define color codes
|
|
RED='\033[0;31m'
|
|
NC='\033[0m' # No Color
|
|
|
|
SCRIPT_DIR=$(dirname "$(readlink -f "$0")")
|
|
source "$SCRIPT_DIR/common.sh"
|
|
|
|
# Usage function
|
|
usage() {
|
|
echo "Usage: $0 --env-name <env_name> --normal-deps <pip_dependencies> [--external-provider-deps <external_provider_deps>] [--optional-deps <special_pip_deps>]"
|
|
echo "Example: $0 --env-name mybuild --normal-deps 'numpy pandas scipy' --external-provider-deps 'foo' --optional-deps 'bar'"
|
|
exit 1
|
|
}
|
|
|
|
# Parse arguments
|
|
env_name=""
|
|
normal_deps=""
|
|
external_provider_deps=""
|
|
optional_deps=""
|
|
|
|
while [[ $# -gt 0 ]]; do
|
|
key="$1"
|
|
case "$key" in
|
|
--env-name)
|
|
if [[ -z "$2" || "$2" == --* ]]; then
|
|
echo "Error: --env-name requires a string value" >&2
|
|
usage
|
|
fi
|
|
env_name="$2"
|
|
shift 2
|
|
;;
|
|
--normal-deps)
|
|
if [[ -z "$2" || "$2" == --* ]]; then
|
|
echo "Error: --normal-deps requires a string value" >&2
|
|
usage
|
|
fi
|
|
normal_deps="$2"
|
|
shift 2
|
|
;;
|
|
--external-provider-deps)
|
|
if [[ -z "$2" || "$2" == --* ]]; then
|
|
echo "Error: --external-provider-deps requires a string value" >&2
|
|
usage
|
|
fi
|
|
external_provider_deps="$2"
|
|
shift 2
|
|
;;
|
|
--optional-deps)
|
|
if [[ -z "$2" || "$2" == --* ]]; then
|
|
echo "Error: --optional-deps requires a string value" >&2
|
|
usage
|
|
fi
|
|
optional_deps="$2"
|
|
shift 2
|
|
;;
|
|
*)
|
|
echo "Unknown option: $1" >&2
|
|
usage
|
|
;;
|
|
esac
|
|
done
|
|
|
|
# Check required arguments
|
|
if [[ -z "$env_name" || -z "$normal_deps" ]]; then
|
|
echo "Error: --env-name and --normal-deps are required." >&2
|
|
usage
|
|
fi
|
|
|
|
if [ -n "$LLAMA_STACK_DIR" ]; then
|
|
echo "Using llama-stack-dir=$LLAMA_STACK_DIR"
|
|
fi
|
|
if [ -n "$LLAMA_STACK_CLIENT_DIR" ]; then
|
|
echo "Using llama-stack-client-dir=$LLAMA_STACK_CLIENT_DIR"
|
|
fi
|
|
|
|
ENVNAME=""
|
|
|
|
# pre-run checks to make sure we can proceed with the installation
|
|
pre_run_checks() {
|
|
local env_name="$1"
|
|
|
|
if ! is_command_available uv; then
|
|
echo "uv is not installed, trying to install it."
|
|
if ! is_command_available pip; then
|
|
echo "pip is not installed, cannot automatically install 'uv'."
|
|
echo "Follow this link to install it:"
|
|
echo "https://docs.astral.sh/uv/getting-started/installation/"
|
|
exit 1
|
|
else
|
|
pip install uv
|
|
fi
|
|
fi
|
|
|
|
# checking if an environment with the same name already exists
|
|
if [ -d "$env_name" ]; then
|
|
echo "Environment '$env_name' already exists, re-using it."
|
|
fi
|
|
}
|
|
|
|
run() {
|
|
# Use only global variables set by flag parser
|
|
if [ -n "$UV_SYSTEM_PYTHON" ] || [ "$env_name" == "__system__" ]; then
|
|
echo "Installing dependencies in system Python environment"
|
|
export UV_SYSTEM_PYTHON=1
|
|
elif [ "$VIRTUAL_ENV" == "$env_name" ]; then
|
|
echo "Virtual environment $env_name is already active"
|
|
else
|
|
echo "Using virtual environment $env_name"
|
|
uv venv "$env_name"
|
|
source "$env_name/bin/activate"
|
|
fi
|
|
|
|
if [ -n "$TEST_PYPI_VERSION" ]; then
|
|
uv pip install fastapi libcst
|
|
uv pip install --extra-index-url https://test.pypi.org/simple/ \
|
|
--index-strategy unsafe-best-match \
|
|
llama-stack=="$TEST_PYPI_VERSION" \
|
|
$normal_deps
|
|
if [ -n "$optional_deps" ]; then
|
|
IFS='#' read -ra parts <<<"$optional_deps"
|
|
for part in "${parts[@]}"; do
|
|
echo "$part"
|
|
uv pip install $part
|
|
done
|
|
fi
|
|
if [ -n "$external_provider_deps" ]; then
|
|
IFS='#' read -ra parts <<<"$external_provider_deps"
|
|
for part in "${parts[@]}"; do
|
|
echo "$part"
|
|
uv pip install "$part"
|
|
done
|
|
fi
|
|
else
|
|
if [ -n "$LLAMA_STACK_DIR" ]; then
|
|
# only warn if DIR does not start with "git+"
|
|
if [ ! -d "$LLAMA_STACK_DIR" ] && [[ "$LLAMA_STACK_DIR" != git+* ]]; then
|
|
printf "${RED}Warning: LLAMA_STACK_DIR is set but directory does not exist: %s${NC}\n" "$LLAMA_STACK_DIR" >&2
|
|
exit 1
|
|
fi
|
|
printf "Installing from LLAMA_STACK_DIR: %s\n" "$LLAMA_STACK_DIR"
|
|
# editable only if LLAMA_STACK_DIR does not start with "git+"
|
|
if [[ "$LLAMA_STACK_DIR" != git+* ]]; then
|
|
EDITABLE="-e"
|
|
else
|
|
EDITABLE=""
|
|
fi
|
|
uv pip install --no-cache-dir $EDITABLE "$LLAMA_STACK_DIR"
|
|
else
|
|
uv pip install --no-cache-dir llama-stack
|
|
fi
|
|
|
|
if [ -n "$LLAMA_STACK_CLIENT_DIR" ]; then
|
|
# only warn if DIR does not start with "git+"
|
|
if [ ! -d "$LLAMA_STACK_CLIENT_DIR" ] && [[ "$LLAMA_STACK_CLIENT_DIR" != git+* ]]; then
|
|
printf "${RED}Warning: LLAMA_STACK_CLIENT_DIR is set but directory does not exist: %s${NC}\n" "$LLAMA_STACK_CLIENT_DIR" >&2
|
|
exit 1
|
|
fi
|
|
printf "Installing from LLAMA_STACK_CLIENT_DIR: %s\n" "$LLAMA_STACK_CLIENT_DIR"
|
|
# editable only if LLAMA_STACK_CLIENT_DIR does not start with "git+"
|
|
if [[ "$LLAMA_STACK_CLIENT_DIR" != git+* ]]; then
|
|
EDITABLE="-e"
|
|
else
|
|
EDITABLE=""
|
|
fi
|
|
uv pip install --no-cache-dir $EDITABLE "$LLAMA_STACK_CLIENT_DIR"
|
|
fi
|
|
|
|
printf "Installing pip dependencies\n"
|
|
uv pip install $normal_deps
|
|
if [ -n "$optional_deps" ]; then
|
|
IFS='#' read -ra parts <<<"$optional_deps"
|
|
for part in "${parts[@]}"; do
|
|
echo "Installing special provider module: $part"
|
|
uv pip install $part
|
|
done
|
|
fi
|
|
if [ -n "$external_provider_deps" ]; then
|
|
IFS='#' read -ra parts <<<"$external_provider_deps"
|
|
for part in "${parts[@]}"; do
|
|
echo "Installing external provider module: $part"
|
|
uv pip install "$part"
|
|
echo "Getting provider spec for module: $part and installing dependencies"
|
|
package_name=$(echo "$part" | sed 's/[<>=!].*//')
|
|
python3 -c "
|
|
import importlib
|
|
import sys
|
|
try:
|
|
module = importlib.import_module(f'$package_name.provider')
|
|
spec = module.get_provider_spec()
|
|
if hasattr(spec, 'pip_packages') and spec.pip_packages:
|
|
print('\\n'.join(spec.pip_packages))
|
|
except Exception as e:
|
|
print(f'Error getting provider spec for $package_name: {e}', file=sys.stderr)
|
|
" | uv pip install -r -
|
|
done
|
|
fi
|
|
fi
|
|
}
|
|
|
|
pre_run_checks "$env_name"
|
|
run
|