mirror of
https://github.com/meta-llama/llama-stack.git
synced 2025-12-03 09:53:45 +00:00
fix(ci): use test.pypi as extra index for RC dependencies (#4009)
Backports UV index configuration fixes from `release-0.3.x` (PR #4002). The main issue: when we created the release branch infrastructure, we configured UV to use `test.pypi` as the PRIMARY index to resolve RC dependencies. This caused UV to look for ALL packages there first, which led to problems - some packages don't have binary wheels on `test.pypi`, so UV tried building from source and failed (like the `psycopg2-binary` issue we hit). The fix is simple: use PyPI as primary (default) and `test.pypi` as an EXTRA index. UV will check PyPI first for everything, and only fall back to `test.pypi` for packages not found there (like our RC client versions). This PR includes: - Fixed `install-llama-stack-client` action to output `UV_EXTRA_INDEX_URL` instead of `UV_INDEX_URL` - New `uv-run-with-index.sh` wrapper that auto-detects release branches and sets UV env vars - Updated pre-commit hooks (`uv-lock`, codegen, etc.) to use the wrapper - Pass UV env vars as Docker build args in all locations - Scope UV env vars properly in Containerfile (inline for llama-stack install, explicitly unset before distribution deps) - Export UV env vars to `GITHUB_ENV` in setup-runner for cross-step persistence The wrapper detects release branches automatically in both CI and local environments, so this "just works" without manual configuration. On main (non-release branch), the wrapper becomes a no-op. Tested and validated on `release-0.3.x` where all CI checks pass.
This commit is contained in:
parent
62603d25c2
commit
f8fe3018af
10 changed files with 161 additions and 49 deletions
|
|
@ -8,9 +8,6 @@ inputs:
|
||||||
default: ""
|
default: ""
|
||||||
|
|
||||||
outputs:
|
outputs:
|
||||||
uv-index-url:
|
|
||||||
description: 'UV_INDEX_URL to use (set for release branches)'
|
|
||||||
value: ${{ steps.configure.outputs.uv-index-url }}
|
|
||||||
uv-extra-index-url:
|
uv-extra-index-url:
|
||||||
description: 'UV_EXTRA_INDEX_URL to use (set for release branches)'
|
description: 'UV_EXTRA_INDEX_URL to use (set for release branches)'
|
||||||
value: ${{ steps.configure.outputs.uv-extra-index-url }}
|
value: ${{ steps.configure.outputs.uv-extra-index-url }}
|
||||||
|
|
@ -46,9 +43,8 @@ runs:
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Configure to use test.pypi for sync (to resolve RC versions)
|
# Configure to use test.pypi as extra index (PyPI is primary)
|
||||||
echo "uv-index-url=https://test.pypi.org/simple/" >> $GITHUB_OUTPUT
|
echo "uv-extra-index-url=https://test.pypi.org/simple/" >> $GITHUB_OUTPUT
|
||||||
echo "uv-extra-index-url=https://pypi.org/simple/" >> $GITHUB_OUTPUT
|
|
||||||
echo "install-after-sync=true" >> $GITHUB_OUTPUT
|
echo "install-after-sync=true" >> $GITHUB_OUTPUT
|
||||||
echo "install-source=git+https://github.com/llamastack/llama-stack-client-python.git@$BRANCH" >> $GITHUB_OUTPUT
|
echo "install-source=git+https://github.com/llamastack/llama-stack-client-python.git@$BRANCH" >> $GITHUB_OUTPUT
|
||||||
elif [ "${{ inputs.client-version }}" = "latest" ]; then
|
elif [ "${{ inputs.client-version }}" = "latest" ]; then
|
||||||
|
|
|
||||||
8
.github/actions/setup-runner/action.yml
vendored
8
.github/actions/setup-runner/action.yml
vendored
|
|
@ -27,9 +27,15 @@ runs:
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
shell: bash
|
shell: bash
|
||||||
env:
|
env:
|
||||||
UV_INDEX_URL: ${{ steps.client-config.outputs.uv-index-url }}
|
|
||||||
UV_EXTRA_INDEX_URL: ${{ steps.client-config.outputs.uv-extra-index-url }}
|
UV_EXTRA_INDEX_URL: ${{ steps.client-config.outputs.uv-extra-index-url }}
|
||||||
run: |
|
run: |
|
||||||
|
# Export UV env vars to GITHUB_ENV so they persist across steps
|
||||||
|
if [ -n "$UV_EXTRA_INDEX_URL" ]; then
|
||||||
|
echo "UV_EXTRA_INDEX_URL=$UV_EXTRA_INDEX_URL" >> $GITHUB_ENV
|
||||||
|
echo "UV_INDEX_STRATEGY=unsafe-best-match" >> $GITHUB_ENV
|
||||||
|
echo "Exported UV environment variables for subsequent steps"
|
||||||
|
fi
|
||||||
|
|
||||||
echo "Updating project dependencies via uv sync"
|
echo "Updating project dependencies via uv sync"
|
||||||
uv sync --all-groups
|
uv sync --all-groups
|
||||||
|
|
||||||
|
|
|
||||||
10
.github/workflows/install-script-ci.yml
vendored
10
.github/workflows/install-script-ci.yml
vendored
|
|
@ -30,10 +30,16 @@ jobs:
|
||||||
|
|
||||||
- name: Build a single provider
|
- name: Build a single provider
|
||||||
run: |
|
run: |
|
||||||
|
BUILD_ARGS="--build-arg INSTALL_MODE=editable --build-arg DISTRO_NAME=starter"
|
||||||
|
if [ -n "${UV_EXTRA_INDEX_URL:-}" ]; then
|
||||||
|
BUILD_ARGS="$BUILD_ARGS --build-arg UV_EXTRA_INDEX_URL=$UV_EXTRA_INDEX_URL"
|
||||||
|
fi
|
||||||
|
if [ -n "${UV_INDEX_STRATEGY:-}" ]; then
|
||||||
|
BUILD_ARGS="$BUILD_ARGS --build-arg UV_INDEX_STRATEGY=$UV_INDEX_STRATEGY"
|
||||||
|
fi
|
||||||
docker build . \
|
docker build . \
|
||||||
-f containers/Containerfile \
|
-f containers/Containerfile \
|
||||||
--build-arg INSTALL_MODE=editable \
|
$BUILD_ARGS \
|
||||||
--build-arg DISTRO_NAME=starter \
|
|
||||||
--tag llama-stack:starter-ci
|
--tag llama-stack:starter-ci
|
||||||
|
|
||||||
- name: Run installer end-to-end
|
- name: Run installer end-to-end
|
||||||
|
|
|
||||||
11
.github/workflows/pre-commit.yml
vendored
11
.github/workflows/pre-commit.yml
vendored
|
|
@ -136,9 +136,12 @@ jobs:
|
||||||
|
|
||||||
- name: Sync dev + type_checking dependencies
|
- name: Sync dev + type_checking dependencies
|
||||||
env:
|
env:
|
||||||
UV_INDEX_URL: ${{ steps.client-config.outputs.uv-index-url }}
|
|
||||||
UV_EXTRA_INDEX_URL: ${{ steps.client-config.outputs.uv-extra-index-url }}
|
UV_EXTRA_INDEX_URL: ${{ steps.client-config.outputs.uv-extra-index-url }}
|
||||||
run: |
|
run: |
|
||||||
|
if [ -n "$UV_EXTRA_INDEX_URL" ]; then
|
||||||
|
export UV_INDEX_STRATEGY="unsafe-best-match"
|
||||||
|
fi
|
||||||
|
|
||||||
uv sync --group dev --group type_checking
|
uv sync --group dev --group type_checking
|
||||||
|
|
||||||
# Install specific client version after sync if needed
|
# Install specific client version after sync if needed
|
||||||
|
|
@ -148,7 +151,13 @@ jobs:
|
||||||
fi
|
fi
|
||||||
|
|
||||||
- name: Run mypy (full type_checking)
|
- name: Run mypy (full type_checking)
|
||||||
|
env:
|
||||||
|
UV_EXTRA_INDEX_URL: ${{ steps.client-config.outputs.uv-extra-index-url }}
|
||||||
run: |
|
run: |
|
||||||
|
if [ -n "$UV_EXTRA_INDEX_URL" ]; then
|
||||||
|
export UV_INDEX_STRATEGY="unsafe-best-match"
|
||||||
|
fi
|
||||||
|
|
||||||
set +e
|
set +e
|
||||||
uv run --group dev --group type_checking mypy
|
uv run --group dev --group type_checking mypy
|
||||||
status=$?
|
status=$?
|
||||||
|
|
|
||||||
38
.github/workflows/providers-build.yml
vendored
38
.github/workflows/providers-build.yml
vendored
|
|
@ -72,10 +72,16 @@ jobs:
|
||||||
- name: Build container image
|
- name: Build container image
|
||||||
if: matrix.image-type == 'container'
|
if: matrix.image-type == 'container'
|
||||||
run: |
|
run: |
|
||||||
|
BUILD_ARGS="--build-arg INSTALL_MODE=editable --build-arg DISTRO_NAME=${{ matrix.distro }}"
|
||||||
|
if [ -n "${UV_EXTRA_INDEX_URL:-}" ]; then
|
||||||
|
BUILD_ARGS="$BUILD_ARGS --build-arg UV_EXTRA_INDEX_URL=$UV_EXTRA_INDEX_URL"
|
||||||
|
fi
|
||||||
|
if [ -n "${UV_INDEX_STRATEGY:-}" ]; then
|
||||||
|
BUILD_ARGS="$BUILD_ARGS --build-arg UV_INDEX_STRATEGY=$UV_INDEX_STRATEGY"
|
||||||
|
fi
|
||||||
docker build . \
|
docker build . \
|
||||||
-f containers/Containerfile \
|
-f containers/Containerfile \
|
||||||
--build-arg INSTALL_MODE=editable \
|
$BUILD_ARGS \
|
||||||
--build-arg DISTRO_NAME=${{ matrix.distro }} \
|
|
||||||
--tag llama-stack:${{ matrix.distro }}-ci
|
--tag llama-stack:${{ matrix.distro }}-ci
|
||||||
|
|
||||||
- name: Print dependencies in the image
|
- name: Print dependencies in the image
|
||||||
|
|
@ -108,12 +114,18 @@ jobs:
|
||||||
- name: Build container image
|
- name: Build container image
|
||||||
run: |
|
run: |
|
||||||
BASE_IMAGE=$(yq -r '.distribution_spec.container_image // "python:3.12-slim"' src/llama_stack/distributions/ci-tests/build.yaml)
|
BASE_IMAGE=$(yq -r '.distribution_spec.container_image // "python:3.12-slim"' src/llama_stack/distributions/ci-tests/build.yaml)
|
||||||
|
BUILD_ARGS="--build-arg INSTALL_MODE=editable --build-arg DISTRO_NAME=ci-tests"
|
||||||
|
BUILD_ARGS="$BUILD_ARGS --build-arg BASE_IMAGE=$BASE_IMAGE"
|
||||||
|
BUILD_ARGS="$BUILD_ARGS --build-arg RUN_CONFIG_PATH=/workspace/src/llama_stack/distributions/ci-tests/run.yaml"
|
||||||
|
if [ -n "${UV_EXTRA_INDEX_URL:-}" ]; then
|
||||||
|
BUILD_ARGS="$BUILD_ARGS --build-arg UV_EXTRA_INDEX_URL=$UV_EXTRA_INDEX_URL"
|
||||||
|
fi
|
||||||
|
if [ -n "${UV_INDEX_STRATEGY:-}" ]; then
|
||||||
|
BUILD_ARGS="$BUILD_ARGS --build-arg UV_INDEX_STRATEGY=$UV_INDEX_STRATEGY"
|
||||||
|
fi
|
||||||
docker build . \
|
docker build . \
|
||||||
-f containers/Containerfile \
|
-f containers/Containerfile \
|
||||||
--build-arg INSTALL_MODE=editable \
|
$BUILD_ARGS \
|
||||||
--build-arg DISTRO_NAME=ci-tests \
|
|
||||||
--build-arg BASE_IMAGE="$BASE_IMAGE" \
|
|
||||||
--build-arg RUN_CONFIG_PATH=/workspace/src/llama_stack/distributions/ci-tests/run.yaml \
|
|
||||||
-t llama-stack:ci-tests
|
-t llama-stack:ci-tests
|
||||||
|
|
||||||
- name: Inspect the container image entrypoint
|
- name: Inspect the container image entrypoint
|
||||||
|
|
@ -148,12 +160,18 @@ jobs:
|
||||||
- name: Build UBI9 container image
|
- name: Build UBI9 container image
|
||||||
run: |
|
run: |
|
||||||
BASE_IMAGE=$(yq -r '.distribution_spec.container_image // "registry.access.redhat.com/ubi9:latest"' src/llama_stack/distributions/ci-tests/build.yaml)
|
BASE_IMAGE=$(yq -r '.distribution_spec.container_image // "registry.access.redhat.com/ubi9:latest"' src/llama_stack/distributions/ci-tests/build.yaml)
|
||||||
|
BUILD_ARGS="--build-arg INSTALL_MODE=editable --build-arg DISTRO_NAME=ci-tests"
|
||||||
|
BUILD_ARGS="$BUILD_ARGS --build-arg BASE_IMAGE=$BASE_IMAGE"
|
||||||
|
BUILD_ARGS="$BUILD_ARGS --build-arg RUN_CONFIG_PATH=/workspace/src/llama_stack/distributions/ci-tests/run.yaml"
|
||||||
|
if [ -n "${UV_EXTRA_INDEX_URL:-}" ]; then
|
||||||
|
BUILD_ARGS="$BUILD_ARGS --build-arg UV_EXTRA_INDEX_URL=$UV_EXTRA_INDEX_URL"
|
||||||
|
fi
|
||||||
|
if [ -n "${UV_INDEX_STRATEGY:-}" ]; then
|
||||||
|
BUILD_ARGS="$BUILD_ARGS --build-arg UV_INDEX_STRATEGY=$UV_INDEX_STRATEGY"
|
||||||
|
fi
|
||||||
docker build . \
|
docker build . \
|
||||||
-f containers/Containerfile \
|
-f containers/Containerfile \
|
||||||
--build-arg INSTALL_MODE=editable \
|
$BUILD_ARGS \
|
||||||
--build-arg DISTRO_NAME=ci-tests \
|
|
||||||
--build-arg BASE_IMAGE="$BASE_IMAGE" \
|
|
||||||
--build-arg RUN_CONFIG_PATH=/workspace/src/llama_stack/distributions/ci-tests/run.yaml \
|
|
||||||
-t llama-stack:ci-tests-ubi9
|
-t llama-stack:ci-tests-ubi9
|
||||||
|
|
||||||
- name: Inspect UBI9 image
|
- name: Inspect UBI9 image
|
||||||
|
|
|
||||||
|
|
@ -52,10 +52,6 @@ repos:
|
||||||
additional_dependencies:
|
additional_dependencies:
|
||||||
- black==24.3.0
|
- black==24.3.0
|
||||||
|
|
||||||
- repo: https://github.com/astral-sh/uv-pre-commit
|
|
||||||
rev: 0.7.20
|
|
||||||
hooks:
|
|
||||||
- id: uv-lock
|
|
||||||
|
|
||||||
- repo: https://github.com/pre-commit/mirrors-mypy
|
- repo: https://github.com/pre-commit/mirrors-mypy
|
||||||
rev: v1.18.2
|
rev: v1.18.2
|
||||||
|
|
@ -63,22 +59,13 @@ repos:
|
||||||
- id: mypy
|
- id: mypy
|
||||||
additional_dependencies:
|
additional_dependencies:
|
||||||
- uv==0.6.2
|
- uv==0.6.2
|
||||||
|
- mypy
|
||||||
- pytest
|
- pytest
|
||||||
- rich
|
- rich
|
||||||
- types-requests
|
- types-requests
|
||||||
- pydantic
|
- pydantic
|
||||||
- httpx
|
|
||||||
pass_filenames: false
|
pass_filenames: false
|
||||||
|
|
||||||
- repo: local
|
|
||||||
hooks:
|
|
||||||
- id: mypy-full
|
|
||||||
name: mypy (full type_checking)
|
|
||||||
entry: uv run --group dev --group type_checking mypy
|
|
||||||
language: system
|
|
||||||
pass_filenames: false
|
|
||||||
stages: [manual]
|
|
||||||
|
|
||||||
# - repo: https://github.com/tcort/markdown-link-check
|
# - repo: https://github.com/tcort/markdown-link-check
|
||||||
# rev: v3.11.2
|
# rev: v3.11.2
|
||||||
# hooks:
|
# hooks:
|
||||||
|
|
@ -87,11 +74,26 @@ repos:
|
||||||
|
|
||||||
- repo: local
|
- repo: local
|
||||||
hooks:
|
hooks:
|
||||||
|
- id: uv-lock
|
||||||
|
name: uv-lock
|
||||||
|
additional_dependencies:
|
||||||
|
- uv==0.7.20
|
||||||
|
entry: ./scripts/uv-run-with-index.sh lock
|
||||||
|
language: python
|
||||||
|
pass_filenames: false
|
||||||
|
require_serial: true
|
||||||
|
files: ^(pyproject\.toml|uv\.lock)$
|
||||||
|
- id: mypy-full
|
||||||
|
name: mypy (full type_checking)
|
||||||
|
entry: ./scripts/uv-run-with-index.sh run --group dev --group type_checking mypy
|
||||||
|
language: system
|
||||||
|
pass_filenames: false
|
||||||
|
stages: [manual]
|
||||||
- id: distro-codegen
|
- id: distro-codegen
|
||||||
name: Distribution Template Codegen
|
name: Distribution Template Codegen
|
||||||
additional_dependencies:
|
additional_dependencies:
|
||||||
- uv==0.7.8
|
- uv==0.7.8
|
||||||
entry: uv run --group codegen ./scripts/distro_codegen.py
|
entry: ./scripts/uv-run-with-index.sh run --group codegen ./scripts/distro_codegen.py
|
||||||
language: python
|
language: python
|
||||||
pass_filenames: false
|
pass_filenames: false
|
||||||
require_serial: true
|
require_serial: true
|
||||||
|
|
@ -100,7 +102,7 @@ repos:
|
||||||
name: Provider Codegen
|
name: Provider Codegen
|
||||||
additional_dependencies:
|
additional_dependencies:
|
||||||
- uv==0.7.8
|
- uv==0.7.8
|
||||||
entry: uv run --group codegen ./scripts/provider_codegen.py
|
entry: ./scripts/uv-run-with-index.sh run --group codegen ./scripts/provider_codegen.py
|
||||||
language: python
|
language: python
|
||||||
pass_filenames: false
|
pass_filenames: false
|
||||||
require_serial: true
|
require_serial: true
|
||||||
|
|
@ -109,7 +111,7 @@ repos:
|
||||||
name: API Spec Codegen
|
name: API Spec Codegen
|
||||||
additional_dependencies:
|
additional_dependencies:
|
||||||
- uv==0.7.8
|
- uv==0.7.8
|
||||||
entry: sh -c 'uv run ./docs/openapi_generator/run_openapi_generator.sh > /dev/null'
|
entry: sh -c './scripts/uv-run-with-index.sh run ./docs/openapi_generator/run_openapi_generator.sh > /dev/null'
|
||||||
language: python
|
language: python
|
||||||
pass_filenames: false
|
pass_filenames: false
|
||||||
require_serial: true
|
require_serial: true
|
||||||
|
|
@ -150,7 +152,7 @@ repos:
|
||||||
name: Generate CI documentation
|
name: Generate CI documentation
|
||||||
additional_dependencies:
|
additional_dependencies:
|
||||||
- uv==0.7.8
|
- uv==0.7.8
|
||||||
entry: uv run ./scripts/gen-ci-docs.py
|
entry: ./scripts/uv-run-with-index.sh run ./scripts/gen-ci-docs.py
|
||||||
language: python
|
language: python
|
||||||
pass_filenames: false
|
pass_filenames: false
|
||||||
require_serial: true
|
require_serial: true
|
||||||
|
|
@ -162,6 +164,7 @@ repos:
|
||||||
files: ^src/llama_stack/ui/.*\.(ts|tsx)$
|
files: ^src/llama_stack/ui/.*\.(ts|tsx)$
|
||||||
pass_filenames: false
|
pass_filenames: false
|
||||||
require_serial: true
|
require_serial: true
|
||||||
|
|
||||||
- id: check-log-usage
|
- id: check-log-usage
|
||||||
name: Ensure 'llama_stack.log' usage for logging
|
name: Ensure 'llama_stack.log' usage for logging
|
||||||
entry: bash
|
entry: bash
|
||||||
|
|
@ -197,6 +200,7 @@ repos:
|
||||||
echo;
|
echo;
|
||||||
exit 1;
|
exit 1;
|
||||||
} || true
|
} || true
|
||||||
|
|
||||||
ci:
|
ci:
|
||||||
autofix_commit_msg: 🎨 [pre-commit.ci] Auto format from pre-commit.com hooks
|
autofix_commit_msg: 🎨 [pre-commit.ci] Auto format from pre-commit.com hooks
|
||||||
autoupdate_commit_msg: ⬆ [pre-commit.ci] pre-commit autoupdate
|
autoupdate_commit_msg: ⬆ [pre-commit.ci] pre-commit autoupdate
|
||||||
|
|
|
||||||
|
|
@ -19,6 +19,8 @@ ARG KEEP_WORKSPACE=""
|
||||||
ARG DISTRO_NAME="starter"
|
ARG DISTRO_NAME="starter"
|
||||||
ARG RUN_CONFIG_PATH=""
|
ARG RUN_CONFIG_PATH=""
|
||||||
ARG UV_HTTP_TIMEOUT=500
|
ARG UV_HTTP_TIMEOUT=500
|
||||||
|
ARG UV_EXTRA_INDEX_URL=""
|
||||||
|
ARG UV_INDEX_STRATEGY=""
|
||||||
ENV UV_HTTP_TIMEOUT=${UV_HTTP_TIMEOUT}
|
ENV UV_HTTP_TIMEOUT=${UV_HTTP_TIMEOUT}
|
||||||
ENV PYTHONDONTWRITEBYTECODE=1
|
ENV PYTHONDONTWRITEBYTECODE=1
|
||||||
ENV PIP_DISABLE_PIP_VERSION_CHECK=1
|
ENV PIP_DISABLE_PIP_VERSION_CHECK=1
|
||||||
|
|
@ -45,7 +47,7 @@ RUN set -eux; \
|
||||||
exit 1; \
|
exit 1; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
RUN pip install --no-cache uv
|
RUN pip install --no-cache-dir uv
|
||||||
ENV UV_SYSTEM_PYTHON=1
|
ENV UV_SYSTEM_PYTHON=1
|
||||||
|
|
||||||
ENV INSTALL_MODE=${INSTALL_MODE}
|
ENV INSTALL_MODE=${INSTALL_MODE}
|
||||||
|
|
@ -68,41 +70,50 @@ RUN set -eux; \
|
||||||
echo "LLAMA_STACK_CLIENT_DIR is set but $LLAMA_STACK_CLIENT_DIR does not exist" >&2; \
|
echo "LLAMA_STACK_CLIENT_DIR is set but $LLAMA_STACK_CLIENT_DIR does not exist" >&2; \
|
||||||
exit 1; \
|
exit 1; \
|
||||||
fi; \
|
fi; \
|
||||||
uv pip install --no-cache -e "$LLAMA_STACK_CLIENT_DIR"; \
|
uv pip install --no-cache-dir -e "$LLAMA_STACK_CLIENT_DIR"; \
|
||||||
fi;
|
fi;
|
||||||
|
|
||||||
# Install llama-stack
|
# Install llama-stack
|
||||||
|
# Use UV_EXTRA_INDEX_URL inline only for this step to avoid affecting distribution deps
|
||||||
RUN set -eux; \
|
RUN set -eux; \
|
||||||
if [ "$INSTALL_MODE" = "editable" ]; then \
|
if [ "$INSTALL_MODE" = "editable" ]; then \
|
||||||
if [ ! -d "$LLAMA_STACK_DIR" ]; then \
|
if [ ! -d "$LLAMA_STACK_DIR" ]; then \
|
||||||
echo "INSTALL_MODE=editable requires LLAMA_STACK_DIR to point to a directory inside the build context" >&2; \
|
echo "INSTALL_MODE=editable requires LLAMA_STACK_DIR to point to a directory inside the build context" >&2; \
|
||||||
exit 1; \
|
exit 1; \
|
||||||
fi; \
|
fi; \
|
||||||
uv pip install --no-cache -e "$LLAMA_STACK_DIR"; \
|
if [ -n "$UV_EXTRA_INDEX_URL" ] && [ -n "$UV_INDEX_STRATEGY" ]; then \
|
||||||
elif [ "$INSTALL_MODE" = "test-pypi" ]; then \
|
UV_EXTRA_INDEX_URL="$UV_EXTRA_INDEX_URL" UV_INDEX_STRATEGY="$UV_INDEX_STRATEGY" \
|
||||||
uv pip install --no-cache fastapi libcst; \
|
uv pip install --no-cache-dir -e "$LLAMA_STACK_DIR"; \
|
||||||
if [ -n "$TEST_PYPI_VERSION" ]; then \
|
|
||||||
uv pip install --no-cache --extra-index-url https://test.pypi.org/simple/ --index-strategy unsafe-best-match "llama-stack==$TEST_PYPI_VERSION"; \
|
|
||||||
else \
|
else \
|
||||||
uv pip install --no-cache --extra-index-url https://test.pypi.org/simple/ --index-strategy unsafe-best-match llama-stack; \
|
unset UV_EXTRA_INDEX_URL UV_INDEX_STRATEGY; \
|
||||||
|
uv pip install --no-cache-dir -e "$LLAMA_STACK_DIR"; \
|
||||||
|
fi; \
|
||||||
|
elif [ "$INSTALL_MODE" = "test-pypi" ]; then \
|
||||||
|
uv pip install --no-cache-dir fastapi libcst; \
|
||||||
|
if [ -n "$TEST_PYPI_VERSION" ]; then \
|
||||||
|
uv pip install --no-cache-dir --extra-index-url https://test.pypi.org/simple/ --index-strategy unsafe-best-match "llama-stack==$TEST_PYPI_VERSION"; \
|
||||||
|
else \
|
||||||
|
uv pip install --no-cache-dir --extra-index-url https://test.pypi.org/simple/ --index-strategy unsafe-best-match llama-stack; \
|
||||||
fi; \
|
fi; \
|
||||||
else \
|
else \
|
||||||
if [ -n "$PYPI_VERSION" ]; then \
|
if [ -n "$PYPI_VERSION" ]; then \
|
||||||
uv pip install --no-cache "llama-stack==$PYPI_VERSION"; \
|
uv pip install --no-cache-dir "llama-stack==$PYPI_VERSION"; \
|
||||||
else \
|
else \
|
||||||
uv pip install --no-cache llama-stack; \
|
uv pip install --no-cache-dir llama-stack; \
|
||||||
fi; \
|
fi; \
|
||||||
fi;
|
fi;
|
||||||
|
|
||||||
# Install the dependencies for the distribution
|
# Install the dependencies for the distribution
|
||||||
|
# Explicitly unset UV index env vars to ensure we only use PyPI for distribution deps
|
||||||
RUN set -eux; \
|
RUN set -eux; \
|
||||||
|
unset UV_EXTRA_INDEX_URL UV_INDEX_STRATEGY; \
|
||||||
if [ -z "$DISTRO_NAME" ]; then \
|
if [ -z "$DISTRO_NAME" ]; then \
|
||||||
echo "DISTRO_NAME must be provided" >&2; \
|
echo "DISTRO_NAME must be provided" >&2; \
|
||||||
exit 1; \
|
exit 1; \
|
||||||
fi; \
|
fi; \
|
||||||
deps="$(llama stack list-deps "$DISTRO_NAME")"; \
|
deps="$(llama stack list-deps "$DISTRO_NAME")"; \
|
||||||
if [ -n "$deps" ]; then \
|
if [ -n "$deps" ]; then \
|
||||||
printf '%s\n' "$deps" | xargs -L1 uv pip install --no-cache; \
|
printf '%s\n' "$deps" | xargs -L1 uv pip install --no-cache-dir; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Cleanup
|
# Cleanup
|
||||||
|
|
|
||||||
|
|
@ -215,6 +215,16 @@ build_image() {
|
||||||
--build-arg "LLAMA_STACK_DIR=/workspace"
|
--build-arg "LLAMA_STACK_DIR=/workspace"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# Pass UV index configuration for release branches
|
||||||
|
if [[ -n "${UV_EXTRA_INDEX_URL:-}" ]]; then
|
||||||
|
echo "Adding UV_EXTRA_INDEX_URL to docker build: $UV_EXTRA_INDEX_URL"
|
||||||
|
build_cmd+=(--build-arg "UV_EXTRA_INDEX_URL=$UV_EXTRA_INDEX_URL")
|
||||||
|
fi
|
||||||
|
if [[ -n "${UV_INDEX_STRATEGY:-}" ]]; then
|
||||||
|
echo "Adding UV_INDEX_STRATEGY to docker build: $UV_INDEX_STRATEGY"
|
||||||
|
build_cmd+=(--build-arg "UV_INDEX_STRATEGY=$UV_INDEX_STRATEGY")
|
||||||
|
fi
|
||||||
|
|
||||||
if ! "${build_cmd[@]}"; then
|
if ! "${build_cmd[@]}"; then
|
||||||
echo "❌ Failed to build Docker image"
|
echo "❌ Failed to build Docker image"
|
||||||
exit 1
|
exit 1
|
||||||
|
|
|
||||||
|
|
@ -279,6 +279,16 @@ if [[ "$STACK_CONFIG" == *"docker:"* && "$COLLECT_ONLY" == false ]]; then
|
||||||
--build-arg "LLAMA_STACK_DIR=/workspace"
|
--build-arg "LLAMA_STACK_DIR=/workspace"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# Pass UV index configuration for release branches
|
||||||
|
if [[ -n "${UV_EXTRA_INDEX_URL:-}" ]]; then
|
||||||
|
echo "Adding UV_EXTRA_INDEX_URL to docker build: $UV_EXTRA_INDEX_URL"
|
||||||
|
build_cmd+=(--build-arg "UV_EXTRA_INDEX_URL=$UV_EXTRA_INDEX_URL")
|
||||||
|
fi
|
||||||
|
if [[ -n "${UV_INDEX_STRATEGY:-}" ]]; then
|
||||||
|
echo "Adding UV_INDEX_STRATEGY to docker build: $UV_INDEX_STRATEGY"
|
||||||
|
build_cmd+=(--build-arg "UV_INDEX_STRATEGY=$UV_INDEX_STRATEGY")
|
||||||
|
fi
|
||||||
|
|
||||||
if ! "${build_cmd[@]}"; then
|
if ! "${build_cmd[@]}"; then
|
||||||
echo "❌ Failed to build Docker image"
|
echo "❌ Failed to build Docker image"
|
||||||
exit 1
|
exit 1
|
||||||
|
|
|
||||||
42
scripts/uv-run-with-index.sh
Executable file
42
scripts/uv-run-with-index.sh
Executable file
|
|
@ -0,0 +1,42 @@
|
||||||
|
#!/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.
|
||||||
|
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
# Detect current branch and target branch
|
||||||
|
# In GitHub Actions, use GITHUB_REF/GITHUB_BASE_REF
|
||||||
|
if [[ -n "${GITHUB_REF:-}" ]]; then
|
||||||
|
BRANCH="${GITHUB_REF#refs/heads/}"
|
||||||
|
else
|
||||||
|
BRANCH=$(git rev-parse --abbrev-ref HEAD 2>/dev/null || echo "")
|
||||||
|
fi
|
||||||
|
|
||||||
|
# For PRs, check the target branch
|
||||||
|
if [[ -n "${GITHUB_BASE_REF:-}" ]]; then
|
||||||
|
TARGET_BRANCH="${GITHUB_BASE_REF}"
|
||||||
|
else
|
||||||
|
TARGET_BRANCH=$(git rev-parse --abbrev-ref HEAD@{upstream} 2>/dev/null | sed 's|origin/||' || echo "")
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check if on a release branch or targeting one, or LLAMA_STACK_RELEASE_MODE is set
|
||||||
|
IS_RELEASE=false
|
||||||
|
if [[ "$BRANCH" =~ ^release-[0-9]+\.[0-9]+\.x$ ]]; then
|
||||||
|
IS_RELEASE=true
|
||||||
|
elif [[ "$TARGET_BRANCH" =~ ^release-[0-9]+\.[0-9]+\.x$ ]]; then
|
||||||
|
IS_RELEASE=true
|
||||||
|
elif [[ "${LLAMA_STACK_RELEASE_MODE:-}" == "true" ]]; then
|
||||||
|
IS_RELEASE=true
|
||||||
|
fi
|
||||||
|
|
||||||
|
# On release branches, use test.pypi as extra index for RC versions
|
||||||
|
if [[ "$IS_RELEASE" == "true" ]]; then
|
||||||
|
export UV_EXTRA_INDEX_URL="https://test.pypi.org/simple/"
|
||||||
|
export UV_INDEX_STRATEGY="unsafe-best-match"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Run uv with all arguments passed through
|
||||||
|
exec uv "$@"
|
||||||
Loading…
Add table
Add a link
Reference in a new issue