1eace7efcSopenharmony_ci/* 2eace7efcSopenharmony_ci * Copyright (c) 2022-2023 Huawei Device Co., Ltd. 3eace7efcSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 4eace7efcSopenharmony_ci * you may not use this file except in compliance with the License. 5eace7efcSopenharmony_ci * You may obtain a copy of the License at 6eace7efcSopenharmony_ci * 7eace7efcSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 8eace7efcSopenharmony_ci * 9eace7efcSopenharmony_ci * Unless required by applicable law or agreed to in writing, software 10eace7efcSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 11eace7efcSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12eace7efcSopenharmony_ci * See the License for the specific language governing permissions and 13eace7efcSopenharmony_ci * limitations under the License. 14eace7efcSopenharmony_ci */ 15eace7efcSopenharmony_ci 16eace7efcSopenharmony_ci#ifndef OHOS_ABILITY_RUNTIME_TEST_OBSERVER_PROXY_H 17eace7efcSopenharmony_ci#define OHOS_ABILITY_RUNTIME_TEST_OBSERVER_PROXY_H 18eace7efcSopenharmony_ci 19eace7efcSopenharmony_ci#include "iremote_proxy.h" 20eace7efcSopenharmony_ci#include "itest_observer.h" 21eace7efcSopenharmony_ci 22eace7efcSopenharmony_cinamespace OHOS { 23eace7efcSopenharmony_cinamespace AAFwk { 24eace7efcSopenharmony_ciclass TestObserverProxy : public IRemoteProxy<ITestObserver> { 25eace7efcSopenharmony_cipublic: 26eace7efcSopenharmony_ci /** 27eace7efcSopenharmony_ci * A constructor used to create a TestObserverProxy instance with the input parameter object passed. 28eace7efcSopenharmony_ci * @param object Indicates remote object. 29eace7efcSopenharmony_ci */ 30eace7efcSopenharmony_ci explicit TestObserverProxy(const sptr<IRemoteObject>& object); 31eace7efcSopenharmony_ci 32eace7efcSopenharmony_ci /** 33eace7efcSopenharmony_ci * Deconstructor used to deconstruct. 34eace7efcSopenharmony_ci */ 35eace7efcSopenharmony_ci virtual ~TestObserverProxy() override; 36eace7efcSopenharmony_ci 37eace7efcSopenharmony_ci /** 38eace7efcSopenharmony_ci * Outputs test status. 39eace7efcSopenharmony_ci * 40eace7efcSopenharmony_ci * @param msg, Indicates the status information. 41eace7efcSopenharmony_ci * @param resultCode, Indicates the result code. 42eace7efcSopenharmony_ci */ 43eace7efcSopenharmony_ci virtual void TestStatus(const std::string& msg, const int64_t& resultCode) override; 44eace7efcSopenharmony_ci 45eace7efcSopenharmony_ci /** 46eace7efcSopenharmony_ci * Outputs information and result code that the test has finished. 47eace7efcSopenharmony_ci * 48eace7efcSopenharmony_ci * @param msg, Indicates the status information. 49eace7efcSopenharmony_ci * @param resultCode, Indicates the result code. 50eace7efcSopenharmony_ci */ 51eace7efcSopenharmony_ci virtual void TestFinished(const std::string& msg, const int64_t& resultCode) override; 52eace7efcSopenharmony_ci 53eace7efcSopenharmony_ci /** 54eace7efcSopenharmony_ci * Executes the specified shell command. 55eace7efcSopenharmony_ci * 56eace7efcSopenharmony_ci * @param cmd, Indicates the specified shell command. 57eace7efcSopenharmony_ci * @param timeoutSec, Indicates the specified time out time, in seconds. 58eace7efcSopenharmony_ci * @return the result of the specified shell command. 59eace7efcSopenharmony_ci */ 60eace7efcSopenharmony_ci virtual ShellCommandResult ExecuteShellCommand(const std::string& cmd, const int64_t timeoutSec) override; 61eace7efcSopenharmony_ci 62eace7efcSopenharmony_ciprivate: 63eace7efcSopenharmony_ci static inline BrokerDelegator<TestObserverProxy> delegator_; 64eace7efcSopenharmony_ci int32_t SendTransactCmd(uint32_t code, MessageParcel &data, MessageParcel &reply, MessageOption &option); 65eace7efcSopenharmony_ci}; 66eace7efcSopenharmony_ci} // namespace AAFwk 67eace7efcSopenharmony_ci} // namespace OHOS 68eace7efcSopenharmony_ci 69eace7efcSopenharmony_ci#endif // OHOS_ABILITY_RUNTIME_TEST_OBSERVER_PROXY_H 70