1e509ee18Sopenharmony_ci/*
2e509ee18Sopenharmony_ci * Copyright (c) 2022 Huawei Device Co., Ltd.
3e509ee18Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4e509ee18Sopenharmony_ci * you may not use this file except in compliance with the License.
5e509ee18Sopenharmony_ci * You may obtain a copy of the License at
6e509ee18Sopenharmony_ci *
7e509ee18Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8e509ee18Sopenharmony_ci *
9e509ee18Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10e509ee18Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11e509ee18Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12e509ee18Sopenharmony_ci * See the License for the specific language governing permissions and
13e509ee18Sopenharmony_ci * limitations under the License.
14e509ee18Sopenharmony_ci */
15e509ee18Sopenharmony_ci
16e509ee18Sopenharmony_ci#include "heapprofilergetheapobjectid_fuzzer.h"
17e509ee18Sopenharmony_ci#include "ecmascript/napi/include/jsnapi.h"
18e509ee18Sopenharmony_ci#include "agent/heapprofiler_impl.h"
19e509ee18Sopenharmony_ci#include "tooling/dispatcher.h"
20e509ee18Sopenharmony_ci
21e509ee18Sopenharmony_ciusing namespace panda;
22e509ee18Sopenharmony_ciusing namespace panda::ecmascript;
23e509ee18Sopenharmony_ciusing namespace panda::ecmascript::tooling;
24e509ee18Sopenharmony_ci
25e509ee18Sopenharmony_ci#define MAXBYTELEN sizeof(int32_t)
26e509ee18Sopenharmony_ci
27e509ee18Sopenharmony_cinamespace OHOS {
28e509ee18Sopenharmony_ci    void HeapprofilerGetheapObjectIdFuzzTest(const uint8_t* data, size_t size)
29e509ee18Sopenharmony_ci    {
30e509ee18Sopenharmony_ci        RuntimeOption option;
31e509ee18Sopenharmony_ci        option.SetLogLevel(RuntimeOption::LOG_LEVEL::ERROR);
32e509ee18Sopenharmony_ci        auto vm = JSNApi::CreateJSVM(option);
33e509ee18Sopenharmony_ci        if (size <= 0) {
34e509ee18Sopenharmony_ci            return;
35e509ee18Sopenharmony_ci        }
36e509ee18Sopenharmony_ci        int32_t input = 0;
37e509ee18Sopenharmony_ci        if (size > MAXBYTELEN) {
38e509ee18Sopenharmony_ci            size = MAXBYTELEN;
39e509ee18Sopenharmony_ci        }
40e509ee18Sopenharmony_ci        if (memcpy_s(&input, MAXBYTELEN, data, size) != 0) {
41e509ee18Sopenharmony_ci            std::cout << "memcpy_s failed!";
42e509ee18Sopenharmony_ci            UNREACHABLE();
43e509ee18Sopenharmony_ci        }
44e509ee18Sopenharmony_ci        std::string str(data, data + size);
45e509ee18Sopenharmony_ci        auto req = std::make_unique<DispatchRequest>(str);
46e509ee18Sopenharmony_ci        auto heapProfiler = std::make_unique<HeapProfilerImpl>(vm, nullptr);
47e509ee18Sopenharmony_ci        auto dispatcherImpl =
48e509ee18Sopenharmony_ci            std::make_unique<HeapProfilerImpl::DispatcherImpl>(nullptr, std::move(heapProfiler));
49e509ee18Sopenharmony_ci        dispatcherImpl->GetHeapObjectId(*req);
50e509ee18Sopenharmony_ci        JSNApi::DestroyJSVM(vm);
51e509ee18Sopenharmony_ci    }
52e509ee18Sopenharmony_ci}
53e509ee18Sopenharmony_ci
54e509ee18Sopenharmony_ci// Fuzzer entry point.
55e509ee18Sopenharmony_ciextern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size)
56e509ee18Sopenharmony_ci{
57e509ee18Sopenharmony_ci    // Run your code on data.
58e509ee18Sopenharmony_ci    OHOS::HeapprofilerGetheapObjectIdFuzzTest(data, size);
59e509ee18Sopenharmony_ci    return 0;
60e509ee18Sopenharmony_ci}