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

4
import pytest
5
6
7
import torch

from vllm.attention.selector import get_attn_backend
8
from vllm.plugins import load_general_plugins
9
from vllm.utils import STR_BACKEND_ENV_VAR, STR_INVALID_VAL
10
11


12
13
14
15
16
17
18
def test_platform_plugins():
    # simulate workload by running an example
    import runpy
    current_file = __file__
    import os
    example_file = os.path.join(
        os.path.dirname(os.path.dirname(os.path.dirname(current_file))),
19
        "examples", "offline_inference/basic/basic.py")
20
21
22
23
    runpy.run_path(example_file)

    # check if the plugin is loaded correctly
    from vllm.platforms import _init_trace, current_platform
24
25
    # assert current_platform.device_name == "DummyDevice", (
    assert current_platform.device_name == "rocm", (
26
27
28
        f"Expected DummyDevice, got {current_platform.device_name}, "
        "possibly because current_platform is imported before the plugin"
        f" is loaded. The first import:\n{_init_trace}")
29
30


31
def test_oot_attention_backend(monkeypatch: pytest.MonkeyPatch):
32
    # ignore the backend env variable if it is set
33
34
    with monkeypatch.context() as m:
        m.setenv(STR_BACKEND_ENV_VAR, STR_INVALID_VAL)
35
        backend = get_attn_backend(16, torch.float16, "auto", 16, False)
36
        # assert backend.get_name() == "Dummy_Backend"
37
38


39
40
41
42
43
44
45
46
47
48
49
50
# TODO
# def test_oot_custom_op(monkeypatch: pytest.MonkeyPatch):
#     # simulate workload by running an example
#     load_general_plugins()
#     from vllm.model_executor.layers.rotary_embedding import RotaryEmbedding
#     layer = RotaryEmbedding(16, 16, 16, 16, True, torch.float16)
#     assert layer.__class__.__name__ == "DummyRotaryEmbedding", (
#         f"Expected DummyRotaryEmbedding, got {layer.__class__.__name__}, "
#         "possibly because the custom op is not registered correctly.")
#     assert hasattr(layer, "addition_config"), (
#         "Expected DummyRotaryEmbedding to have an 'addition_config' attribute, "
#         "which is set by the custom op.")