test_multimodal_broadcast.py 1.79 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
"""Compare the outputs of HF and distributed vLLM when using greedy sampling.
The second test will hang if more than one test is run per command, so we need
to run the tests one by one. The solution is to pass arguments (model name) by
environment variables.

Run:
```sh
TEST_DIST_MODEL=llava-hf/llava-1.5-7b-hf \
    test_multimodal_broadcast.py
TEST_DIST_MODEL=microsoft/Phi-3-vision-128k-instruct \
    test_multimodal_broadcast.py
```
"""
import os

import pytest

from vllm.utils import cuda_device_count_stateless

model = os.environ["TEST_DIST_MODEL"]

22
if model.startswith("llava-hf/llava-1.5"):
23
    from ..models.test_llava import models, run_test
24
25
elif model.startswith("llava-hf/llava-v1.6"):
    from ..models.test_llava_next import models, run_test
26
27
28
29
30
31
32
else:
    raise NotImplementedError(f"Unsupported model: {model}")


@pytest.mark.parametrize("tensor_parallel_size", [2])
@pytest.mark.parametrize("dtype", ["half"])
@pytest.mark.parametrize("max_tokens", [128])
33
@pytest.mark.parametrize("num_logprobs", [5])
34
def test_models(hf_runner, vllm_runner, image_assets,
35
36
                tensor_parallel_size: int, dtype: str, max_tokens: int,
                num_logprobs: int) -> None:
37
38
39
40
41
42
43
44
45
46
    if cuda_device_count_stateless() < tensor_parallel_size:
        pytest.skip(
            f"Need at least {tensor_parallel_size} GPUs to run the test.")

    distributed_executor_backend = os.getenv("DISTRIBUTED_EXECUTOR_BACKEND")

    run_test(
        hf_runner,
        vllm_runner,
        image_assets,
47
        model=models[0],
48
49
        # So that LLaVA-NeXT processor may return nested list
        size_factors=[0.25, 0.5, 1.0],
50
51
        dtype=dtype,
        max_tokens=max_tokens,
52
        num_logprobs=num_logprobs,
53
54
55
        tensor_parallel_size=tensor_parallel_size,
        distributed_executor_backend=distributed_executor_backend,
    )