"tests/vscode:/vscode.git/clone" did not exist on "bc9df1571b8002738eb8db70a07f552e32feb75f"
test_scheduler_plugins.py 1.94 KB
Newer Older
1
2
# SPDX-License-Identifier: Apache-2.0

3
4
import pytest

5
from vllm.core.scheduler import Scheduler
6
7
8
9
10
from vllm.engine.arg_utils import EngineArgs
from vllm.engine.llm_engine import LLMEngine
from vllm.sampling_params import SamplingParams
from vllm.v1.core.scheduler import Scheduler as V1Scheduler
from vllm.v1.engine.llm_engine import LLMEngine as V1LLMEngine
11
12


13
class DummyV0Scheduler(Scheduler):
14
15

    def schedule(self):
16
17
        raise Exception("Exception raised by DummyV0Scheduler")

18

19
class DummyV1Scheduler(V1Scheduler):
20

21
22
    def schedule(self):
        raise Exception("Exception raised by DummyV1Scheduler")
23
24


25
26
def test_scheduler_plugins_v0(monkeypatch):
    monkeypatch.setenv("VLLM_USE_V1", "0")
27
28
29
30
31
    with pytest.raises(Exception) as exception_info:

        engine_args = EngineArgs(
            model="facebook/opt-125m",
            enforce_eager=True,  # reduce test time
32
            scheduler_cls=DummyV0Scheduler,
33
34
35
36
37
38
39
40
        )

        engine = LLMEngine.from_engine_args(engine_args=engine_args)

        sampling_params = SamplingParams(max_tokens=1)
        engine.add_request("0", "foo", sampling_params)
        engine.step()

41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
    assert str(exception_info.value) == "Exception raised by DummyV0Scheduler"


def test_scheduler_plugins_v1(monkeypatch):
    monkeypatch.setenv("VLLM_USE_V1", "1")
    # Explicitly turn off engine multiprocessing so that the scheduler runs in
    # this process
    monkeypatch.setenv("VLLM_ENABLE_V1_MULTIPROCESSING", "0")

    with pytest.raises(Exception) as exception_info:

        engine_args = EngineArgs(
            model="facebook/opt-125m",
            enforce_eager=True,  # reduce test time
            scheduler_cls=DummyV1Scheduler,
        )

        engine = V1LLMEngine.from_engine_args(engine_args=engine_args)

        sampling_params = SamplingParams(max_tokens=1)
        engine.add_request("0", "foo", sampling_params)
        engine.step()

    assert str(exception_info.value) == "Exception raised by DummyV1Scheduler"