提交 b5ef29f8 编写于 作者: 1 15929983503

hisysevent normal app commit for master

Signed-off-by: N15929983503 <duanhaizhen@huawei.com>
上级 324cbd49
......@@ -28,6 +28,7 @@ group("hiviewdfxtestacts") {
"hilogtest/hilogjstest:ActsHilogJsTest",
"hilogtest/hilogndktest:ActsHilogndkTest",
"hisyseventtest/hisyseventjstest:ActsHiSysEventJsTest",
"hisyseventtest/hisyseventnormaltest:ActsHiSysEventNormalTest",
"hitracechainjstest:ActsHiTraceChainJsTest",
"hitracemetertest:ActsHitraceMeterTest",
"hiview/faultlogger/faultloggerjs:faultloggerjs_test",
......
# 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("ActsHiSysEventNormalTest") {
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 = "ActsHiSysEventNormalTest"
# part_name = "prebuilt_hap"
# subsystem_name = "xts"
}
ohos_js_assets("hisysevent_js_assets") {
js2abc = true
hap_profile = "./src/main/config.json"
source_dir = "./src/main/js"
}
ohos_resources("hisysevent_resources") {
sources = [ "./src/main/resources" ]
hap_profile = "./src/main/config.json"
}
{
"description": "Configuration for hjunit demo Tests",
"driver": {
"type": "OHJSUnitTest",
"test-timeout": "270000",
"shell-timeout": "270000",
"bundle-name": "ohos.acts.hiviewdfx.hisysevent.normalapp.function",
"package-name": "ohos.acts.hiviewdfx.hisysevent.normalapp.function"
},
"kits": [
{
"test-file-name": [
"ActsHiSysEventNormalTest.hap"
],
"type": "AppInstallKit",
"cleanup-apps": true
}
]
}
{
"app": {
"bundleName": "ohos.acts.hiviewdfx.hisysevent.normalapp.function",
"vendor": "example",
"version": {
"code": 1,
"name": "1.0"
},
"apiVersion": {
"compatible": 4,
"target": 5
}
},
"deviceConfig": {},
"module": {
"package": "ohos.acts.hiviewdfx.hisysevent.normalapp.function",
"name": ".entry",
"deviceType": [
"tablet",
"default",
"phone"
],
"distro": {
"deliveryWithInstall": true,
"moduleName": "entry",
"moduleType": "entry"
},
"reqPermissions": [
{
"name": "ohos.permission.READ_DFX_SYSEVENT"
}
],
"abilities": [
{
"skills": [
{
"entities": [
"entity.system.home"
],
"actions": [
"action.system.home"
]
}
],
"orientation": "unspecified",
"formsEnabled": false,
"name": ".MainAbility",
"srcLanguage": "js",
"srcPath": "MainAbility",
"icon": "$media:icon",
"description": "$string:MainAbility_desc",
"label": "$string:MainAbility_label",
"type": "page",
"visible": true,
"launchType": "standard"
},
{
"orientation": "unspecified",
"formsEnabled": false,
"name": ".TestAbility",
"srcLanguage": "js",
"srcPath": "TestAbility",
"icon": "$media:icon",
"description": "$string:TestAbility_desc",
"label": "$string:TestAbility_label",
"type": "page",
"visible": true,
"launchType": "standard"
}
],
"js": [
{
"pages": [
"pages/index/index"
],
"name": "default",
"window": {
"designWidth": 720,
"autoDesignWidth": false
}
},
{
"pages": [
"pages/index/index"
],
"name": ".TestAbility",
"window": {
"designWidth": 720,
"autoDesignWidth": false
}
}
],
"testRunner": {
"name": "OpenHarmonyTestRunner",
"srcPath": "TestRunner"
},
"mainAbility": ".MainAbility",
"srcPath": ""
}
}
\ No newline at end of file
/*
* 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');
}
};
{
"strings": {
"hello": "Hello",
"world": "World"
}
}
\ No newline at end of file
{
"strings": {
"hello": "您好",
"world": "世界"
}
}
\ No newline at end of file
.container {
flex-direction: column;
justify-content: center;
align-items: center;
}
.title {
font-size: 100px;
}
<div class="container">
<text class="title">
{{ $t('strings.hello') }} {{ title }}
</text>
</div>
/*
* 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'
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')
},
onReady() {
},
}
\ No newline at end of file
/*
* Copyright (c) 2022 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 AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry'
import { Hypium } from '@ohos/hypium'
import testsuite from '../test/List.test'
export default {
onCreate() {
console.info('TestApplication onCreate')
var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
console.info('start run testcase!!!')
Hypium.hypiumTest(abilityDelegator, abilityDelegatorArguments, testsuite)
},
onDestroy() {
console.info("TestApplication onDestroy");
}
};
{
"strings": {
"hello": "Hello",
"world": "World"
},
"Files": {
}
}
\ No newline at end of file
{
"strings": {
"hello": "您好",
"world": "世界"
},
"Files": {
}
}
\ No newline at end of file
.container {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
left: 0px;
top: 0px;
width: 100%;
height: 100%;
}
.title {
font-size: 60px;
text-align: center;
width: 100%;
height: 40%;
margin: 10px;
}
@media screen and (device-type: phone) and (orientation: landscape) {
.title {
font-size: 60px;
}
}
@media screen and (device-type: tablet) and (orientation: landscape) {
.title {
font-size: 100px;
}
}
\ No newline at end of file
<div class="container">
<text class="title">
{{ $t('strings.hello') }} {{ title }}
</text>
</div>
/*
* Copyright (c) 2022 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 {
data: {
title: ""
},
onInit() {
this.title = this.$t('strings.world');
}
}
/*
* Copyright (c) 2022 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 AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry'
function translateParamsToString(parameters) {
const keySet = new Set([
'-s class', '-s notClass', '-s suite', '-s itName',
'-s level', '-s testType', '-s size', '-s timeout',
'-s package', '-s dryRun'
])
let targetParams = '';
for (const key in parameters) {
if (keySet.has(key)) {
targetParams += ' ' + key + ' ' + parameters[key]
}
}
return targetParams.trim()
}
export default {
onPrepare() {
console.info('OpenHarmonyTestRunner OnPrepare')
},
onRun() {
console.log('OpenHarmonyTestRunner onRun run')
var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
var testAbilityName = abilityDelegatorArguments.parameters['-p'] + '.TestAbility'
var cmd = 'aa start -d 0 -a ' + testAbilityName + ' -b ' + abilityDelegatorArguments.bundleName
cmd += ' ' + translateParamsToString(abilityDelegatorArguments.parameters)
var debug = abilityDelegatorArguments.parameters["-D"]
console.info('debug value : '+debug)
if (debug == 'true')
{
cmd += ' -D'
}
console.info('cmd : '+cmd)
abilityDelegator.executeShellCommand(cmd, (err, data) => {
console.info('executeShellCommand : err : ' + JSON.stringify(err));
console.info('executeShellCommand : data : ' + data.stdResult);
console.info('executeShellCommand : data : ' + data.exitCode);
})
}
};
/*
* 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 '@ohos/hypium'
export default function hiSysEventNormalTest() {
describe('hiSysEventNormalTest', function () {
beforeAll(function() {
console.info('hiSysEventNormalTest beforeAll called')
})
afterAll(function() {
console.info('hiSysEventNormalTest afterAll called')
})
beforeEach(function() {
console.info('hiSysEventNormalTest beforeEach called')
})
afterEach(function() {
console.info('hiSysEventNormalTest afterEach called')
})
/**
* @tc.number DFX_DFT_HiSysEvent_JS_5800
* @tc.name testHiSysEventApi58
* @tc.desc 验证普通应用调用write接口使用callback方式进行回调处理,返回错误码202
*/
it('testHiSysEventApi58', 1, async function (done) {
console.info('testHiSysEventApi58 start')
try {
hiSysEvent.write({
domain: "RELIABILITY",
name: "STACK",
eventType: hiSysEvent.EventType.FAULT,
},(err, val) => {
if (err) {
console.error('in testHiSysEventApi58 test callback: err.code = ' + err.code)
} else {
console.info('in testHiSysEventApi58 test callback: result = ' + val)
}
})
} catch (err) {
console.error(`testHiSysEventApi58 > error code: ${err.code}, error msg: ${err.message}`)
expect(err.code == 202).assertTrue()
console.info('testHiSysEventApi58 end')
done()
}
console.info('testHiSysEventApi58 end')
})
/**
* @tc.number DFX_DFT_HiSysEvent_JS_5900
* @tc.name testHiSysEventApi59
* @tc.desc 验证普通应用调用write接口使用Promise方式进行回调处理,返回错误码202
*/
it('testHiSysEventApi59', 1, async function (done) {
console.info('testHiSysEventApi59 start')
try {
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();
}
).catch(
(err) => {
console.error(`HiSysEvent json-callback-error code=${err.code}`);
expect(err.code == 0).assertFail();
}
)
} catch (err) {
console.error(`testHiSysEventApi59 > error code: ${err.code}, error msg: ${err.message}`)
expect(err.code == 202).assertTrue()
console.info('testHiSysEventApi59 end')
done()
}
console.info('testHiSysEventApi59 end')
})
/**
* @tc.number DFX_DFT_HiSysEvent_JS_6000
* @tc.name testHiSysEventApi60
* @tc.desc 验证普通应用调用订阅接口,规则为domain+eventName, rule=PREFIX,返回错误码202
*/
it('testHiSysEventApi60', 3, async function (done) {
console.info('testHiSysEventApi60 start')
let watcher = {
rules: [{
domain: "RELIABIL",
name: "STACK",
tag: "STABIL",
ruleType: hiSysEvent.RuleType.PREFIX
}],
onEvent: (info) => {
console.info(`testHiSysEventApi60: OnEvent...`)
expect(Object.keys(info).length > 0).assertTrue()
console.info(`testHiSysEventApi60: 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(`testHiSysEventApi60: ${key}: ${info.params[key]}`)
}
}
},
onServiceDied: () => {
console.info(`testHiSysEventApi60 Onservice died`);
}
}
try {
hiSysEvent.addWatcher(watcher)
expect(true).assertTrue()
console.info('testHiSysEventApi60 end')
done();
} catch (err) {
console.error(`testHiSysEventApi60 > error code: ${err.code}, error msg: ${err.message}`)
expect(err.code == 202).assertTrue()
console.info('testHiSysEventApi60 end')
done()
}
})
/**
* @tc.number DFX_DFT_HiSysEvent_JS_6100
* @tc.name testHiSysEventApi61
* @tc.desc 验证普通应用调用订阅接口,规则为domain+eventName, rule=REGULAR,返回错误码202
*/
it('testHiSysEventApi61', 3, async function (done) {
console.info('testHiSysEventApi61 start')
let watcher = {
rules: [{
domain: "RELIABIL\\w+",
name: "STACK",
ruleType: hiSysEvent.RuleType.REGULAR
}],
onEvent: (info) => {
console.info(`testHiSysEventApi61: OnEvent...`)
expect(Object.keys(info).length > 0).assertTrue()
console.info(`testHiSysEventApi61: 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(`testHiSysEventApi61: ${key}: ${info.params[key]}`)
}
}
},
onServiceDied: () => {
console.info(`testHiSysEventApi61 Onservice died`);
}
}
try {
hiSysEvent.addWatcher(watcher)
expect(true).assertTrue()
console.info('testHiSysEventApi61 end')
done();
} catch (err) {
console.error(`testHiSysEventApi61 > error code: ${err.code}, error msg: ${err.message}`)
expect(err.code == 202).assertTrue()
console.info('testHiSysEventApi61 end')
done()
}
})
/**
* @tc.number DFX_DFT_HiSysEvent_JS_6200
* @tc.name testHiSysEventApi62
* @tc.desc 验证普通应用调用订阅接口,规则为domain+eventName, rule=WHOLE_WORD,返回错误码202
*/
it('testHiSysEventApi62', 3, async function (done) {
console.info('testHiSysEventApi62 start')
let watcher = {
rules: [{
domain: "RELIABILITY",
name: "STACK",
ruleType: hiSysEvent.RuleType.WHOLE_WORD
}],
onEvent: (info) => {
console.info(`testHiSysEventApi62: OnEvent...`)
expect(Object.keys(info).length > 0).assertTrue()
console.info(`testHiSysEventApi62: 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(`testHiSysEventApi62: ${key}: ${info.params[key]}`)
}
}
},
onServiceDied: () => {
console.info(`testHiSysEventApi62 Onservice died`);
}
}
try {
hiSysEvent.addWatcher(watcher)
expect(true).assertTrue()
console.info('testHiSysEventApi62 end')
done();
} catch (err) {
console.error(`testHiSysEventApi62 > error code: ${err.code}, error msg: ${err.message}`)
expect(err.code == 202)
console.info('testHiSysEventApi62 end')
done()
}
})
/**
* @tc.number DFX_DFT_HiSysEvent_JS_6300
* @tc.name testHiSysEventApi63
* @tc.desc 验证普通应用调用订阅接口,规则为domain+eventName+tag, rule=PREFIX,返回错误码202
*/
it('testHiSysEventApi63', 3, async function (done) {
console.info('testHiSysEventApi63 start')
let watcher = {
rules: [{
domain: "RELIABIL",
name: "STACK",
tag: "STABILI",
ruleType: hiSysEvent.RuleType.PREFIX
}],
onEvent: (info) => {
console.info(`testHiSysEventApi63: OnEvent...`)
expect(Object.keys(info).length > 0).assertTrue()
console.info(`testHiSysEventApi63: 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(`testHiSysEventApi63: ${key}: ${info.params[key]}`)
}
}
},
onServiceDied: () => {
console.info(`testHiSysEventApi63 Onservice died`);
}
}
try {
hiSysEvent.addWatcher(watcher)
expect(true).assertTrue()
console.info('testHiSysEventApi63 end')
done();
} catch (err) {
console.error(`testHiSysEventApi63 > error code: ${err.code}, error msg: ${err.message}`)
expect(err.code == 202).assertTrue()
console.info('testHiSysEventApi63 end')
done()
}
})
/**
* @tc.number DFX_DFT_HiSysEvent_JS_6400
* @tc.name testHiSysEventApi64
* @tc.desc 验证普通应用调用订阅接口,规则为tag, rule=REGULAR,返回错误码202
*/
it('testHiSysEventApi64', 3, async function (done) {
console.info('testHiSysEventApi64 start')
let watcher = {
rules: [{
tag: "STABIL\\w+",
ruleType: hiSysEvent.RuleType.REGULAR
}],
onEvent: (info) => {
console.info(`testHiSysEventApi64: OnEvent...`)
expect(Object.keys(info).length > 0).assertTrue()
console.info(`testHiSysEventApi64: 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(`testHiSysEventApi64: ${key}: ${info.params[key]}`)
}
}
},
onServiceDied: () => {
console.info(`testHiSysEventApi64 Onservice died`);
}
}
try {
hiSysEvent.addWatcher(watcher)
expect(true).assertTrue()
console.info('testHiSysEventApi64 end')
done();
} catch (err) {
console.error(`testHiSysEventApi64 > error code: ${err.code}, error msg: ${err.message}`)
expect(err.code == 202).assertTrue()
console.info('testHiSysEventApi64 end')
done()
}
})
/**
* @tc.number DFX_DFT_HiSysEvent_JS_6500
* @tc.name testHiSysEventApi65
* @tc.desc 验证普通应用调用删除订阅接口,返回错误码202
*/
it('testHiSysEventApi65', 3, async function (done) {
console.info('testHiSysEventApi18 start')
let watcher = {
rules: [{
domain: "RELIABILITY",
name: "STACK",
ruleType: hiSysEvent.RuleType.PREFIX
}],
onEvent: (info) => {
console.info(`testHiSysEventApi65: OnEvent...`)
expect(Object.keys(info).length > 0).assertTrue()
console.info(`testHiSysEventApi65: 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(`testHiSysEventApi65: ${key}: ${info.params[key]}`)
}
}
},
onServiceDied: () => {
console.info(`testHiSysEventApi65 Onservice died`);
}
}
setTimeout(() => {
try {
hiSysEvent.removeWatcher(watcher)
expect(true).assertTrue()
console.info('testHiSysEventApi65 end')
done();
} catch (err) {
console.error(`testHiSysEventApi65 > error code: ${err.code}, error msg: ${err.message}`)
expect(err.code == 202).assertTrue()
console.info('testHiSysEventApi65 end')
done()
}
}, 1000)
})
/**
* @tc.number DFX_DFT_HiSysEvent_JS_6600
* @tc.name testHiSysEventApi66
* @tc.desc 验证普通应用调用查询订阅接口,返回错误码202
*/
it('testHiSysEventApi66', 1, async function (done) {
console.info('testHiSysEventApi66 start')
try {
hiSysEvent.query({
beginTime: -1,
endTime: -1,
maxEvents: 500000,
}, [{
domain: "RELIABILITY" ,
names: ["STACK"],
}], {
onQuery: function (infos) {
},
onComplete: function(reason, total) {
done()
}
})
} catch (err) {
console.error(`testHiSysEventApi66 delay > error code: ${err.code}, error msg: ${err.message}`)
expect(err.code == 202).assertTrue()
console.info('testHiSysEventApi66 end')
done()
}
})
})
}
/*
* 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 hiSysEventNormalTest from './HiSysEventNormal.test.js'
export default function testsuite() {
hiSysEventNormalTest()
}
{
"string": [
{
"name": "app_name",
"value": "test2demo"
},
{
"name": "mainability_description",
"value": "hap sample empty page"
},
{
"name": "MainAbility_desc",
"value": "description"
},
{
"name": "MainAbility_label",
"value": "label"
},
{
"name": "TestAbility_desc",
"value": "description"
},
{
"name": "TestAbility_label",
"value": "label"
}
]
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册