|
2 | 2 |
|
3 | 3 | import httpx |
4 | 4 | import pytest |
| 5 | +from pytest_mock import MockerFixture |
5 | 6 |
|
| 7 | +from pydantic_ai._json_schema import InlineDefsJsonSchemaTransformer |
6 | 8 | from pydantic_ai.exceptions import UserError |
| 9 | +from pydantic_ai.profiles.deepseek import deepseek_model_profile |
| 10 | +from pydantic_ai.profiles.harmony import harmony_model_profile |
| 11 | +from pydantic_ai.profiles.meta import meta_model_profile |
| 12 | +from pydantic_ai.profiles.mistral import mistral_model_profile |
| 13 | +from pydantic_ai.profiles.openai import OpenAIJsonSchemaTransformer |
| 14 | +from pydantic_ai.profiles.qwen import qwen_model_profile |
7 | 15 |
|
8 | 16 | from ..conftest import TestEnv, try_import |
9 | 17 |
|
@@ -51,3 +59,51 @@ def test_ovhcloud_pass_http_client(): |
51 | 59 | provider = OVHcloudProvider(api_key='your-api-key', http_client=http_client) |
52 | 60 | assert isinstance(provider.client, openai.AsyncOpenAI) |
53 | 61 | assert provider.client.api_key == 'your-api-key' |
| 62 | + |
| 63 | + |
| 64 | +def test_ovhcloud_model_profile(mocker: MockerFixture): |
| 65 | + provider = OVHcloudProvider(api_key='your-api-key') |
| 66 | + |
| 67 | + ns = 'pydantic_ai.providers.ovhcloud' |
| 68 | + |
| 69 | + # Mock all profile functions |
| 70 | + deepseek_mock = mocker.patch(f'{ns}.deepseek_model_profile', wraps=deepseek_model_profile) |
| 71 | + harmony_mock = mocker.patch(f'{ns}.harmony_model_profile', wraps=harmony_model_profile) |
| 72 | + meta_mock = mocker.patch(f'{ns}.meta_model_profile', wraps=meta_model_profile) |
| 73 | + mistral_mock = mocker.patch(f'{ns}.mistral_model_profile', wraps=mistral_model_profile) |
| 74 | + qwen_mock = mocker.patch(f'{ns}.qwen_model_profile', wraps=qwen_model_profile) |
| 75 | + |
| 76 | + # Test deepseek provider |
| 77 | + profile = provider.model_profile('DeepSeek-R1-Distill-Llama-70B') |
| 78 | + deepseek_mock.assert_called_with('DeepSeek-R1-Distill-Llama-70B') |
| 79 | + assert profile is not None |
| 80 | + assert profile.json_schema_transformer == OpenAIJsonSchemaTransformer |
| 81 | + |
| 82 | + # Test harmony (for openai gpt-oss) provider |
| 83 | + profile = provider.model_profile('gpt-oss-120b') |
| 84 | + harmony_mock.assert_called_with('gpt-oss-120b') |
| 85 | + assert profile is not None |
| 86 | + assert profile.json_schema_transformer == OpenAIJsonSchemaTransformer |
| 87 | + |
| 88 | + # Test meta provider |
| 89 | + meta_profile = provider.model_profile('Llama-3.3-70B-Instruct') |
| 90 | + meta_mock.assert_called_with('Llama-3.3-70B-Instruct') |
| 91 | + assert meta_profile is not None |
| 92 | + assert meta_profile.json_schema_transformer == InlineDefsJsonSchemaTransformer |
| 93 | + |
| 94 | + # Test mistral provider |
| 95 | + profile = provider.model_profile('Mistral-Small-3.2-24B-Instruct-2506') |
| 96 | + mistral_mock.assert_called_with('Mistral-Small-3.2-24B-Instruct-2506') |
| 97 | + assert profile is not None |
| 98 | + assert profile.json_schema_transformer == OpenAIJsonSchemaTransformer |
| 99 | + |
| 100 | + # Test qwen provider |
| 101 | + qwen_profile = provider.model_profile('Qwen3-32B') |
| 102 | + qwen_mock.assert_called_with('Qwen3-32B') |
| 103 | + assert qwen_profile is not None |
| 104 | + assert qwen_profile.json_schema_transformer == InlineDefsJsonSchemaTransformer |
| 105 | + |
| 106 | + # Test unknown provider |
| 107 | + unknown_profile = provider.model_profile('unknown-model') |
| 108 | + assert unknown_profile is not None |
| 109 | + assert unknown_profile.json_schema_transformer == OpenAIJsonSchemaTransformer |
0 commit comments