test_granite.py 1.13 KB
Newer Older
1
# SPDX-License-Identifier: Apache-2.0
2
# SPDX-FileCopyrightText: Copyright contributors to the vLLM project
Shawn Tan's avatar
Shawn Tan committed
3
4
import pytest

5
from ...utils import check_logprobs_close
Shawn Tan's avatar
Shawn Tan committed
6
7

MODELS = [
8
    # TODO(sang): Sliding window should be tested separately.
Shawn Tan's avatar
Shawn Tan committed
9
    "ibm/PowerLM-3b",
10
    "ibm/PowerMoE-3b",
Shawn Tan's avatar
Shawn Tan committed
11
12
13
14
15
16
17
]


@pytest.mark.parametrize("model", MODELS)
@pytest.mark.parametrize("dtype", ["bfloat16"])
@pytest.mark.parametrize("max_tokens", [64])
@pytest.mark.parametrize("num_logprobs", [5])
18
@pytest.mark.cpu_model
Shawn Tan's avatar
Shawn Tan committed
19
20
21
22
23
24
25
26
27
28
29
def test_models(
    hf_runner,
    vllm_runner,
    example_prompts,
    model: str,
    dtype: str,
    max_tokens: int,
    num_logprobs: int,
) -> None:
    with hf_runner(model, dtype=dtype) as hf_model:
        hf_outputs = hf_model.generate_greedy_logprobs_limit(
30
31
            example_prompts, max_tokens, num_logprobs
        )
Shawn Tan's avatar
Shawn Tan committed
32
33
34

    with vllm_runner(model, dtype=dtype) as vllm_model:
        vllm_outputs = vllm_model.generate_greedy_logprobs(
35
36
            example_prompts, max_tokens, num_logprobs
        )
Shawn Tan's avatar
Shawn Tan committed
37
38
39
40
41
42
    check_logprobs_close(
        outputs_0_lst=hf_outputs,
        outputs_1_lst=vllm_outputs,
        name_0="hf",
        name_1="vllm",
    )