test_utils.py 1.02 KB
Newer Older
1
2
3
4
5
6
7
8
import os

import ray

from vllm.utils import cuda_device_count_stateless


@ray.remote
9
class _CUDADeviceCountStatelessTestActor:
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24

    def get_count(self):
        return cuda_device_count_stateless()

    def set_cuda_visible_devices(self, cuda_visible_devices: str):
        os.environ["CUDA_VISIBLE_DEVICES"] = cuda_visible_devices

    def get_cuda_visible_devices(self):
        return os.environ["CUDA_VISIBLE_DEVICES"]


def test_cuda_device_count_stateless():
    """Test that cuda_device_count_stateless changes return value if
    CUDA_VISIBLE_DEVICES is changed."""

25
26
    actor = _CUDADeviceCountStatelessTestActor.options(  # type: ignore
        num_gpus=2).remote()
27
28
    assert sorted(ray.get(
        actor.get_cuda_visible_devices.remote()).split(",")) == ["0", "1"]
29
30
31
32
33
    assert ray.get(actor.get_count.remote()) == 2
    ray.get(actor.set_cuda_visible_devices.remote("0"))
    assert ray.get(actor.get_count.remote()) == 1
    ray.get(actor.set_cuda_visible_devices.remote(""))
    assert ray.get(actor.get_count.remote()) == 0