2025-10-16 16:35:35 +08:00
|
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
# SPDX-FileCopyrightText: Copyright contributors to the vLLM project
|
|
|
|
|
import pytest
|
|
|
|
|
|
2026-01-22 16:20:27 +08:00
|
|
|
from vllm.utils.collection_utils import common_prefix, swap_dict_values
|
2025-10-16 16:35:35 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
2026-01-22 16:20:27 +08:00
|
|
|
("inputs", "expected_output"),
|
|
|
|
|
[
|
|
|
|
|
([""], ""),
|
|
|
|
|
(["a"], "a"),
|
|
|
|
|
(["a", "b"], ""),
|
|
|
|
|
(["a", "ab"], "a"),
|
|
|
|
|
(["a", "ab", "b"], ""),
|
|
|
|
|
(["abc", "a", "ab"], "a"),
|
|
|
|
|
(["aba", "abc", "ab"], "ab"),
|
|
|
|
|
],
|
|
|
|
|
)
|
|
|
|
|
def test_common_prefix(inputs, expected_output):
|
|
|
|
|
assert common_prefix(inputs) == expected_output
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
|
|
("obj", "key1", "key2"),
|
2025-10-16 16:35:35 +08:00
|
|
|
[
|
|
|
|
|
# Tests for both keys exist
|
|
|
|
|
({1: "a", 2: "b"}, 1, 2),
|
|
|
|
|
# Tests for one key does not exist
|
|
|
|
|
({1: "a", 2: "b"}, 1, 3),
|
|
|
|
|
# Tests for both keys do not exist
|
|
|
|
|
({1: "a", 2: "b"}, 3, 4),
|
|
|
|
|
],
|
|
|
|
|
)
|
|
|
|
|
def test_swap_dict_values(obj, key1, key2):
|
|
|
|
|
original_obj = obj.copy()
|
|
|
|
|
|
|
|
|
|
swap_dict_values(obj, key1, key2)
|
|
|
|
|
|
|
|
|
|
if key1 in original_obj:
|
|
|
|
|
assert obj[key2] == original_obj[key1]
|
|
|
|
|
else:
|
|
|
|
|
assert key2 not in obj
|
|
|
|
|
if key2 in original_obj:
|
|
|
|
|
assert obj[key1] == original_obj[key2]
|
|
|
|
|
else:
|
|
|
|
|
assert key1 not in obj
|