1/*
2 * Copyright (c) 2022 Huawei Device Co., Ltd.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
7 *     http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15
16#include "agent/runtime_impl.h"
17#include "ecmascript/tests/test_helper.h"
18#include "tooling/protocol_handler.h"
19
20using namespace panda::ecmascript;
21using namespace panda::ecmascript::tooling;
22
23
24namespace panda::test {
25class RuntimeImplTest : public testing::Test {
26public:
27    static void SetUpTestCase()
28    {
29        GTEST_LOG_(INFO) << "SetUpTestCase";
30    }
31
32    static void TearDownTestCase()
33    {
34        GTEST_LOG_(INFO) << "TearDownCase";
35    }
36
37    void SetUp() override
38    {
39        TestHelper::CreateEcmaVMWithScope(ecmaVm, thread, scope);
40    }
41
42    void TearDown() override
43    {
44        TestHelper::DestroyEcmaVMWithScope(ecmaVm, scope);
45    }
46
47protected:
48    EcmaVM *ecmaVm {nullptr};
49    EcmaHandleScope *scope {nullptr};
50    JSThread *thread {nullptr};
51};
52
53HWTEST_F_L0(RuntimeImplTest, DispatcherImplDispatch)
54{
55    std::string result = "";
56    std::function<void(const void*, const std::string &)> callback =
57        [&result]([[maybe_unused]] const void *ptr, const std::string &temp) {result = temp;};
58    ProtocolChannel *channel = new ProtocolHandler(callback, ecmaVm);
59    auto runtimeImpl = std::make_unique<RuntimeImpl>(ecmaVm, channel);
60    auto dispatcherImpl = std::make_unique<RuntimeImpl::DispatcherImpl>(channel, std::move(runtimeImpl));
61    std::string msg = std::string() + R"({"id":0,"method":"Rumtime.test","params":{}})";
62    DispatchRequest request(msg);
63    dispatcherImpl->Dispatch(request);
64    ASSERT_TRUE(result.find("unknown method: test") != std::string::npos);
65
66    msg = std::string() + R"({"id":0,"method":"Rumtime.enable","params":{}})";
67    DispatchRequest request1(msg);
68    dispatcherImpl->Dispatch(request1);
69    ASSERT_TRUE(result.find("protocols") != std::string::npos);
70    if (channel != nullptr) {
71        delete channel;
72        channel = nullptr;
73    }
74}
75
76HWTEST_F_L0(RuntimeImplTest, DispatcherImplEnable)
77{
78    std::string result = "";
79    std::function<void(const void*, const std::string &)> callback =
80        [&result]([[maybe_unused]] const void *ptr, const std::string &temp) {result = temp;};
81    ProtocolChannel *channel = new ProtocolHandler(callback, ecmaVm);
82    auto runtimeImpl = std::make_unique<RuntimeImpl>(ecmaVm, channel);
83    auto dispatcherImpl = std::make_unique<RuntimeImpl::DispatcherImpl>(channel, std::move(runtimeImpl));
84
85    std::string msg = std::string() + R"({"id":0,"method":"Rumtime.enable","params":{}})";
86    DispatchRequest request1(msg);
87    dispatcherImpl->Enable(request1);
88    ASSERT_TRUE(result.find("protocols") != std::string::npos);
89    if (channel != nullptr) {
90        delete channel;
91        channel = nullptr;
92    }
93}
94
95HWTEST_F_L0(RuntimeImplTest, DispatcherImplDisable)
96{
97    std::string result = "";
98    std::function<void(const void*, const std::string &)> callback =
99        [&result]([[maybe_unused]] const void *ptr, const std::string &temp) {result = temp;};
100    ProtocolChannel *channel = new ProtocolHandler(callback, ecmaVm);
101    auto runtimeImpl = std::make_unique<RuntimeImpl>(ecmaVm, channel);
102    auto dispatcherImpl = std::make_unique<RuntimeImpl::DispatcherImpl>(channel, std::move(runtimeImpl));
103
104    std::string msg = std::string() + R"({"id":0,"method":"Rumtime.disable","params":{}})";
105    DispatchRequest request1(msg);
106    dispatcherImpl->Disable(request1);
107    ASSERT_TRUE(result == "{\"id\":0,\"result\":{}}");
108    if (channel != nullptr) {
109        delete channel;
110        channel = nullptr;
111    }
112}
113
114HWTEST_F_L0(RuntimeImplTest, DispatcherImplRunIfWaitingForDebugger)
115{
116    std::string result = "";
117    std::function<void(const void*, const std::string &)> callback =
118        [&result]([[maybe_unused]] const void *ptr, const std::string &temp) {result = temp;};
119    ProtocolChannel *channel = new ProtocolHandler(callback, ecmaVm);
120    auto runtimeImpl = std::make_unique<RuntimeImpl>(ecmaVm, channel);
121    auto dispatcherImpl = std::make_unique<RuntimeImpl::DispatcherImpl>(channel, std::move(runtimeImpl));
122
123    std::string msg = std::string() + R"({"id":0,"method":"Rumtime.runIfWaitingForDebugger","params":{}})";
124    DispatchRequest request1(msg);
125    dispatcherImpl->RunIfWaitingForDebugger(request1);
126    ASSERT_TRUE(result == "{\"id\":0,\"result\":{}}");
127    if (channel != nullptr) {
128        delete channel;
129        channel = nullptr;
130    }
131}
132
133HWTEST_F_L0(RuntimeImplTest, DispatcherImplGetProperties)
134{
135    std::string result = "";
136    std::function<void(const void*, const std::string &)> callback =
137        [&result]([[maybe_unused]] const void *ptr, const std::string &temp) {result = temp;};
138    ProtocolChannel *channel = new ProtocolHandler(callback, ecmaVm);
139    auto runtimeImpl = std::make_unique<RuntimeImpl>(ecmaVm, channel);
140    auto dispatcherImpl = std::make_unique<RuntimeImpl::DispatcherImpl>(channel, std::move(runtimeImpl));
141
142    std::string msg = std::string() + R"({"id":0,"method":"Rumtime.getProperties","params":{"objectId":0}})";
143    DispatchRequest request(msg);
144    dispatcherImpl->GetProperties(request);
145    ASSERT_TRUE(result.find("wrong params") != std::string::npos);
146
147    msg = std::string() + R"({"id":0,"method":"Rumtime.getProperties","params":{"objectId":"0"}})";
148    DispatchRequest request1(msg);
149    dispatcherImpl->GetProperties(request1);
150    ASSERT_TRUE(result.find("Unknown object id") != std::string::npos);
151    if (channel != nullptr) {
152        delete channel;
153        channel = nullptr;
154    }
155}
156
157HWTEST_F_L0(RuntimeImplTest, DispatcherImplGetHeapUsage)
158{
159    std::string result = "";
160    std::function<void(const void*, const std::string &)> callback =
161        [&result]([[maybe_unused]] const void *ptr, const std::string &temp) {result = temp;};
162    ProtocolChannel *channel = new ProtocolHandler(callback, ecmaVm);
163    auto runtimeImpl = std::make_unique<RuntimeImpl>(ecmaVm, channel);
164    auto dispatcherImpl = std::make_unique<RuntimeImpl::DispatcherImpl>(channel, std::move(runtimeImpl));
165
166    std::string msg = std::string() + R"({"id":0,"method":"Rumtime.getHeapUsage ","params":{}})";
167    DispatchRequest request(msg);
168    dispatcherImpl->GetHeapUsage(request);
169    ASSERT_TRUE(result.find("usedSize") != std::string::npos);
170    ASSERT_TRUE(result.find("totalSize") != std::string::npos);
171    if (channel != nullptr) {
172        delete channel;
173        channel = nullptr;
174    }
175}
176}  // namespace panda::test
177