提交 67393c02 编写于 作者: C chenxuihui

hitracemeter js testcase

Signed-off-by: Nchenxuihui <chenxuhui2@huawei.com>
上级 0e3e88de
# 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("ActsHitraceMeterTest") {
hap_profile = "./src/main/config.json"
deps = [
":hitracemeter_assets",
":hitracemeter_resources",
]
certificate_profile = "./signature/openharmony_sx.p7b"
hap_name = "ActsHitraceMeterTest"
}
ohos_js_assets("hitracemeter_assets") {
js2abc = true
hap_profile = "./src/main/config.json"
source_dir = "./src/main/js"
}
ohos_resources("hitracemeter_resources") {
sources = [ "./src/main/resources" ]
hap_profile = "./src/main/config.json"
}
{
"description": "Configuration for hitracemeter demo Tests",
"driver": {
"type": "OHJSUnitTest",
"test-timeout": "300000",
"package-name": "ohos.hitracemeter.test",
"bundle-name": "ohos.hitracemeter.test",
"shell-timeout": "300000"
},
"kits": [
{
"test-file-name": [
"ActsHitraceMeterTest.hap"
],
"type": "AppInstallKit",
"cleanup-apps": true
}
]
}
{
"app": {
"bundleName": "ohos.hitracemeter.test",
"vendor": "example",
"version": {
"code": 1,
"name": "1.0"
},
"apiVersion": {
"compatible": 4,
"target": 5
}
},
"deviceConfig": {},
"module": {
"package": "ohos.hitracemeter.test",
"name": ".entry",
"mainAbility": ".MainAbility",
"srcPath":"",
"deviceType": [
"default",
"phone"
],
"distro": {
"deliveryWithInstall": true,
"moduleName": "entry",
"moduleType": "entry"
},
"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"
}
}
}
/*
* 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.
*/
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.
*/
require('./hitracemeter_test.js');
import HitraceMeterTest from './hitracemeter_test.js'
export default function testsuite() {
HitraceMeterTest()
}
\ 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.
*/
import hiTraceMeter from "@ohos.hiTraceMeter"
import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from '@ohos/hypium'
export default function HitraceMeterTest() {
describe("HitraceMeterTest", function () {
async function msleep(time) {
var promise = new Promise((resolve, reject) => {
setTimeout(() => resolve("done!"), time);
});
var result = await promise;
}
it("DFX_DFR_HitraceMeter_0100", 0, async function (done) {
console.info("-------DFX_DFR_HitraceMeter_0100 start--------");
await msleep(3000);
for (var i = 0; i < 3; i++) {
console.info("DFX_DFR_HitraceMeter_0100 i = " + i)
console.info("DFX_DFR_HitraceMeter_0100 " + i.toString() + " startTrace start");
hiTraceMeter.startTrace("test-" + i.toString(), 111 + i, 5000);
console.info("DFX_DFR_HitraceMeter_0100 " + i.toString() + "startTrace end");
// await msleep(3000);
console.info("DFX_DFR_HitraceMeter_0100 " + i.toString() + " finishTrace start");
hiTraceMeter.finishTrace("test-" + i.toString(), 111 + i);
console.info("DFX_DFR_HitraceMeter_0100 " + i.toString() + "finishTrace end");
}
console.info("DFX_DFR_HitraceMeter_0100 end");
done();
})
it("DFX_DFR_HitraceMeter_0200", 0, async function (done) {
console.info("------DFX_DFR_HitraceMeter_0200 start------");
// Normal condition
let flag = false;
try {
console.info("DFX_DFR_HitraceMeter_0200 1 start");
hiTraceMeter.startTrace("test2", 222);
expect(true).assertTrue();
console.info("DFX_DFR_HitraceMeter_0200 1 success");
} catch (err) {
console.info("DFX_DFR_HitraceMeter_0200 1 fail!");
console.info("DFX_DFR_HitraceMeter_0200 1 err = " + err);
expect(false).assertTrue();
}
// Abnormal condition, Pass only one parameter
try {
console.info("DFX_DFR_HitraceMeter_0200 2 start");
hiTraceMeter.startTrace("test2");
expect(flag).assertFalse();
} catch (err) {
flag = true;
console.info("DFX_DFR_HitraceMeter_0200 2 fail!");
console.info("DFX_DFR_HitraceMeter_0200 2 err = " + err);
expect(flag).assertTrue();
}
// Abnormal condition, Pass multiple parameters
flag = false;
try {
console.info("DFX_DFR_HitraceMeter_0200 3 start");
hiTraceMeter.startTrace("test2", 222, 2000, 2);
expect(flag).assertFalse();
} catch (err) {
flag = true;
console.info("DFX_DFR_HitraceMeter_0200 3 fail!");
console.info("DFX_DFR_HitraceMeter_0200 3 err = " + err);
expect(flag).assertTrue();
}
// Abnormal condition, Parameter format mismatch
flag = false;
try {
console.info("DFX_DFR_HitraceMeter_0200 4 start");
hiTraceMeter.startTrace(2, "222", "2000");
expect(flag).assertFalse();
} catch (err) {
flag = true;
console.info("DFX_DFR_HitraceMeter_0200 4 fail!");
console.info("DFX_DFR_HitraceMeter_0200 4 err = " + err);
expect(flag).assertTrue();
}
console.info("------DFX_DFR_HitraceMeter_0200 end------");
done();
})
it("DFX_DFR_HitraceMeter_0300", 0, async function (done) {
console.info("------DFX_DFR_HitraceMeter_0300 start------");
// Normal condition
let flag = false;
try {
console.info("DFX_DFR_HitraceMeter_0300 1 start")
hiTraceMeter.finishTrace("test3", 111);
expect(true).assertTrue();
console.info("DFX_DFR_HitraceMeter_0300 1 success");
} catch (err) {
console.info("DFX_DFR_HitraceMeter_0300 1 fail!");
console.info("DFX_DFR_HitraceMeter_0300 1 err = " + err);
expect(false).assertTrue();
}
// Abnormal condition, Pass only one parameter
try {
console.info("DFX_DFR_HitraceMeter_0300 2 start")
hiTraceMeter.finishTrace("test3");
expect(flag).assertFalse();
} catch (err) {
flag = true;
console.info("DFX_DFR_HitraceMeter_0300 2 fail!");
console.info("DFX_DFR_HitraceMeter_0300 2 err = " + err);
expect(flag).assertTrue();
}
// Abnormal condition, Pass multiple parameters
flag = false;
try {
console.info("DFX_DFR_HitraceMeter_0300 3 start")
hiTraceMeter.finishTrace("test3", 1, 1);
expect(flag).assertFalse();
} catch (err) {
flag = true;
console.info("DFX_DFR_HitraceMeter_0300 3 fail!");
console.info("DFX_DFR_HitraceMeter_0300 3 err = " + err);
expect(flag).assertTrue();
}
// Abnormal condition, Parameter format mismatch
flag = false;
try {
console.info("DFX_DFR_HitraceMeter_0300 4 start")
hiTraceMeter.finishTrace(1, "123");
expect(flag).assertFalse();
} catch (err) {
flag = true;
console.info("DFX_DFR_HitraceMeter_0300 4 fail!");
console.info("DFX_DFR_HitraceMeter_0300 4 err = " + err);
expect(flag).assertTrue();
}
console.info("------DFX_DFR_HitraceMeter_0300 end------");
done();
})
it("DFX_DFR_HitraceMeter_0400", 0, async function (done) {
console.info("-------DFX_DFR_HitraceMeter_0400 start--------");
for (var i = 0; i < 3; i++) {
console.info("DFX_DFR_HitraceMeter_0400 :" + i);
hiTraceMeter.traceByValue("test4-" + i.toString(), 3 + i);
await msleep(1000);
}
console.info("DFX_DFR_HitraceMeter_0400 end");
done();
})
it("DFX_DFR_HitraceMeter_0500", 0, async function (done) {
console.info("-------DFX_DFR_HitraceMeter_0500 start--------");
// Normal condition
let flag = false;
try {
console.info("DFX_DFR_HitraceMeter_0500 1 start")
hiTraceMeter.traceByValue("test5", 5);
expect(true).assertTrue();
console.info("DFX_DFR_HitraceMeter_0500 1 success")
} catch (err) {
console.info("DFX_DFR_HitraceMeter_0500 1 fail!");
console.info("DFX_DFR_HitraceMeter_0500 1 err = " + err);
expect(false).assertTrue();
}
// Abnormal condition, Pass only one parameter
try {
console.info("DFX_DFR_HitraceMeter_0500 2 start")
hiTraceMeter.traceByValue("test5");
expect(flag).assertFalse();
} catch (err) {
flag = true;
console.info("DFX_DFR_HitraceMeter_0500 2 fail!");
console.info("DFX_DFR_HitraceMeter_0500 2 err = " + err);
expect(flag).assertTrue();
}
// Abnormal condition, Pass multiple parameters
flag = false;
try {
console.info("DFX_DFR_HitraceMeter_0500 3 start")
hiTraceMeter.traceByValue("test5", 3, 1);
expect(flag).assertFalse();
} catch (err) {
flag = true;
console.info("DFX_DFR_HitraceMeter_0500 3 fail!");
console.info("DFX_DFR_HitraceMeter_0500 3 err = " + err);
expect(flag).assertTrue();
}
// Abnormal condition, Parameter format mismatch
flag = false;
try {
console.info("DFX_DFR_HitraceMeter_0500 4 start")
hiTraceMeter.traceByValue(1, "123");
expect(flag).assertFalse();
} catch (err) {
flag = true;
console.info("DFX_DFR_HitraceMeter_0500 4 fail!");
console.info("DFX_DFR_HitraceMeter_0500 4 err = " + err);
expect(flag).assertTrue();
}
console.info("------DFX_DFR_HitraceMeter_0500 end------");
done();
})
})
}
\ No newline at end of file
{
"string": [
{
"name": "app_name",
"value": "FaultloggerJs"
},
{
"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.
先完成此消息的编辑!
想要评论请 注册