test_multimodal.py 2.66 KB
Newer Older
1
# SPDX-License-Identifier: Apache-2.0
2
# SPDX-FileCopyrightText: Copyright contributors to the vLLM project
3
4
5
6

import openai
import pytest

7
from vllm.multimodal.utils import encode_image_base64
8
9
from vllm.platforms import current_platform

10
from ...entrypoints.openai.test_vision import TEST_IMAGE_ASSETS
11
12
13
14
from ...utils import RemoteOpenAIServer


@pytest.fixture(scope="session")
15
def base64_encoded_image(local_asset_server) -> dict[str, str]:
16
    return {
17
18
19
        image_asset: encode_image_base64(
            local_asset_server.get_image_asset(image_asset)
        )
20
        for image_asset in TEST_IMAGE_ASSETS
21
22
23
24
    }


@pytest.mark.asyncio
25
@pytest.mark.skipif(not current_platform.is_tpu(), reason="This test needs a TPU")
26
@pytest.mark.parametrize("model_name", ["llava-hf/llava-1.5-7b-hf"])
27
async def test_basic_vision(model_name: str, base64_encoded_image: dict[str, str]):
28
29
    pytest.skip("Skip this test until it's fixed.")

30
    def whats_in_this_image_msg(b64):
31
32
33
34
35
36
37
38
        return [
            {
                "role": "user",
                "content": [
                    {"type": "text", "text": "What's in this image?"},
                    {
                        "type": "image_url",
                        "image_url": {"url": f"data:image/jpeg;base64,{b64}"},
39
                    },
40
41
42
                ],
            }
        ]
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58

    server_args = [
        "--max-model-len",
        "1024",
        "--max-num-seqs",
        "16",
        "--gpu-memory-utilization",
        "0.95",
        "--trust-remote-code",
        "--max-num-batched-tokens",
        "576",
        # NOTE: max-num-batched-tokens>=mm_item_size
        "--disable_chunked_mm_input",
    ]

    # Server will pre-compile on first startup (takes a long time).
59
60
61
    with RemoteOpenAIServer(
        model_name, server_args, max_wait_seconds=600
    ) as remote_server:
62
63
64
        client: openai.AsyncOpenAI = remote_server.get_async_client()

        # Other requests now should be much faster
65
        for image_url in TEST_IMAGE_ASSETS:
66
            image_base64 = base64_encoded_image[image_url]
67
            chat_completion_from_base64 = await client.chat.completions.create(
68
69
70
                model=model_name,
                messages=whats_in_this_image_msg(image_base64),
                max_completion_tokens=24,
71
72
                temperature=0.0,
            )
73
74
75
76
77
78
79
80
81
            result = chat_completion_from_base64
            assert result
            choice = result.choices[0]
            assert choice.finish_reason == "length"

            message = choice.message
            message = result.choices[0].message
            assert message.content is not None and len(message.content) >= 10
            assert message.role == "assistant"