1eace7efcSopenharmony_ci/*
2eace7efcSopenharmony_ci * Copyright (c) 2022 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_ITEST_OBSERVER_H
17eace7efcSopenharmony_ci#define OHOS_ABILITY_RUNTIME_ITEST_OBSERVER_H
18eace7efcSopenharmony_ci
19eace7efcSopenharmony_ci#include "iremote_broker.h"
20eace7efcSopenharmony_ci#include "shell_command_result.h"
21eace7efcSopenharmony_ci
22eace7efcSopenharmony_cinamespace OHOS {
23eace7efcSopenharmony_cinamespace AAFwk {
24eace7efcSopenharmony_ciclass ITestObserver : public IRemoteBroker {
25eace7efcSopenharmony_cipublic:
26eace7efcSopenharmony_ci    DECLARE_INTERFACE_DESCRIPTOR(u"ohos.aafwk.ITestObserver");
27eace7efcSopenharmony_ci
28eace7efcSopenharmony_ci    /**
29eace7efcSopenharmony_ci     * Outputs test status.
30eace7efcSopenharmony_ci     *
31eace7efcSopenharmony_ci     * @param msg, Indicates the status information.
32eace7efcSopenharmony_ci     * @param resultCode, Indicates the result code.
33eace7efcSopenharmony_ci     */
34eace7efcSopenharmony_ci    virtual void TestStatus(const std::string& msg, const int64_t& resultCode) = 0;
35eace7efcSopenharmony_ci
36eace7efcSopenharmony_ci    /**
37eace7efcSopenharmony_ci     * Outputs information and result code that the test has finished.
38eace7efcSopenharmony_ci     *
39eace7efcSopenharmony_ci     * @param msg, Indicates the status information.
40eace7efcSopenharmony_ci     * @param resultCode, Indicates the result code.
41eace7efcSopenharmony_ci     */
42eace7efcSopenharmony_ci    virtual void TestFinished(const std::string& msg, const int64_t& resultCode) = 0;
43eace7efcSopenharmony_ci
44eace7efcSopenharmony_ci    /**
45eace7efcSopenharmony_ci     * Executes the specified shell command.
46eace7efcSopenharmony_ci     *
47eace7efcSopenharmony_ci     * @param cmd, Indicates the specified shell command.
48eace7efcSopenharmony_ci     * @param timeoutSec, Indicates the specified time out time, in seconds.
49eace7efcSopenharmony_ci     * @return the result of the specified shell command.
50eace7efcSopenharmony_ci     */
51eace7efcSopenharmony_ci    virtual ShellCommandResult ExecuteShellCommand(const std::string& cmd, const int64_t timeoutSec) = 0;
52eace7efcSopenharmony_ci
53eace7efcSopenharmony_ci    enum class Message {
54eace7efcSopenharmony_ci        // ipc id for test status (1)
55eace7efcSopenharmony_ci        AA_TEST_STATUS = 1,
56eace7efcSopenharmony_ci        // ipc id for test finished (2)
57eace7efcSopenharmony_ci        AA_TEST_FINISHED = 2,
58eace7efcSopenharmony_ci        // ipc id for execute shell command (3)
59eace7efcSopenharmony_ci        AA_EXECUTE_SHELL_COMMAND = 3,
60eace7efcSopenharmony_ci    };
61eace7efcSopenharmony_ci};
62eace7efcSopenharmony_ci}  // namespace AAFwk
63eace7efcSopenharmony_ci}  // namespace OHOS
64eace7efcSopenharmony_ci
65eace7efcSopenharmony_ci#endif  // OHOS_ABILITY_RUNTIME_ITEST_OBSERVER_H
66