100600bfbSopenharmony_ci#!/usr/bin/env python3 200600bfbSopenharmony_ci# -*- coding: utf-8 -*- 300600bfbSopenharmony_ci# Copyright (C) 2024 Huawei Device Co., Ltd. 400600bfbSopenharmony_ci# Licensed under the Apache License, Version 2.0 (the "License"); 500600bfbSopenharmony_ci# you may not use this file except in compliance with the License. 600600bfbSopenharmony_ci# You may obtain a copy of the License at 700600bfbSopenharmony_ci# 800600bfbSopenharmony_ci# http://www.apache.org/licenses/LICENSE-2.0 900600bfbSopenharmony_ci# 1000600bfbSopenharmony_ci# Unless required by applicable law or agreed to in writing, software 1100600bfbSopenharmony_ci# distributed under the License is distributed on an "AS IS" BASIS, 1200600bfbSopenharmony_ci# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 1300600bfbSopenharmony_ci# See the License for the specific language governing permissions and 1400600bfbSopenharmony_ci# limitations under the License. 1500600bfbSopenharmony_ciimport pytest 1600600bfbSopenharmony_ciimport subprocess 1700600bfbSopenharmony_ciimport re 1800600bfbSopenharmony_cifrom utils import * 1900600bfbSopenharmony_ci 2000600bfbSopenharmony_cidef CheckIpcStat(output): 2100600bfbSopenharmony_ci result = re.search("CurrentPid:\d+\nTotalCount:\d+\nTotalTimeCost:\d+", output) 2200600bfbSopenharmony_ci return result is not None 2300600bfbSopenharmony_ci 2400600bfbSopenharmony_cidef CheckIpcStartAll(output): 2500600bfbSopenharmony_ci pass 2600600bfbSopenharmony_ci 2700600bfbSopenharmony_ciclass TestHidumperIpc: 2800600bfbSopenharmony_ci 2900600bfbSopenharmony_ci @pytest.mark.L0 3000600bfbSopenharmony_ci def test_ipc_stat(self): 3100600bfbSopenharmony_ci # 校验命令行输出 3200600bfbSopenharmony_ci pid = GetPidByProcessName("samgr") 3300600bfbSopenharmony_ci output = subprocess.check_output(f"hdc shell hidumper --ipc {pid} --start-stat", shell=True, text=True, encoding="utf-8") 3400600bfbSopenharmony_ci assert "success" in output 3500600bfbSopenharmony_ci 3600600bfbSopenharmony_ci command = f"hidumper --ipc {pid} --stat" 3700600bfbSopenharmony_ci CheckCmd(command, CheckIpcStat) 3800600bfbSopenharmony_ci CheckCmdRedirect(command, CheckIpcStat) 3900600bfbSopenharmony_ci 4000600bfbSopenharmony_ci output = subprocess.check_output(f"hdc shell hidumper --ipc {pid} --stop-stat", shell=True, text=True, encoding="utf-8") 4100600bfbSopenharmony_ci assert "success" in output 42