2025-04-30 11:38:20 -07:00
|
|
|
import os
|
2024-09-12 21:36:41 -07:00
|
|
|
import unittest
|
|
|
|
|
|
|
|
|
|
from sglang.test.test_utils import (
|
|
|
|
|
DEFAULT_MODEL_NAME_FOR_TEST,
|
|
|
|
|
DEFAULT_MOE_MODEL_NAME_FOR_TEST,
|
2025-04-28 10:57:17 -07:00
|
|
|
DEFAULT_SMALL_MODEL_NAME_FOR_TEST,
|
2025-03-26 07:53:12 +08:00
|
|
|
CustomTestCase,
|
2025-05-31 15:53:55 -07:00
|
|
|
is_in_amd_ci,
|
2024-09-14 15:38:37 -07:00
|
|
|
is_in_ci,
|
2025-04-28 10:57:17 -07:00
|
|
|
run_bench_offline_throughput,
|
2024-11-21 20:07:48 -08:00
|
|
|
run_bench_one_batch,
|
2025-01-21 02:55:14 -08:00
|
|
|
write_github_step_summary,
|
2024-09-12 21:36:41 -07:00
|
|
|
)
|
|
|
|
|
|
2025-04-28 10:57:17 -07:00
|
|
|
# We use `run_bench_offline_throughput`` instead of `run_bench_one_batch` for most cases
|
|
|
|
|
# because `run_bench_offline_throughput`` has overlap scheduler.
|
|
|
|
|
|
2024-09-12 21:36:41 -07:00
|
|
|
|
2025-03-26 07:53:12 +08:00
|
|
|
class TestBenchOneBatch(CustomTestCase):
|
2025-04-28 10:57:17 -07:00
|
|
|
|
|
|
|
|
def test_bs1_small(self):
|
2025-07-04 13:25:50 +08:00
|
|
|
_, output_throughput, _ = run_bench_one_batch(
|
2025-04-28 10:57:17 -07:00
|
|
|
DEFAULT_SMALL_MODEL_NAME_FOR_TEST, ["--cuda-graph-max-bs", "2"]
|
|
|
|
|
)
|
|
|
|
|
self.assertGreater(output_throughput, 50)
|
|
|
|
|
|
|
|
|
|
def test_bs1_default(self):
|
|
|
|
|
output_throughput = run_bench_offline_throughput(
|
2025-03-08 05:23:06 -08:00
|
|
|
DEFAULT_MODEL_NAME_FOR_TEST, ["--cuda-graph-max-bs", "2"]
|
|
|
|
|
)
|
2024-09-12 21:36:41 -07:00
|
|
|
|
2024-09-14 15:38:37 -07:00
|
|
|
if is_in_ci():
|
2025-01-21 02:55:14 -08:00
|
|
|
write_github_step_summary(
|
2025-04-27 15:29:46 -07:00
|
|
|
f"### test_bs1_default (llama-3.1-8b)\n"
|
|
|
|
|
f"output_throughput: {output_throughput:.2f} token/s\n"
|
2025-01-21 02:55:14 -08:00
|
|
|
)
|
2024-11-17 15:48:12 -08:00
|
|
|
self.assertGreater(output_throughput, 135)
|
2024-09-12 21:36:41 -07:00
|
|
|
|
2025-01-21 02:55:14 -08:00
|
|
|
def test_moe_tp2_bs1(self):
|
2025-04-28 10:57:17 -07:00
|
|
|
output_throughput = run_bench_offline_throughput(
|
2025-03-08 05:23:06 -08:00
|
|
|
DEFAULT_MOE_MODEL_NAME_FOR_TEST, ["--tp", "2", "--cuda-graph-max-bs", "2"]
|
2024-09-12 21:36:41 -07:00
|
|
|
)
|
|
|
|
|
|
2024-09-14 15:38:37 -07:00
|
|
|
if is_in_ci():
|
2025-01-21 02:55:14 -08:00
|
|
|
write_github_step_summary(
|
2025-04-28 10:57:17 -07:00
|
|
|
f"### test_moe_tp2_bs1 (Mixtral-8x7B)\n"
|
2025-04-27 15:29:46 -07:00
|
|
|
f"output_throughput: {output_throughput:.2f} token/s\n"
|
2025-01-21 02:55:14 -08:00
|
|
|
)
|
2025-05-31 15:53:55 -07:00
|
|
|
if is_in_amd_ci():
|
2025-04-30 11:38:20 -07:00
|
|
|
self.assertGreater(output_throughput, 85)
|
|
|
|
|
else:
|
|
|
|
|
self.assertGreater(output_throughput, 125)
|
2024-09-12 21:36:41 -07:00
|
|
|
|
2025-01-21 02:55:14 -08:00
|
|
|
def test_torch_compile_tp2_bs1(self):
|
2025-04-28 10:57:17 -07:00
|
|
|
output_throughput = run_bench_offline_throughput(
|
2025-01-21 02:55:14 -08:00
|
|
|
DEFAULT_MODEL_NAME_FOR_TEST,
|
|
|
|
|
["--tp", "2", "--enable-torch-compile", "--cuda-graph-max-bs", "2"],
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
if is_in_ci():
|
|
|
|
|
write_github_step_summary(
|
2025-04-28 10:57:17 -07:00
|
|
|
f"### test_torch_compile_tp2_bs1 (Mixtral-8x7B)\n"
|
2025-04-27 15:29:46 -07:00
|
|
|
f"output_throughput: {output_throughput:.2f} token/s\n"
|
2025-01-21 02:55:14 -08:00
|
|
|
)
|
2025-05-31 15:53:55 -07:00
|
|
|
if is_in_amd_ci():
|
2025-05-25 07:38:39 +08:00
|
|
|
self.assertGreater(output_throughput, 200)
|
|
|
|
|
else:
|
|
|
|
|
self.assertGreater(output_throughput, 220)
|
2025-01-21 02:55:14 -08:00
|
|
|
|
2024-09-12 21:36:41 -07:00
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
|
unittest.main()
|