test_disable_detokenization.py 1.26 KB
Newer Older
1
# SPDX-License-Identifier: Apache-2.0
2
# SPDX-FileCopyrightText: Copyright contributors to the vLLM project
3

4
5
6
7
8
9
import pytest

from vllm.entrypoints.llm import LLM
from vllm.sampling_params import SamplingParams


10
@pytest.mark.skip_v1
11
@pytest.mark.parametrize("model", ["distilbert/distilgpt2"])
12
13
14
15
16
17
18
19
def test_computed_prefix_blocks(model: str):
    # This test checks if the engine generates completions both with and
    # without optional detokenization, that detokenization includes text
    # and no-detokenization doesn't, and that both completions have the same
    # token_ids.
    prompt = (
        "You are a helpful assistant. How do I build a car from cardboard and "
        "paper clips? Is there an easy to follow video tutorial available "
20
21
        "online for free?"
    )
22

23
    llm = LLM(model=model)
24
    sampling_params = SamplingParams(max_tokens=10, temperature=0.0, detokenize=False)
25

26
    outputs_no_detokenization = llm.generate(prompt, sampling_params)[0].outputs[0]
27
    sampling_params.detokenize = True
28
    outputs_with_detokenization = llm.generate(prompt, sampling_params)[0].outputs[0]
29

30
31
32
    assert outputs_no_detokenization.text == ""
    assert outputs_with_detokenization.text != ""
    assert outputs_no_detokenization.token_ids == outputs_with_detokenization.token_ids