test_multimodal_broadcast.py 1.72 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
"""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"]

if model.startswith("llava-hf/llava"):
23
    from ..models.test_llava import models, run_test
24
elif model.startswith("microsoft/Phi-3-vision"):
25
    from ..models.test_phi3v 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
        size_factors=[1.0],
49
50
        dtype=dtype,
        max_tokens=max_tokens,
51
        num_logprobs=num_logprobs,
52
53
54
        tensor_parallel_size=tensor_parallel_size,
        distributed_executor_backend=distributed_executor_backend,
    )