mirror of
				https://github.com/meta-llama/llama-stack.git
				synced 2025-10-25 09:05:37 +00:00 
			
		
		
		
	
		
			Some checks failed
		
		
	
	SqlStore Integration Tests / test-postgres (3.13) (push) Failing after 1s
				
			Test External Providers Installed via Module / test-external-providers-from-module (venv) (push) Has been skipped
				
			Python Package Build Test / build (3.12) (push) Failing after 3s
				
			Integration Tests (Replay) / Integration Tests (, , , client=, ) (push) Failing after 3s
				
			SqlStore Integration Tests / test-postgres (3.12) (push) Failing after 7s
				
			Integration Auth Tests / test-matrix (oauth2_token) (push) Failing after 9s
				
			Unit Tests / unit-tests (3.12) (push) Failing after 7s
				
			Python Package Build Test / build (3.13) (push) Failing after 12s
				
			Unit Tests / unit-tests (3.13) (push) Failing after 13s
				
			Test External API and Providers / test-external (venv) (push) Failing after 19s
				
			Vector IO Integration Tests / test-matrix (push) Failing after 22s
				
			API Conformance Tests / check-schema-compatibility (push) Successful in 31s
				
			UI Tests / ui-tests (22) (push) Successful in 1m35s
				
			Pre-commit / pre-commit (push) Successful in 2m27s
				
			
		
			
				
	
	
		
			88 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| name: Integration Tests (Replay)
 | |
| 
 | |
| run-name: Run the integration test suites from tests/integration in replay mode
 | |
| 
 | |
| on:
 | |
|   push:
 | |
|     branches: [ main ]
 | |
|   pull_request:
 | |
|     branches: [ main ]
 | |
|     types: [opened, synchronize, reopened]
 | |
|     paths:
 | |
|       - 'llama_stack/**'
 | |
|       - '!llama_stack/ui/**'
 | |
|       - 'tests/**'
 | |
|       - 'uv.lock'
 | |
|       - 'pyproject.toml'
 | |
|       - '.github/workflows/integration-tests.yml' # This workflow
 | |
|       - '.github/actions/setup-ollama/action.yml'
 | |
|       - '.github/actions/setup-test-environment/action.yml'
 | |
|       - '.github/actions/run-and-record-tests/action.yml'
 | |
|   schedule:
 | |
|     # If changing the cron schedule, update the provider in the test-matrix job
 | |
|     - cron: '0 0 * * *'  # (test latest client) Daily at 12 AM UTC
 | |
|     - cron: '1 0 * * 0'  # (test vllm) Weekly on Sunday at 1 AM UTC
 | |
|   workflow_dispatch:
 | |
|     inputs:
 | |
|       test-all-client-versions:
 | |
|         description: 'Test against both the latest and published versions'
 | |
|         type: boolean
 | |
|         default: false
 | |
|       test-setup:
 | |
|         description: 'Test against a specific setup'
 | |
|         type: string
 | |
|         default: 'ollama'
 | |
| 
 | |
| concurrency:
 | |
|   # Skip concurrency for pushes to main - each commit should be tested independently
 | |
|   group: ${{ github.workflow }}-${{ github.ref == 'refs/heads/main' && github.run_id || github.ref }}
 | |
|   cancel-in-progress: true
 | |
| 
 | |
| jobs:
 | |
| 
 | |
|   run-replay-mode-tests:
 | |
|     runs-on: ubuntu-latest
 | |
|     name: ${{ format('Integration Tests ({0}, {1}, {2}, client={3}, {4})', matrix.client-type, matrix.config.setup, matrix.python-version, matrix.client-version, matrix.config.suite) }}
 | |
| 
 | |
|     strategy:
 | |
|       fail-fast: false
 | |
|       matrix:
 | |
|         client-type: [library, server, docker]
 | |
|         # Use Python 3.13 only on nightly schedule (daily latest client test), otherwise use 3.12
 | |
|         python-version: ${{ github.event.schedule == '0 0 * * *' && fromJSON('["3.12", "3.13"]') || fromJSON('["3.12"]') }}
 | |
|         client-version: ${{ (github.event.schedule == '0 0 * * *' || github.event.inputs.test-all-client-versions == 'true') && fromJSON('["published", "latest"]') || fromJSON('["latest"]') }}
 | |
|         # Define (setup, suite) pairs - they are always matched and cannot be independent
 | |
|         # Weekly schedule (Sun 1 AM): vllm+base
 | |
|         # Input test-setup=ollama-vision: ollama-vision+vision
 | |
|         # Default (including test-setup=ollama): ollama+base, ollama-vision+vision, gpt+responses
 | |
|         config: >-
 | |
|           ${{
 | |
|             github.event.schedule == '1 0 * * 0'
 | |
|               && fromJSON('[{"setup": "vllm", "suite": "base"}]')
 | |
|             || github.event.inputs.test-setup == 'ollama-vision'
 | |
|               && fromJSON('[{"setup": "ollama-vision", "suite": "vision"}]')
 | |
|             || fromJSON('[{"setup": "ollama", "suite": "base"}, {"setup": "ollama-vision", "suite": "vision"}]')
 | |
|           }}
 | |
| 
 | |
|     steps:
 | |
|       - name: Checkout repository
 | |
|         uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0
 | |
| 
 | |
|       - name: Setup test environment
 | |
|         uses: ./.github/actions/setup-test-environment
 | |
|         with:
 | |
|           python-version: ${{ matrix.python-version }}
 | |
|           client-version: ${{ matrix.client-version }}
 | |
|           setup: ${{ matrix.config.setup }}
 | |
|           suite: ${{ matrix.config.suite }}
 | |
|           inference-mode: 'replay'
 | |
| 
 | |
|       - name: Run tests
 | |
|         uses: ./.github/actions/run-and-record-tests
 | |
|         env:
 | |
|           OPENAI_API_KEY: dummy
 | |
|         with:
 | |
|           stack-config: ${{ matrix.client-type == 'library' && 'ci-tests' || matrix.client-type == 'server' && 'server:ci-tests' || 'docker:ci-tests' }}
 | |
|           setup: ${{ matrix.config.setup }}
 | |
|           inference-mode: 'replay'
 | |
|           suite: ${{ matrix.config.suite }}
 |