1d9f0492fSopenharmony_ci/*
2d9f0492fSopenharmony_ci * Copyright (c) 2022 Huawei Device Co., Ltd.
3d9f0492fSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4d9f0492fSopenharmony_ci * you may not use this file except in compliance with the License.
5d9f0492fSopenharmony_ci * You may obtain a copy of the License at
6d9f0492fSopenharmony_ci *
7d9f0492fSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0
8d9f0492fSopenharmony_ci *
9d9f0492fSopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10d9f0492fSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11d9f0492fSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12d9f0492fSopenharmony_ci * See the License for the specific language governing permissions and
13d9f0492fSopenharmony_ci * limitations under the License.
14d9f0492fSopenharmony_ci */
15d9f0492fSopenharmony_ci
16d9f0492fSopenharmony_ci#include <thread>
17d9f0492fSopenharmony_ci#include <string>
18d9f0492fSopenharmony_ci#include <gtest/gtest.h>
19d9f0492fSopenharmony_ci
20d9f0492fSopenharmony_ci#include "parameter.h"
21d9f0492fSopenharmony_ci#include "service_control.h"
22d9f0492fSopenharmony_ci#include "service_watcher.h"
23d9f0492fSopenharmony_ci#include "test_utils.h"
24d9f0492fSopenharmony_ci
25d9f0492fSopenharmony_ciusing namespace testing::ext;
26d9f0492fSopenharmony_ci
27d9f0492fSopenharmony_cinamespace initModuleTest {
28d9f0492fSopenharmony_ciclass ServiceWatcherModuleTest : public testing::Test {
29d9f0492fSopenharmony_cipublic:
30d9f0492fSopenharmony_ci    static void SetUpTestCase(void) {};
31d9f0492fSopenharmony_ci    static void TearDownTestCase(void) {};
32d9f0492fSopenharmony_ci    void SetUp(void) {};
33d9f0492fSopenharmony_ci    void TearDown(void) {};
34d9f0492fSopenharmony_ci};
35d9f0492fSopenharmony_ci
36d9f0492fSopenharmony_cistatic void ServiceStatusChange(const char *key, const ServiceInfo *status)
37d9f0492fSopenharmony_ci{
38d9f0492fSopenharmony_ci    std::cout <<"service Name is: " << key;
39d9f0492fSopenharmony_ci    std::cout <<", ServiceStatus is: "<< status->status;
40d9f0492fSopenharmony_ci    std::cout <<", pid is: "<< status->pid << std::endl;
41d9f0492fSopenharmony_ci}
42d9f0492fSopenharmony_ci
43d9f0492fSopenharmony_ciHWTEST_F(ServiceWatcherModuleTest, serviceWatcher_test_001, TestSize.Level0)
44d9f0492fSopenharmony_ci{
45d9f0492fSopenharmony_ci    GTEST_LOG_(INFO) << "serviceWatcher_test_001 start";
46d9f0492fSopenharmony_ci    string serviceName = "test.Service";
47d9f0492fSopenharmony_ci    int ret = ServiceWatchForStatus(serviceName.c_str(), ServiceStatusChange);
48d9f0492fSopenharmony_ci    EXPECT_EQ(ret, 0); // No matter if service exist or not, ServiceWatchForStatus always success.
49d9f0492fSopenharmony_ci    auto status = GetServiceStatus(serviceName);
50d9f0492fSopenharmony_ci    EXPECT_TRUE(status == "idle");
51d9f0492fSopenharmony_ci    GTEST_LOG_(INFO) << "serviceWatcher_test_001 end";
52d9f0492fSopenharmony_ci}
53d9f0492fSopenharmony_ci
54d9f0492fSopenharmony_ciHWTEST_F(ServiceWatcherModuleTest, serviceWatcher_test_002, TestSize.Level0)
55d9f0492fSopenharmony_ci{
56d9f0492fSopenharmony_ci    GTEST_LOG_(INFO) << "serviceWatcher_test_002 start";
57d9f0492fSopenharmony_ci    string serviceName = "media_service";
58d9f0492fSopenharmony_ci    auto status = GetServiceStatus(serviceName);
59d9f0492fSopenharmony_ci    if (status == "running") {
60d9f0492fSopenharmony_ci        int ret = ServiceControl(serviceName.c_str(), STOP);
61d9f0492fSopenharmony_ci        ASSERT_EQ(ret, 0);
62d9f0492fSopenharmony_ci    } else if (status != "created" && status != "stopped") {
63d9f0492fSopenharmony_ci        std::cout << serviceName << " in invalid status " << status << std::endl;
64d9f0492fSopenharmony_ci        ASSERT_TRUE(0);
65d9f0492fSopenharmony_ci    }
66d9f0492fSopenharmony_ci    int ret = ServiceWatchForStatus(serviceName.c_str(), ServiceStatusChange);
67d9f0492fSopenharmony_ci    EXPECT_EQ(ret, 0);
68d9f0492fSopenharmony_ci    status = GetServiceStatus(serviceName);
69d9f0492fSopenharmony_ci    EXPECT_TRUE(status == "stopped");
70d9f0492fSopenharmony_ci    GTEST_LOG_(INFO) << "serviceWatcher_test_002 end";
71d9f0492fSopenharmony_ci}
72d9f0492fSopenharmony_ci
73d9f0492fSopenharmony_ciHWTEST_F(ServiceWatcherModuleTest, serviceWatcher_test_003, TestSize.Level0)
74d9f0492fSopenharmony_ci{
75d9f0492fSopenharmony_ci    GTEST_LOG_(INFO) << "serviceWatcher_test_003 start";
76d9f0492fSopenharmony_ci    const std::string serviceName = "deviceinfoservice";
77d9f0492fSopenharmony_ci    // watcher service status
78d9f0492fSopenharmony_ci    int ret = ServiceWatchForStatus(serviceName.c_str(), ServiceStatusChange);
79d9f0492fSopenharmony_ci    EXPECT_EQ(ret, 0); // No matter if service exist or not, ServiceWatchForStatus always success.
80d9f0492fSopenharmony_ci    // start service
81d9f0492fSopenharmony_ci    char udid[65] = {}; // 65 udid len
82d9f0492fSopenharmony_ci    ret = AclGetDevUdid(udid, sizeof(udid));
83d9f0492fSopenharmony_ci    EXPECT_NE(ret, 0);
84d9f0492fSopenharmony_ci    auto status1 = GetServiceStatus(serviceName);
85d9f0492fSopenharmony_ci    EXPECT_TRUE(status1 == "running");
86d9f0492fSopenharmony_ci
87d9f0492fSopenharmony_ci    GTEST_LOG_(INFO) << "serviceWatcher_test_003 end";
88d9f0492fSopenharmony_ci}
89d9f0492fSopenharmony_ci}
90