mirror of
				https://github.com/meta-llama/llama-stack.git
				synced 2025-10-25 01:01:13 +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.
		
			
				
	
	
		
			66 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
	
		
			2.2 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| name: 'Setup Test Environment'
 | |
| description: 'Common setup steps for integration tests including dependencies, providers, and build'
 | |
| 
 | |
| inputs:
 | |
|   python-version:
 | |
|     description: 'Python version to use'
 | |
|     required: true
 | |
|   client-version:
 | |
|     description: 'Client version (latest or published)'
 | |
|     required: true
 | |
|   provider:
 | |
|     description: 'Provider to setup (ollama or vllm)'
 | |
|     required: true
 | |
|     default: 'ollama'
 | |
|   run-vision-tests:
 | |
|     description: 'Whether to setup provider for vision tests'
 | |
|     required: false
 | |
|     default: 'false'
 | |
|   inference-mode:
 | |
|     description: 'Inference mode (record or replay)'
 | |
|     required: true
 | |
| 
 | |
| runs:
 | |
|   using: 'composite'
 | |
|   steps:
 | |
|     - name: Install dependencies
 | |
|       uses: ./.github/actions/setup-runner
 | |
|       with:
 | |
|         python-version: ${{ inputs.python-version }}
 | |
|         client-version: ${{ inputs.client-version }}
 | |
| 
 | |
|     - name: Setup ollama
 | |
|       if: ${{ inputs.provider == 'ollama' && inputs.inference-mode == 'record' }}
 | |
|       uses: ./.github/actions/setup-ollama
 | |
|       with:
 | |
|         run-vision-tests: ${{ inputs.run-vision-tests }}
 | |
| 
 | |
|     - name: Setup vllm
 | |
|       if: ${{ inputs.provider == 'vllm' && inputs.inference-mode == 'record' }}
 | |
|       uses: ./.github/actions/setup-vllm
 | |
| 
 | |
|     - name: Build Llama Stack
 | |
|       shell: bash
 | |
|       run: |
 | |
|         # Install llama-stack-client-python based on the client-version input
 | |
|         if [ "${{ inputs.client-version }}" = "latest" ]; then
 | |
|           echo "Installing latest llama-stack-client-python from main branch"
 | |
|           export LLAMA_STACK_CLIENT_DIR=git+https://github.com/llamastack/llama-stack-client-python.git@main
 | |
|         elif [ "${{ inputs.client-version }}" = "published" ]; then
 | |
|           echo "Installing published llama-stack-client-python from PyPI"
 | |
|           unset LLAMA_STACK_CLIENT_DIR
 | |
|         else
 | |
|           echo "Invalid client-version: ${{ inputs.client-version }}"
 | |
|           exit 1
 | |
|         fi
 | |
| 
 | |
|         echo "Building Llama Stack"
 | |
| 
 | |
|         LLAMA_STACK_DIR=. \
 | |
|           uv run --no-sync llama stack build --template ci-tests --image-type venv
 | |
| 
 | |
|     - name: Configure git for commits
 | |
|       shell: bash
 | |
|       run: |
 | |
|         git config --local user.email "github-actions[bot]@users.noreply.github.com"
 | |
|         git config --local user.name "github-actions[bot]"
 |