diff --git a/hiviewdfx/BUILD.gn b/hiviewdfx/BUILD.gn index e97b2a689b5ff70a29f338f1d3de61764de45fd7..aa8f453d33dc37ad887414f7f199a3ddc4ffc6f2 100644 --- a/hiviewdfx/BUILD.gn +++ b/hiviewdfx/BUILD.gn @@ -22,6 +22,7 @@ group("hiviewdfxtestacts") { "hidebugtest/hidebugtestjstest:ActsHiDebugTest", "hilogtest/hilogjstest:ActsHilogJsTest", "hilogtest/hilogndktest:hilogndktest", + "hisyseventtest/hisyseventjstest:ActsHiSysEventJsTest", "hitracechainjstest:ActsHiTraceChainJsTest", "hitracechaintest:ActsHiTraceChainTest", "hiview/faultlogger/faultloggerjs:faultloggerjs_test", diff --git a/hiviewdfx/hisyseventtest/hisyseventjstest/BUILD.gn b/hiviewdfx/hisyseventtest/hisyseventjstest/BUILD.gn new file mode 100755 index 0000000000000000000000000000000000000000..f347519e1f42025400f21e7ee519980a0672d681 --- /dev/null +++ b/hiviewdfx/hisyseventtest/hisyseventjstest/BUILD.gn @@ -0,0 +1,38 @@ +# Copyright (C) 2021 Huawei Device Co., Ltd. +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +import("//test/xts/tools/build/suite.gni") +ohos_js_hap_suite("ActsHiSysEventJsTest") { + hap_profile = "./src/main/config.json" + deps = [ + ":hisysevent_js_assets", + ":hisysevent_resources", + ] + + # shared_libraries = [ + # "//third_party/giflib:libgif", + # "//third_party/libpng:libpng", + # ] + certificate_profile = "./signature/openharmony_sx.p7b" + hap_name = "ActsHiSysEventJsTest" + + # part_name = "prebuilt_hap" + # subsystem_name = "xts" +} +ohos_js_assets("hisysevent_js_assets") { + source_dir = "./src/main/js/default" +} +ohos_resources("hisysevent_resources") { + sources = [ "./src/main/resources" ] + hap_profile = "./src/main/config.json" +} diff --git a/hiviewdfx/hisyseventtest/hisyseventjstest/Test.json b/hiviewdfx/hisyseventtest/hisyseventjstest/Test.json new file mode 100755 index 0000000000000000000000000000000000000000..c5264adb902d8ab95038fda6062489cf45e77231 --- /dev/null +++ b/hiviewdfx/hisyseventtest/hisyseventjstest/Test.json @@ -0,0 +1,18 @@ +{ + "description": "Configuration for hjunit demo Tests", + "driver": { + "type": "JSUnitTest", + "test-timeout": "270000", + "package": "ohos.acts.hiviewdfx.hisysevent.function", + "shell-timeout": "100000" + }, + "kits": [ + { + "test-file-name": [ + "ActsHiSysEventJsTest.hap" + ], + "type": "AppInstallKit", + "cleanup-apps": true + } + ] +} diff --git a/hiviewdfx/hisyseventtest/hisyseventjstest/signature/openharmony_sx.p7b b/hiviewdfx/hisyseventtest/hisyseventjstest/signature/openharmony_sx.p7b new file mode 100755 index 0000000000000000000000000000000000000000..9be1e98fa4c0c28ca997ed660112fa16b194f0f5 Binary files /dev/null and b/hiviewdfx/hisyseventtest/hisyseventjstest/signature/openharmony_sx.p7b differ diff --git a/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/config.json b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/config.json new file mode 100755 index 0000000000000000000000000000000000000000..d3064df89b96eb49d11334d7cc890eee98c6d969 --- /dev/null +++ b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/config.json @@ -0,0 +1,60 @@ +{ + "app": { + "bundleName": "ohos.acts.hiviewdfx.hisysevent.function", + "vendor": "example", + "version": { + "code": 1, + "name": "1.0" + }, + "apiVersion": { + "compatible": 4, + "target": 5 + } + }, + "deviceConfig": {}, + "module": { + "package": "ohos.acts.hiviewdfx.hisysevent.function", + "name": ".MyApplication", + "deviceType": [ + "phone" + ], + "distro": { + "deliveryWithInstall": true, + "moduleName": "entry", + "moduleType": "entry" + }, + "abilities": [ + { + "visible": true, + "skills": [ + { + "entities": [ + "entity.system.home" + ], + "actions": [ + "action.system.home" + ] + } + ], + "name": "ohos.acts.hiviewdfx.hisysevent.function.MainAbility", + "icon": "$media:icon", + "description": "$string:mainability_description", + "label": "MyApplication", + "type": "page", + "launchType": "standard" + } + ], + "js": [ + { + "pages": [ + "pages/index/index" + ], + "name": "default", + "window": { + "designWidth": 720, + "autoDesignWidth": false + } + } + ] + } +} diff --git a/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/app.js b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/app.js new file mode 100755 index 0000000000000000000000000000000000000000..3ee099f58926b1a7c42f02bb88ebb4998f9e4ac4 --- /dev/null +++ b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/app.js @@ -0,0 +1,22 @@ +/* + * Copyright (C) 2021 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +export default { + onCreate() { + console.info('AceApplication onCreate'); + }, + onDestroy() { + console.info('AceApplication onDestroy'); + } +}; diff --git a/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/i18n/en-US.json b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/i18n/en-US.json new file mode 100755 index 0000000000000000000000000000000000000000..e63c70d978a3a53be988388c87182f81785e170c --- /dev/null +++ b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/i18n/en-US.json @@ -0,0 +1,6 @@ +{ + "strings": { + "hello": "Hello", + "world": "World" + } +} \ No newline at end of file diff --git a/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/i18n/zh-CN.json b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/i18n/zh-CN.json new file mode 100755 index 0000000000000000000000000000000000000000..de6ee5748322f44942c1b003319d8e66c837675f --- /dev/null +++ b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/i18n/zh-CN.json @@ -0,0 +1,6 @@ +{ + "strings": { + "hello": "您好", + "world": "世界" + } +} \ No newline at end of file diff --git a/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/pages/index/index.css b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/pages/index/index.css new file mode 100755 index 0000000000000000000000000000000000000000..6fda792753f2e15f22b529c7b90a82185b2770bf --- /dev/null +++ b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/pages/index/index.css @@ -0,0 +1,9 @@ +.container { + flex-direction: column; + justify-content: center; + align-items: center; +} + +.title { + font-size: 100px; +} diff --git a/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/pages/index/index.hml b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/pages/index/index.hml new file mode 100755 index 0000000000000000000000000000000000000000..f64b040a5ae394dbaa5e185e1ecd4f4556b92184 --- /dev/null +++ b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/pages/index/index.hml @@ -0,0 +1,5 @@ +
+ + {{ $t('strings.hello') }} {{ title }} + +
diff --git a/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/pages/index/index.js b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/pages/index/index.js new file mode 100755 index 0000000000000000000000000000000000000000..d1af64d7509673fdd0d9026e70938277765862f4 --- /dev/null +++ b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/pages/index/index.js @@ -0,0 +1,46 @@ +/* + * Copyright (C) 2021 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +import app from '@system.app' +import device from '@system.device' +import router from '@system.router' +import {Core, ExpectExtend, Constant} from 'deccjsunit/index' + +const injectRef = Object.getPrototypeOf(global) || global +injectRef.regeneratorRuntime = require('@babel/runtime/regenerator') + +export default { + data: { + title: "" + }, + onInit() { + this.title = this.$t('strings.world'); + }, + onShow() { + console.info('onShow finish') + const core = Core.getInstance() + const expectExtend = new ExpectExtend({ + 'id': 'extend' + }) + core.addService('expect', expectExtend) + core.init() + const configService = core.getDefaultService('config') + configService.setConfig(this) + + require('../../test/List.test') + core.execute() + }, + onReady() { + }, +} \ No newline at end of file diff --git a/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/test/HiSysEvent.test.js b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/test/HiSysEvent.test.js new file mode 100755 index 0000000000000000000000000000000000000000..2acf52233ae0fab1829a2e0835cf96b13a8b7a85 --- /dev/null +++ b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/test/HiSysEvent.test.js @@ -0,0 +1,912 @@ +/* + * Copyright (C) 2021 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +import hiSysEvent from '@ohos.hiSysEvent' +import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from 'deccjsunit/index' + +describe('hiSysEventJsTest', function () { + beforeAll(function() { + console.info('hiSysEventJsTest beforeAll called') + }) + + afterAll(function() { + console.info('hiSysEventJsTest afterAll called') + }) + + beforeEach(function() { + console.info('hiSysEventJsTest beforeEach called') + }) + + afterEach(function() { + console.info('hiSysEventJsTest afterEach called') + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_0100 + * @tc.name testHiSysEventApi01 + * @tc.desc 添加Js打点事件-callback方式进行回调处理 + */ + it('testHiSysEventApi01', 1, async function (done) { + console.info('testHiSysEventApi01 start') + hiSysEvent.write({ + domain: "RELIABILITY", + name: "STACK", + eventType: hiSysEvent.EventType.FAULT, + },(err, value) => { + console.log('HiSysEvent into json-callback'); + if (err) { + console.error(`HiSysEvent json-callback-error code=${err.code}`); + expect().assertFail(); + done(); + } else { + console.log(`HiSysEvent json-callback-success value=${value}`); + expect(value == 0).assertTrue(); + done(); + } + }); + console.info('testHiSysEventApi01 end') + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_0200 + * @tc.name testHiSysEventApi02 + * @tc.desc 添加Js打点事件-Promise方式中then()方法进行打点成功回调处理 + */ + it('testHiSysEventApi02', 1, async function (done) { + console.info('testHiSysEventApi02 start') + hiSysEvent.write({ + domain: "RELIABILITY", + name: "STACK", + eventType: hiSysEvent.EventType.FAULT, + }).then( + (value) => { + console.log(`HiSysEvent json-callback-success value=${value}`); + expect(value == 0).assertTrue(); + done(); + } + ) + console.info('testHiSysEventApi02 end') + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_0400 + * @tc.name testHiSysEventApi04 + * @tc.desc HiSysEvent添加Js打点事件-添加成功后回调函数被调用(domain+eventName, eventType=FAULT) + */ + it('testHiSysEventApi04', 3, async function (done) { + console.info('testHiSysEventApi04 start') + hiSysEvent.write({ + domain: "RELIABILITY", + name: "STACK", + eventType: hiSysEvent.EventType.FAULT, + },(err, value) => { + console.log('HiSysEvent into json-callback'); + if (err) { + console.error(`HiSysEvent json-callback-error code=${err.code}`); + expect().assertFail(); + done(); + } else { + console.log(`HiSysEvent json-callback-success value=${value}`); + expect(value == 0).assertTrue(); + done(); + } + }); + console.info('testHiSysEventApi04 end') + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_0500 + * @tc.name testHiSysEventApi05 + * @tc.desc 添加Js打点事件-添加成功后回调函数被调用(domain+eventName, eventType=STATISTIC) + */ + it('testHiSysEventApi05', 3, async function (done) { + console.info('testHiSysEventApi05 start') + hiSysEvent.write({ + domain: "RELIABILITY", + name: "STACK", + eventType: hiSysEvent.EventType.STATISTIC, + },(err, value) => { + console.log('HiSysEvent into json-callback'); + if (err) { + console.error(`HiSysEvent json-callback-error code=${err.code}`); + expect().assertFail(); + done(); + } else { + console.log(`HiSysEvent json-callback-success value=${value}`); + expect(value == 0).assertTrue(); + done(); + } + }); + console.info('testHiSysEventApi05 end') + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_0600 + * @tc.name testHiSysEventApi06 + * @tc.desc 添加Js打点事件-添加成功后回调函数被调用(domain+eventName, eventType=SECURITY) + */ + it('testHiSysEventApi06', 3, async function (done) { + console.info('testHiSysEventApi06 start') + hiSysEvent.write({ + domain: "RELIABILITY", + name: "STACK", + eventType: hiSysEvent.EventType.SECURITY, + },(err, value) => { + console.log('HiSysEvent into json-callback'); + if (err) { + console.error(`HiSysEvent json-callback-error code=${err.code}`); + expect().assertFail(); + done(); + } else { + console.log(`HiSysEvent json-callback-success value=${value}`); + expect(value == 0).assertTrue(); + done(); + } + }); + console.info('testHiSysEventApi06 end') + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_0700 + * @tc.name testHiSysEventApi07 + * @tc.desc 添加Js打点事件-添加成功后回调函数被调用(domain+eventName, eventType=BEHAVIOR) + */ + it('testHiSysEventApi07', 3, async function (done) { + console.info('testHiSysEventApi07 start') + hiSysEvent.write({ + domain: "RELIABILITY", + name: "STACK", + eventType: hiSysEvent.EventType.BEHAVIOR, + },(err, value) => { + console.log('HiSysEvent into json-callback'); + if (err) { + console.error(`HiSysEvent json-callback-error code=${err.code}`); + expect().assertFail(); + done(); + } else { + console.log(`HiSysEvent json-callback-success value=${value}`); + expect(value == 0).assertTrue(); + done(); + } + }); + console.info('testHiSysEventApi07 end') + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_0800 + * @tc.name testHiSysEventApi08 + * @tc.desc 添加Js打点事件-添加成功后回调函数被调用(domain+eventName+params, eventType=FAULT) + */ + it('testHiSysEventApi08', 3, async function (done) { + console.info('testHiSysEventApi08 start') + hiSysEvent.write({ + domain: "RELIABILITY", + name: "STACK", + eventType: hiSysEvent.EventType.FAULT, + params: { + PID: 487, + UID: 103, + PACKAGE_NAME: "com.ohos.hisysevent.test", + PROCESS_NAME: "syseventservice", + MSG: "no msg." + } + },(err, value) => { + console.log('HiSysEvent into json-callback'); + if (err) { + console.error(`HiSysEvent json-callback-error code=${err.code}`); + expect().assertFail(); + done(); + } else { + console.log(`HiSysEvent json-callback-success value=${value}`); + expect(value == 0).assertTrue(); + done(); + } + }); + console.info('testHiSysEventApi08 end') + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_0900 + * @tc.name testHiSysEventApi09 + * @tc.desc HiSysEvent添加Js打点事件-添加成功后回调函数被调用(domain+eventName+params, eventType=STATISTIC) + */ + it('testHiSysEventApi09', 3, async function (done) { + console.info('testHiSysEventApi09 start') + hiSysEvent.write({ + domain: "RELIABILITY", + name: "STACK", + eventType: hiSysEvent.EventType.STATISTIC, + params: { + PID: 487, + UID: 103, + PACKAGE_NAME: "com.ohos.hisysevent.test", + PROCESS_NAME: "syseventservice", + MSG: "no msg." + } + },(err, value) => { + console.log('HiSysEvent into json-callback'); + if (err) { + console.error(`HiSysEvent json-callback-error code=${err.code}`); + expect().assertFail(); + done(); + } else { + console.log(`HiSysEvent json-callback-success value=${value}`); + expect(value == 0).assertTrue(); + done(); + } + }); + console.info('testHiSysEventApi09 end') + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_1000 + * @tc.name testHiSysEventApi10 + * @tc.desc HiSysEvent添加Js打点事件-添加成功后回调函数被调用(domain+eventName+params, eventType=SECURITY) + */ + it('testHiSysEventApi10', 3, async function (done) { + console.info('testHiSysEventApi10 start') + hiSysEvent.write({ + domain: "RELIABILITY", + name: "STACK", + eventType: hiSysEvent.EventType.SECURITY, + params: { + PID: 487, + UID: 103, + PACKAGE_NAME: "com.ohos.hisysevent.test", + PROCESS_NAME: "syseventservice", + MSG: "no msg." + } + },(err, value) => { + console.log('testHiSysEventApi10 into json-callback'); + if (err) { + console.error(`testHiSysEventApi10 json-callback-error code=${err.code}`); + expect().assertFail(); + done(); + } else { + console.log(`testHiSysEventApi10 json-callback-success value=${value}`); + expect(value == 0).assertTrue(); + done(); + } + }); + console.info('testHiSysEventApi10 end') + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_1100 + * @tc.name testHiSysEventApi11 + * @tc.desc HiSysEvent添加Js打点事件-添加成功后回调函数被调用(domain+eventName+params, eventType=BEHAVIOR) + */ + it('testHiSysEventApi11', 3, async function (done) { + console.info('testHiSysEventApi11 start') + hiSysEvent.write({ + domain: "RELIABILITY", + name: "STACK", + eventType: hiSysEvent.EventType.BEHAVIOR, + params: { + PID: 487, + UID: 103, + PACKAGE_NAME: "com.ohos.hisysevent.test", + PROCESS_NAME: "syseventservice", + MSG: "no msg." + } + },(err, value) => { + console.log('testHiSysEventApi11 into json-callback'); + if (err) { + console.error(`testHiSysEventApi11 json-callback-error code=${err.code}`); + expect().assertFail(); + done(); + } else { + console.log(`testHiSysEventApi11 json-callback-success value=${value}`); + expect(value == 0).assertTrue(); + done(); + } + }); + console.info('testHiSysEventApi11 end') + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_1200 + * @tc.name testHiSysEventApi12 + * @tc.desc HiSysEvent订阅接口测试-订阅成功回调函数被调用(domain+eventName, rule=PREFIX) + */ + it('testHiSysEventApi12', 3, async function (done) { + console.info('testHiSysEventApi12 start') + let watcher = { + rules: [{ + domain: "RELIABILITY", + name: "STACK", + ruleType: hiSysEvent.RuleType.PREFIX + }], + onEvent: (info) => { + console.info(`testHiSysEventApi12: OnEvent...`) + expect(Object.keys(info).length > 0).assertTrue() + console.info(`testHiSysEventApi12: domain is : ${info.domain}, name is ${info.name}, + eventType is ${info.eventType}`) + if (info.params instanceof Object) { + for (const key in info.params) { + console.info(`testHiSysEventApi12: ${key}: ${info.params[key]}`) + } + } + }, + onServiceDied: () => { + console.info(`testHiSysEventApi12 Onservice died`); + } + } + let result = hiSysEvent.addWatcher(watcher) + expect(result).assertEqual(0) + console.info('testHiSysEventApi12 end') + done(); + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_1300 + * @tc.name testHiSysEventApi13 + * @tc.desc HiSysEvent订阅接口测试-订阅成功回调函数被调用(domain+eventName, rule=REGULAR) + */ + it('testHiSysEventApi13', 3, async function (done) { + console.info('testHiSysEventApi13 start') + let watcher = { + rules: [{ + domain: "RELIABILITY", + name: "STACK", + ruleType: hiSysEvent.RuleType.REGULAR + }], + onEvent: (info) => { + console.info(`testHiSysEventApi13: OnEvent...`) + expect(Object.keys(info).length > 0).assertTrue() + console.info(`testHiSysEventApi13: domain is : ${info.domain}, name is ${info.name}, + eventType is ${info.eventType}`) + if (info.params instanceof Object) { + for (const key in info.params) { + console.info(`testHiSysEventApi13: ${key}: ${info.params[key]}`) + } + } + }, + onServiceDied: () => { + console.info(`testHiSysEventApi13 Onservice died`); + } + } + let result = hiSysEvent.addWatcher(watcher) + expect(result).assertEqual(0) + console.info('testHiSysEventApi13 end') + done(); + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_1400 + * @tc.name testHiSysEventApi14 + * @tc.desc HiSysEvent订阅接口测试-订阅成功回调函数被调用(domain+eventName, rule=WHOLE_WORD) + */ + it('testHiSysEventApi14', 3, async function (done) { + console.info('testHiSysEventApi14 start') + let watcher = { + rules: [{ + domain: "RELIABILITY", + name: "STACK", + ruleType: hiSysEvent.RuleType.WHOLE_WORD + }], + onEvent: (info) => { + console.info(`testHiSysEventApi14: OnEvent...`) + expect(Object.keys(info).length > 0).assertTrue() + console.info(`testHiSysEventApi14: domain is : ${info.domain}, name is ${info.name}, + eventType is ${info.eventType}`) + if (info.params instanceof Object) { + for (const key in info.params) { + console.info(`testHiSysEventApi14: ${key}: ${info.params[key]}`) + } + } + }, + onServiceDied: () => { + console.info(`testHiSysEventApi14 Onservice died`); + } + } + let result = hiSysEvent.addWatcher(watcher) + expect(result).assertEqual(0) + console.info('testHiSysEventApi14 end') + done(); + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_1500 + * @tc.name testHiSysEventApi15 + * @tc.desc HiSysEvent订阅接口测试-订阅成功回调函数被调用(domain+eventName+tag, rule=PREFIX) + */ + it('testHiSysEventApi15', 3, async function (done) { + console.info('testHiSysEventApi15 start') + let watcher = { + rules: [{ + domain: "RELIABILITY", + name: "STACK", + tag: "STABILITY", + ruleType: hiSysEvent.RuleType.PREFIX + }], + onEvent: (info) => { + console.info(`testHiSysEventApi15: OnEvent...`) + expect(Object.keys(info).length > 0).assertTrue() + console.info(`testHiSysEventApi15: domain is : ${info.domain}, name is ${info.name}, + eventType is ${info.eventType}`) + if (info.params instanceof Object) { + for (const key in info.params) { + console.info(`testHiSysEventApi15: ${key}: ${info.params[key]}`) + } + } + }, + onServiceDied: () => { + console.info(`testHiSysEventApi15 Onservice died`); + } + } + let result = hiSysEvent.addWatcher(watcher) + expect(result).assertEqual(0) + console.info('testHiSysEventApi15 end') + done(); + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_1600 + * @tc.name testHiSysEventApi16 + * @tc.desc HiSysEvent订阅接口测试-订阅成功回调函数被调用(domain+eventName+tag, rule=REGULAR) + */ + it('testHiSysEventApi16', 3, async function (done) { + console.info('testHiSysEventApi16 start') + let watcher = { + rules: [{ + domain: "RELIABILITY", + name: "STACK", + tag: "STABILITY", + ruleType: hiSysEvent.RuleType.REGULAR + }], + onEvent: (info) => { + console.info(`testHiSysEventApi16: OnEvent...`) + expect(Object.keys(info).length > 0).assertTrue() + console.info(`testHiSysEventApi16: domain is : ${info.domain}, + name is ${info.name}, eventType is ${info.eventType}`) + if (info.params instanceof Object) { + for (const key in info.params) { + console.info(`testHiSysEventApi16: ${key}: ${info.params[key]}`) + } + } + }, + onServiceDied: () => { + console.info(`testHiSysEventApi16 Onservice died`); + } + } + let result = hiSysEvent.addWatcher(watcher) + expect(result).assertEqual(0) + console.info('testHiSysEventApi16 end') + done(); + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_1700 + * @tc.name testHiSysEventApi17 + * @tc.desc HiSysEvent订阅接口测试-订阅成功回调函数被调用(domain+eventName+tag, rule=WHOLE_WORD) + */ + it('testHiSysEventApi17', 3, async function (done) { + console.info('testHiSysEventApi17 start') + let watcher = { + rules: [{ + domain: "RELIABILITY", + name: "STACK", + tag: "STABILITY", + ruleType: hiSysEvent.RuleType.WHOLE_WORD + }], + onEvent: (info) => { + console.info(`testHiSysEventApi17: OnEvent...`) + expect(Object.keys(info).length > 0).assertTrue() + console.info(`testHiSysEventApi17: domain is : ${info.domain}, name is ${info.name}, + eventType is ${info.eventType}`) + if (info.params instanceof Object) { + for (const key in info.params) { + console.info(`testHiSysEventApi17: ${key}: ${info.params[key]}`) + } + } + }, + onServiceDied: () => { + console.info(`testHiSysEventApi17 Onservice died`); + } + } + let result = hiSysEvent.addWatcher(watcher) + expect(result).assertEqual(0) + console.info('testHiSysEventApi17 end') + done(); + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_1800 + * @tc.name testHiSysEventApi18 + * @tc.desc HiSysEvent删除订阅接口测试-删除订阅成功回调函数被调用(domain+eventName, rule=PREFIX) + */ + it('testHiSysEventApi18', 3, async function (done) { + console.info('testHiSysEventApi18 start') + let watcher = { + rules: [{ + domain: "RELIABILITY", + name: "STACK", + ruleType: hiSysEvent.RuleType.PREFIX + }], + onEvent: (info) => { + console.info(`testHiSysEventApi18: OnEvent...`) + expect(Object.keys(info).length > 0).assertTrue() + console.info(`testHiSysEventApi18: domain is : ${info.domain}, name is ${info.name}, + eventType is ${info.eventType}`) + if (info.params instanceof Object) { + for (const key in info.params) { + console.info(`testHiSysEventApi18: ${key}: ${info.params[key]}`) + } + } + }, + onServiceDied: () => { + console.info(`testHiSysEventApi18 Onservice died`); + } + } + let result = hiSysEvent.addWatcher(watcher) + expect(result).assertEqual(0) + setTimeout(() => { + result = hiSysEvent.removeWatcher(watcher) + expect(result).assertEqual(0) + done() + console.info('testHiSysEventApi18 end') + }, 1000) + done(); + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_1900 + * @tc.name testHiSysEventApi19 + * @tc.desc HiSysEvent删除订阅接口测试-删除订阅成功回调函数被调用(domain+eventName, rule=REGULAR) + */ + it('testHiSysEventApi19', 3, async function (done) { + console.info('testHiSysEventApi19 start') + let watcher = { + rules: [{ + domain: "RELIABILITY", + name: "STACK", + ruleType: hiSysEvent.RuleType.REGULAR + }], + onEvent: (info) => { + console.info(`testHiSysEventApi19: OnEvent...`) + expect(Object.keys(info).length > 0).assertTrue() + console.info(`testHiSysEventApi19: domain is : ${info.domain}, name is ${info.name}, + eventType is ${info.eventType}`) + if (info.params instanceof Object) { + for (const key in info.params) { + console.info(`testHiSysEventApi19: ${key}: ${info.params[key]}`) + } + } + }, + onServiceDied: () => { + console.info(`testHiSysEventApi19 Onservice died`); + } + } + let result = hiSysEvent.addWatcher(watcher) + expect(result).assertEqual(0) + setTimeout(() => { + result = hiSysEvent.removeWatcher(watcher) + expect(result).assertEqual(0) + done() + console.info('testHiSysEventApi19 end') + }, 1000) + done(); + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_2000 + * @tc.name testHiSysEventApi20 + * @tc.desc HiSysEvent删除订阅接口测试-删除订阅成功回调函数被调用(domain+eventName, rule=WHOLE_WORD) + */ + it('testHiSysEventApi20', 3, async function (done) { + console.info('testHiSysEventApi14 start') + let watcher = { + rules: [{ + domain: "RELIABILITY", + name: "STACK", + ruleType: hiSysEvent.RuleType.WHOLE_WORD + }], + onEvent: (info) => { + console.info(`testHiSysEventApi20: OnEvent...`) + expect(Object.keys(info).length > 0).assertTrue() + console.info(`testHiSysEventApi20: domain is : ${info.domain}, name is ${info.name}, + eventType is ${info.eventType}`) + if (info.params instanceof Object) { + for (const key in info.params) { + console.info(`testHiSysEventApi20: ${key}: ${info.params[key]}`) + } + } + }, + onServiceDied: () => { + console.info(`testHiSysEventApi20 Onservice died`); + } + } + let result = hiSysEvent.addWatcher(watcher) + expect(result).assertEqual(0) + setTimeout(() => { + result = hiSysEvent.removeWatcher(watcher) + expect(result).assertEqual(0) + done() + console.info('testHiSysEventApi20 end') + }, 1000) + done(); + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_2100 + * @tc.name testHiSysEventApi21 + * @tc.desc HiSysEvent删除订阅接口测试-删除订阅成功回调函数被调用(domain+eventName+tag, rule=PREFIX) + */ + it('testHiSysEventApi21', 3, async function (done) { + console.info('testHiSysEventApi21 start') + let watcher = { + rules: [{ + domain: "RELIABILITY", + name: "STACK", + tag: "STABILITY", + ruleType: hiSysEvent.RuleType.PREFIX + }], + onEvent: (info) => { + console.info(`testHiSysEventApi21: OnEvent...`) + expect(Object.keys(info).length > 0).assertTrue() + console.info(`testHiSysEventApi21: domain is : ${info.domain}, name is ${info.name}, + eventType is ${info.eventType}`) + if (info.params instanceof Object) { + for (const key in info.params) { + console.info(`testHiSysEventApi21: ${key}: ${info.params[key]}`) + } + } + }, + onServiceDied: () => { + console.info(`testHiSysEventApi21 Onservice died`); + } + } + let result = hiSysEvent.addWatcher(watcher) + expect(result).assertEqual(0) + setTimeout(() => { + result = hiSysEvent.removeWatcher(watcher) + expect(result).assertEqual(0) + done() + console.info('testHiSysEventApi21 end') + }, 1000) + done(); + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_2200 + * @tc.name testHiSysEventApi22 + * @tc.desc HiSysEvent删除订阅接口测试-删除订阅成功回调函数被调用(domain+eventName+tag, rule=REGULAR) + */ + it('testHiSysEventApi22', 3, async function (done) { + console.info('testHiSysEventApi22 start') + let watcher = { + rules: [{ + domain: "RELIABILITY", + name: "STACK", + tag: "STABILITY", + ruleType: hiSysEvent.RuleType.REGULAR + }], + onEvent: (info) => { + console.info(`testHiSysEventApi22: OnEvent...`) + expect(Object.keys(info).length > 0).assertTrue() + console.info(`testHiSysEventApi22: domain is : ${info.domain}, name is ${info.name}, + eventType is ${info.eventType}`) + if (info.params instanceof Object) { + for (const key in info.params) { + console.info(`testHiSysEventApi22: ${key}: ${info.params[key]}`) + } + } + }, + onServiceDied: () => { + console.info(`testHiSysEventApi22 Onservice died`); + } + } + let result = hiSysEvent.addWatcher(watcher) + expect(result).assertEqual(0) + setTimeout(() => { + result = hiSysEvent.removeWatcher(watcher) + expect(result).assertEqual(0) + done() + console.info('testHiSysEventApi22 end') + }, 1000) + done(); + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_2300 + * @tc.name testHiSysEventApi23 + * @tc.desc HiSysEvent删除订阅接口测试-删除订阅成功回调函数被调用(domain+eventName+tag, rule=WHOLE_WORD) + */ + it('testHiSysEventApi23', 3, async function (done) { + console.info('testHiSysEventApi23 start') + let watcher = { + rules: [{ + domain: "RELIABILITY", + name: "STACK", + tag: "STABILITY", + ruleType: hiSysEvent.RuleType.WHOLE_WORD + }], + onEvent: (info) => { + console.info(`testHiSysEventApi23: OnEvent...`) + expect(Object.keys(info).length > 0).assertTrue() + console.info(`testHiSysEventApi23: domain is : ${info.domain}, name is ${info.name}, + eventType is ${info.eventType}`) + if (info.params instanceof Object) { + for (const key in info.params) { + console.info(`testHiSysEventApi23: ${key}: ${info.params[key]}`) + } + } + }, + onServiceDied: () => { + console.info(`testHiSysEventApi23 Onservice died`); + } + } + let result = hiSysEvent.addWatcher(watcher) + expect(result).assertEqual(0) + setTimeout(() => { + result = hiSysEvent.removeWatcher(watcher) + expect(result).assertEqual(0) + done() + console.info('testHiSysEventApi23 end') + }, 1000) + done(); + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_2400 + * @tc.name testHiSysEventApi24 + * @tc.desc HiSysEvent查询接口测试-查询成功回调函数被调用(查询一个事件) + */ + it('testHiSysEventApi24', 1, async function (done) { + console.info('testHiSysEventApi24 start') + hiSysEvent.write({ + domain: "RELIABILITY", + name: "STACK", + eventType: hiSysEvent.EventType.SECURITY, + params: { + PID: 487, + UID: 103, + PACKAGE_NAME: "com.ohos.hisysevent.test", + PROCESS_NAME: "syseventservice", + MSG: "no msg." + } + },(err, value) => { + console.log('testHiSysEventApi24 into json-callback'); + if (err) { + console.error('in testHiSysEventApi24 test callback: err.code = ' + err.code) + result = err.code + } else { + console.info('in testHiSysEventApi24 test callback: result = ' + value) + result = value; + } + }); + setTimeout(() => { + let ret = hiSysEvent.query({ + beginTime: -1, + endTime: -1, + maxEvents: 1, + }, [{ + domain: "RELIABILITY", + names: ["STACK"], + }], { + onQuery: function (infos, seqs) { + console.info(`testHiSysEventApi24: onQuery...`) + expect(infos.length >= 0).assertTrue() + expect(seqs.length >= 0).assertTrue() + console.info(`testHiSysEventApi24: infos.size is ${infos.length}, seqs.length is ${seqs.length}`) + if (infos instanceof Array) { + for (let i = 0; i < infos.length; i++) { + let item = infos[i]; + console.info(`testHiSysEventApi24: domain is ${item.domain}, name is ${item.name}, + eventType is ${item.eventType}`) + if (item.params instanceof Object) { + for (const key in item.params) { + console.info(`testHiSysEventApi24: ${key}: ${item.params[key]}`) + } + } + } + } + if (seqs instanceof Array) { + for (let i = 0; i < seqs.length; i++) { + let item = seqs[i]; + console.info(`testHiSysEventApi24: seq${i}: ${item}`) + } + } + }, + onComplete: function(reason, total) { + console.info(`testHiSysEventApi24: onComplete...`) + console.info(`testHiSysEventApi24: reason is ${reason}, total is ${total}`) + done() + console.info(`testHiSysEventApi24 end`) + } + }) + expect(ret).assertEqual(0) + }, 1000); + }) + + /** + * @tc.number DFX_DFT_HiSysEvent_JS_2500 + * @tc.name testHiSysEventApi25 + * @tc.desc HiSysEvent查询接口测试-查询成功回调函数被调用(查询多个事件) + */ + it('testHiSysEventApi25', 1, async function (done) { + console.info('testHiSysEventApi25 start') + hiSysEvent.write({ + domain: "AAFWK", + name: "JS_ERROR", + eventType: hiSysEvent.EventType.SECURITY, + },(err, value) => { + console.log('testHiSysEventApi25 into json-callback'); + if (err) { + console.error('in testHiSysEventApi25 test callback: err.code = ' + err.code) + result = err.code + } else { + console.info('in testHiSysEventApi25 test callback: result = ' + value) + result = value; + } + }); + hiSysEvent.write({ + domain: "AAFWK", + name: "LIFECYCLE_TIMEOUT", + eventType: hiSysEvent.EventType.STATISTIC, + },(err, value) => { + console.log('testHiSysEventApi25 into json-callback'); + if (err) { + console.error('in testHiSysEventApi25 test callback: err.code = ' + err.code) + result = err.code + } else { + console.info('in testHiSysEventApi25 test callback: result = ' + value) + result = value; + } + }); + setTimeout(() => { + let ret = hiSysEvent.query({ + beginTime: -1, + endTime: -1, + maxEvents: 5, + }, [{ + domain: "AAFWK", + names: ["JS_ERROR","LIFECYCLE_TIMEOUT"], + }], { + onQuery: function (infos, seqs) { + console.info(`testHiSysEventApi25: onQuery...`) + expect(infos.length >= 0).assertTrue() + expect(seqs.length >= 0).assertTrue() + console.info(`testHiSysEventApi25: infos.size is ${infos.length}, seqs.length is ${seqs.length}`) + if (infos instanceof Array) { + for (let i = 0; i < infos.length; i++) { + let item = infos[i]; + console.info(`testHiSysEventApi25: domain is ${item.domain}, name is ${item.name}, + eventType is ${item.eventType}`) + if (item.params instanceof Object) { + for (const key in item.params) { + console.info(`testHiSysEventApi25: ${key}: ${item.params[key]}`) + } + } + } + } + if (seqs instanceof Array) { + for (let i = 0; i < seqs.length; i++) { + let item = seqs[i]; + console.info(`testHiSysEventApi25: seq${i}: ${item}`) + } + } + }, + onComplete: function(reason, total) { + console.info(`testHiSysEventApi25: onComplete...`) + console.info(`testHiSysEventApi25: reason is ${reason}, total is ${total}`) + done() + console.info(`testHiSysEventApi25 end`) + } + }) + expect(ret).assertEqual(0) + }, 1000); + }) +}) diff --git a/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/test/List.test.js b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/test/List.test.js new file mode 100755 index 0000000000000000000000000000000000000000..7bd9c7ce685761419393f2df9988670ebbbebefa --- /dev/null +++ b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/js/default/test/List.test.js @@ -0,0 +1,15 @@ +/* + * Copyright (C) 2021 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +require('./HiSysEvent.test.js') diff --git a/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/resources/base/element/string.json b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/resources/base/element/string.json new file mode 100755 index 0000000000000000000000000000000000000000..ab025e765292c86abf35e594e18f4e4549ed2f06 --- /dev/null +++ b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/resources/base/element/string.json @@ -0,0 +1,12 @@ +{ + "string": [ + { + "name": "app_name", + "value": "test2demo" + }, + { + "name": "mainability_description", + "value": "hap sample empty page" + } + ] +} diff --git a/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/resources/base/media/icon.png b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/resources/base/media/icon.png new file mode 100755 index 0000000000000000000000000000000000000000..ce307a8827bd75456441ceb57d530e4c8d45d36c Binary files /dev/null and b/hiviewdfx/hisyseventtest/hisyseventjstest/src/main/resources/base/media/icon.png differ