mirror of
				https://github.com/meta-llama/llama-stack.git
				synced 2025-10-24 16:57:21 +00:00 
			
		
		
		
	# What does this PR do? simplify Ollama inference adapter by - - moving image_url download code to OpenAIMixin - being a ModelRegistryHelper instead of having one (mypy blocks check_model_availability method assignment) ## Test Plan - add unit tests for new download feature - add integration tests for openai_chat_completion w/ image_url (close test gap)
		
			
				
	
	
		
			77 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # 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.
 | |
| 
 | |
| 
 | |
| import base64
 | |
| import pathlib
 | |
| 
 | |
| import pytest
 | |
| 
 | |
| 
 | |
| @pytest.fixture
 | |
| def image_path():
 | |
|     return pathlib.Path(__file__).parent / "dog.png"
 | |
| 
 | |
| 
 | |
| @pytest.fixture
 | |
| def base64_image_data(image_path):
 | |
|     return base64.b64encode(image_path.read_bytes()).decode("utf-8")
 | |
| 
 | |
| 
 | |
| async def test_openai_chat_completion_image_url(openai_client, vision_model_id):
 | |
|     message = {
 | |
|         "role": "user",
 | |
|         "content": [
 | |
|             {
 | |
|                 "type": "image_url",
 | |
|                 "image_url": {
 | |
|                     "url": "https://raw.githubusercontent.com/meta-llama/llama-stack/main/tests/integration/inference/dog.png"
 | |
|                 },
 | |
|             },
 | |
|             {
 | |
|                 "type": "text",
 | |
|                 "text": "Describe what is in this image.",
 | |
|             },
 | |
|         ],
 | |
|     }
 | |
| 
 | |
|     response = openai_client.chat.completions.create(
 | |
|         model=vision_model_id,
 | |
|         messages=[message],
 | |
|         stream=False,
 | |
|     )
 | |
| 
 | |
|     message_content = response.choices[0].message.content.lower().strip()
 | |
|     assert len(message_content) > 0
 | |
|     assert any(expected in message_content for expected in {"dog", "puppy", "pup"})
 | |
| 
 | |
| 
 | |
| async def test_openai_chat_completion_image_data(openai_client, vision_model_id, base64_image_data):
 | |
|     message = {
 | |
|         "role": "user",
 | |
|         "content": [
 | |
|             {
 | |
|                 "type": "image_url",
 | |
|                 "image_url": {
 | |
|                     "url": f"data:image/png;base64,{base64_image_data}",
 | |
|                 },
 | |
|             },
 | |
|             {
 | |
|                 "type": "text",
 | |
|                 "text": "Describe what is in this image.",
 | |
|             },
 | |
|         ],
 | |
|     }
 | |
| 
 | |
|     response = openai_client.chat.completions.create(
 | |
|         model=vision_model_id,
 | |
|         messages=[message],
 | |
|         stream=False,
 | |
|     )
 | |
| 
 | |
|     message_content = response.choices[0].message.content.lower().strip()
 | |
|     assert len(message_content) > 0
 | |
|     assert any(expected in message_content for expected in {"dog", "puppy", "pup"})
 |