# Copyright (c) 2025 Huawei Technologies Co., Ltd. All Rights Reserved. # Copyright 2023 The vLLM team. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. # This file is a part of the vllm-ascend project. # import json from typing import Any import openai import pytest from vllm.utils import get_open_port from tests.e2e.conftest import RemoteOpenAIServer from tools.aisbench import run_aisbench_cases MODELS = [ "vllm-ascend/DeepSeek-R1-W8A8", ] prompts = [ "San Francisco is a", ] api_keyword_args = { "max_tokens": 10, } aisbench_cases = [{ "case_type": "accuracy", "dataset_path": "vllm-ascend/gsm8k-lite", "request_conf": "vllm_api_general_chat", "dataset_conf": "gsm8k/gsm8k_gen_0_shot_cot_chat_prompt", "max_out_len": 32768, "batch_size": 32, "baseline": 95, "threshold": 5 }] @pytest.mark.asyncio @pytest.mark.parametrize("model", MODELS) async def test_models(model: str) -> None: port = get_open_port() env_dict = { "OMP_NUM_THREADS": "100", "OMP_PROC_BIND": "false", "HCCL_BUFFSIZE": "200", "VLLM_ASCEND_ENABLE_MLAPO": "1", "VLLM_RPC_TIMEOUT": "3600000", "VLLM_EXECUTE_MODEL_TIMEOUT_SECONDS": "3600000", "DISABLE_L2_CACHE": "1", "DYNAMIC_EPLB": "true", } speculative_config = {"num_speculative_tokens": 1, "method": "mtp"} compilation_config = { "cudagraph_capture_sizes": [24], "cudagraph_mode": "FULL_DECODE_ONLY" } additional_config: dict[str, Any] = { "enable_shared_expert_dp": False, "multistream_overlap_shared_expert": False, "dynamic_eplb": True, "num_iterations_eplb_update": 14000, "num_wait_worker_iterations": 30, "init_redundancy_expert": 0, "gate_eplb": False } server_args = [ "--quantization", "ascend", "--seed", "1024", "--no-enable-prefix-caching", "--data-parallel-size", "4", "--tensor-parallel-size", "4", "--enable-expert-parallel", "--port", str(port), "--max-model-len", "40000", "--max-num-batched-tokens", "4096", "--max-num-seqs", "12", "--trust-remote-code", "--gpu-memory-utilization", "0.92" ] server_args.extend( ["--speculative-config", json.dumps(speculative_config)]) server_args.extend( ["--compilation-config", json.dumps(compilation_config)]) server_args.extend(["--additional-config", json.dumps(additional_config)]) request_keyword_args: dict[str, Any] = { **api_keyword_args, } with RemoteOpenAIServer(model, server_args, server_port=port, env_dict=env_dict, auto_port=False) as server: client = server.get_async_client() batch = await client.completions.create( model=model, prompt=prompts, **request_keyword_args, ) choices: list[openai.types.CompletionChoice] = batch.choices assert choices[0].text, "empty response" print(choices) # aisbench test run_aisbench_cases(model, port, aisbench_cases, server_args=server_args)