1fb726d48Sopenharmony_ci/*
2fb726d48Sopenharmony_ci * Copyright (C) 2022 Huawei Device Co., Ltd.
3fb726d48Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4fb726d48Sopenharmony_ci * you may not use this file except in compliance with the License.
5fb726d48Sopenharmony_ci * You may obtain a copy of the License at
6fb726d48Sopenharmony_ci *
7fb726d48Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8fb726d48Sopenharmony_ci *
9fb726d48Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10fb726d48Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11fb726d48Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12fb726d48Sopenharmony_ci * See the License for the specific language governing permissions and
13fb726d48Sopenharmony_ci * limitations under the License.
14fb726d48Sopenharmony_ci */
15fb726d48Sopenharmony_ci
16fb726d48Sopenharmony_ciimport { LogDataSender } from '../../../../src/trace/database/data-trafic/LogDataSender';
17fb726d48Sopenharmony_ciimport { threadPool } from '../../../../src/trace/database/SqlLite';
18fb726d48Sopenharmony_ciimport { LogStruct } from '../../../../src/trace/database/ui-worker/ProcedureWorkerLog';
19fb726d48Sopenharmony_ciimport { TraceRow } from '../../../../src/trace/component/trace/base/TraceRow';
20fb726d48Sopenharmony_cijest.mock('../../../../src/js-heap/model/DatabaseStruct', () => {});
21fb726d48Sopenharmony_ci
22fb726d48Sopenharmony_cijest.mock('../../../../src/trace/database/ui-worker/ProcedureWorker', () => {
23fb726d48Sopenharmony_ci  return {};
24fb726d48Sopenharmony_ci});
25fb726d48Sopenharmony_cijest.mock('../../../../src/trace/database/ui-worker/ProcedureWorkerSnapshot', () => {
26fb726d48Sopenharmony_ci  return {};
27fb726d48Sopenharmony_ci});
28fb726d48Sopenharmony_cidescribe('LogDataSender Test', () => {
29fb726d48Sopenharmony_ci  let logData = {
30fb726d48Sopenharmony_ci    id: 4,
31fb726d48Sopenharmony_ci    startTs: 16276,
32fb726d48Sopenharmony_ci    pid: 2082,
33fb726d48Sopenharmony_ci    tid: 2082,
34fb726d48Sopenharmony_ci    dur: 1,
35fb726d48Sopenharmony_ci    depth: 1,
36fb726d48Sopenharmony_ci    tag: 'C02c01/Init',
37fb726d48Sopenharmony_ci    context: '[param_request.c:53]Can not get log level from param, keep the original loglevel.',
38fb726d48Sopenharmony_ci    originTime: '08-06 15:43:19.954',
39fb726d48Sopenharmony_ci    processName: 'hilog',
40fb726d48Sopenharmony_ci    level: 'Info',
41fb726d48Sopenharmony_ci    frame: {
42fb726d48Sopenharmony_ci      'x': 1,
43fb726d48Sopenharmony_ci      'y': 7,
44fb726d48Sopenharmony_ci      'width': 1,
45fb726d48Sopenharmony_ci      'height': 7
46fb726d48Sopenharmony_ci    }
47fb726d48Sopenharmony_ci  }
48fb726d48Sopenharmony_ci  it('LogDataSenderTest01', () => {
49fb726d48Sopenharmony_ci    threadPool.submitProto = jest.fn((query: number, params: any, callback: Function) => {
50fb726d48Sopenharmony_ci      callback(logData, 1, true);
51fb726d48Sopenharmony_ci    });
52fb726d48Sopenharmony_ci    let logTraceRow = TraceRow.skeleton<LogStruct>();
53fb726d48Sopenharmony_ci    LogDataSender(logTraceRow).then(res => {
54fb726d48Sopenharmony_ci      expect(res).toHaveLength(1);
55fb726d48Sopenharmony_ci    });
56fb726d48Sopenharmony_ci  });
57fb726d48Sopenharmony_ci});