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_cijest.mock('../../../../src/trace/component/SpSystemTrace', () => {
17fb726d48Sopenharmony_ci  return {};
18fb726d48Sopenharmony_ci});
19fb726d48Sopenharmony_ciimport { SpChartManager } from '../../../../src/trace/component/chart/SpChartManager';
20fb726d48Sopenharmony_ciimport { SpLogChart } from '../../../../src/trace/component/chart/SpLogChart';
21fb726d48Sopenharmony_ci
22fb726d48Sopenharmony_cijest.mock('../../../../src/js-heap/model/DatabaseStruct');
23fb726d48Sopenharmony_ciconst sqlite = require('../../../../src/trace/database/sql/SqlLite.sql');
24fb726d48Sopenharmony_cijest.mock('../../../../src/trace/database/sql/SqlLite.sql');
25fb726d48Sopenharmony_ci
26fb726d48Sopenharmony_ciwindow.ResizeObserver =
27fb726d48Sopenharmony_ci  window.ResizeObserver ||
28fb726d48Sopenharmony_ci  jest.fn().mockImplementation(() => ({
29fb726d48Sopenharmony_ci    disconnect: jest.fn(),
30fb726d48Sopenharmony_ci    observe: jest.fn(),
31fb726d48Sopenharmony_ci    unobserve: jest.fn(),
32fb726d48Sopenharmony_ci  }));
33fb726d48Sopenharmony_ci
34fb726d48Sopenharmony_cidescribe('SpLogChart Test', () => {
35fb726d48Sopenharmony_ci  let htmlElement: any = document.createElement('sp-system-trace');
36fb726d48Sopenharmony_ci  let logChart = new SpLogChart(new SpChartManager(htmlElement));
37fb726d48Sopenharmony_ci  let queryLog = sqlite.queryLogData;
38fb726d48Sopenharmony_ci  let queryLogData = [
39fb726d48Sopenharmony_ci    {
40fb726d48Sopenharmony_ci      id: 2,
41fb726d48Sopenharmony_ci      startTs: 0,
42fb726d48Sopenharmony_ci      level: 'I',
43fb726d48Sopenharmony_ci      depth: 1,
44fb726d48Sopenharmony_ci      tag: 'C02d0c/Hiprofiler',
45fb726d48Sopenharmony_ci      context: 'ParseTimeExtend: update ts with 0 to 33727453411',
46fb726d48Sopenharmony_ci      time: 1502029274737385200,
47fb726d48Sopenharmony_ci      pid: 1119,
48fb726d48Sopenharmony_ci      tid: 1172,
49fb726d48Sopenharmony_ci      processName: 'hiprofiler_plug',
50fb726d48Sopenharmony_ci      dur: 1,
51fb726d48Sopenharmony_ci      frame: {
52fb726d48Sopenharmony_ci        x: 0,
53fb726d48Sopenharmony_ci        y: 7,
54fb726d48Sopenharmony_ci        width: 1,
55fb726d48Sopenharmony_ci        height: 7,
56fb726d48Sopenharmony_ci      },
57fb726d48Sopenharmony_ci    },
58fb726d48Sopenharmony_ci    {
59fb726d48Sopenharmony_ci      id: 37,
60fb726d48Sopenharmony_ci      startTs: 76402674,
61fb726d48Sopenharmony_ci      level: 'W',
62fb726d48Sopenharmony_ci      depth: 2,
63fb726d48Sopenharmony_ci      tag: 'C01300/AbilityManagerService',
64fb726d48Sopenharmony_ci      context: '[ability_manager_service.cpp(UpdateCallerInfo:6178)]UpdateCallerInfo caller abilityRecord is null.',
65fb726d48Sopenharmony_ci      time: 1502029274813788000,
66fb726d48Sopenharmony_ci      pid: 558,
67fb726d48Sopenharmony_ci      tid: 558,
68fb726d48Sopenharmony_ci      processName: 'foundation',
69fb726d48Sopenharmony_ci      dur: 1,
70fb726d48Sopenharmony_ci      frame: {
71fb726d48Sopenharmony_ci        x: 3,
72fb726d48Sopenharmony_ci        y: 14,
73fb726d48Sopenharmony_ci        width: 1,
74fb726d48Sopenharmony_ci        height: 7,
75fb726d48Sopenharmony_ci      },
76fb726d48Sopenharmony_ci    },
77fb726d48Sopenharmony_ci    {
78fb726d48Sopenharmony_ci      id: 99,
79fb726d48Sopenharmony_ci      startTs: 579581683,
80fb726d48Sopenharmony_ci      level: 'E',
81fb726d48Sopenharmony_ci      depth: 3,
82fb726d48Sopenharmony_ci      tag: 'C01300/AbilityManagerService',
83fb726d48Sopenharmony_ci      context: '[ability_interceptor.cpp(CheckCrowdtest:104)]GetApplicaionInfo from bms failed.',
84fb726d48Sopenharmony_ci      time: 1502029275316967000,
85fb726d48Sopenharmony_ci      pid: 558,
86fb726d48Sopenharmony_ci      tid: 558,
87fb726d48Sopenharmony_ci      processName: 'foundation',
88fb726d48Sopenharmony_ci      dur: 1,
89fb726d48Sopenharmony_ci      frame: {
90fb726d48Sopenharmony_ci        x: 29,
91fb726d48Sopenharmony_ci        y: 21,
92fb726d48Sopenharmony_ci        width: 1,
93fb726d48Sopenharmony_ci        height: 7,
94fb726d48Sopenharmony_ci      },
95fb726d48Sopenharmony_ci    },
96fb726d48Sopenharmony_ci  ];
97fb726d48Sopenharmony_ci  queryLog.mockResolvedValue(queryLogData);
98fb726d48Sopenharmony_ci  it('SpLogChart01', function () {
99fb726d48Sopenharmony_ci    expect(logChart.init()).toBeDefined();
100fb726d48Sopenharmony_ci  });
101fb726d48Sopenharmony_ci});
102