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