test_detokenization.py 1.51 KB
Newer Older
1
2
# SPDX-License-Identifier: Apache-2.0

3
4
import pytest

5
from vllm.config import LoadFormat
6
7
8
from vllm.entrypoints.llm import LLM
from vllm.sampling_params import SamplingParams

9
from ..conftest import MODEL_WEIGHTS_S3_BUCKET
10

11

12
13
@pytest.mark.parametrize("model",
                         [f"{MODEL_WEIGHTS_S3_BUCKET}/distilbert/distilgpt2"])
14
15
16
17
18
19
20
21
22
23
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 "
        "online for free?")

24
    llm = LLM(model=model, load_format=LoadFormat.RUNAI_STREAMER)
25
26
27
28
29
30
31
32
33
34
35
36
37
38
    sampling_params = SamplingParams(max_tokens=10,
                                     temperature=0.0,
                                     detokenize=False)

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

    assert outputs_no_detokenization.text == ''
    assert outputs_with_detokenization.text != ''
    assert outputs_no_detokenization.token_ids == \
        outputs_with_detokenization.token_ids