提交 32f745b6 编写于 作者: J jiyong_sd

Adapt to the new framework

Signed-off-by: Njiyong_sd <jiyong@huawei.com>
Change-Id: I1c7390819753147395c52d272228063bb3e47079
上级 f050e16a
{ {
"description": "Configuration for hjunit demo Tests", "description": "Configuration for hjunit demo Tests",
"driver": { "driver": {
"type": "JSUnitTest", "type": "OHJSUnitTest",
"test-timeout": "300000", "test-timeout": "300000",
"package": "com.example.actsabilitypermissiontest", "bundle-name": "com.example.actsabilitypermissiontest",
"shell-timeout": "300000" "module-name": "com.example.actsabilitypermissiontest",
"shell-timeout": "600000",
"testcase-timeout": 70000
}, },
"kits": [ "kits": [
{ {
......
...@@ -31,7 +31,7 @@ export default class MainAbility extends Ability { ...@@ -31,7 +31,7 @@ export default class MainAbility extends Ability {
// Main window is created, set main page for this ability // Main window is created, set main page for this ability
console.log("MainAbility onWindowStageCreate") console.log("MainAbility onWindowStageCreate")
globalThis.abilityContext = this.context globalThis.abilityContext = this.context
windowStage.setUIContent(this.context, "pages/index/index", null) windowStage.setUIContent(this.context, "MainAbility/pages/index/index", null)
} }
onWindowStageDestroy() { onWindowStageDestroy() {
......
...@@ -12,9 +12,10 @@ ...@@ -12,9 +12,10 @@
* See the License for the specific language governing permissions and * See the License for the specific language governing permissions and
* limitations under the License. * limitations under the License.
*/ */
import file from '@system.file'; import router from '@ohos.router';
import {Core, ExpectExtend, InstrumentLog, ReportExtend} from "deccjsunit/index" import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry'
import testsuite from "../../test/List.test.ets" import { Hypium } from '@ohos/hypium'
import testsuite from '../../../test/List.test'
@Entry @Entry
@Component @Component
...@@ -22,20 +23,12 @@ struct Index { ...@@ -22,20 +23,12 @@ struct Index {
aboutToAppear() { aboutToAppear() {
console.info("start run testcase!!!!") console.info("start run testcase!!!!")
const core = Core.getInstance() var abilityDelegator: any
const expectExtend = new ExpectExtend({ abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
'id': 'extend' var abilityDelegatorArguments: any
}) abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
core.addService('expect', expectExtend) console.info('start run testcase!!!')
const reportExtend = new ReportExtend(file) Hypium.hypiumTest(abilityDelegator, abilityDelegatorArguments, testsuite)
core.addService('report', reportExtend)
core.init()
core.subscribeEvent('task', reportExtend)
const configService = core.getDefaultService('config')
console.info('parameters---->' + JSON.stringify(globalThis.abilityWant.parameters))
configService.setConfig(globalThis.abilityWant.parameters)
testsuite(globalThis.abilityContext)
core.execute()
} }
build() { build() {
......
...@@ -35,7 +35,7 @@ export default class MainAbility2 extends Ability { ...@@ -35,7 +35,7 @@ export default class MainAbility2 extends Ability {
onWindowStageCreate(windowStage) { onWindowStageCreate(windowStage) {
// Main window is created, set main page for this ability // Main window is created, set main page for this ability
console.log("MainAbility2 onWindowStageCreate") console.log("MainAbility2 onWindowStageCreate")
windowStage.setUIContent(this.context, "pages/index/index2", null) windowStage.setUIContent(this.context, "MainAbility/pages/index/index2", null)
globalThis.ability2Context = this.context; globalThis.ability2Context = this.context;
commonEvent.publish("ACTS_AbilityPermission_0100_Start_CommonEvent", PublishCallBackOne1); commonEvent.publish("ACTS_AbilityPermission_0100_Start_CommonEvent", PublishCallBackOne1);
} }
......
/*
* 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 Ability from '@ohos.application.Ability'
export default class TestAbility extends Ability {
onCreate(want, launchParam) {
console.log('TestAbility onCreate')
}
onDestroy() {
console.log('TestAbility onDestroy')
}
onWindowStageCreate(windowStage) {
console.log('TestAbility onWindowStageCreate')
windowStage.loadContent("TestAbility/pages/index", (err, data) => {
if (err.code) {
console.error('Failed to load the content. Cause:' + JSON.stringify(err));
return;
}
console.info('Succeeded in loading the content. Data: ' + JSON.stringify(data))
});
globalThis.abilityContext = this.context;
}
onWindowStageDestroy() {
console.log('TestAbility onWindowStageDestroy')
}
onForeground() {
console.log('TestAbility onForeground')
}
onBackground() {
console.log('TestAbility onBackground')
}
};
\ 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 router from '@ohos.router';
@Entry
@Component
struct Index {
aboutToAppear() {
console.info('TestAbility index aboutToAppear')
}
@State message: string = 'Hello World'
build() {
Row() {
Column() {
Text(this.message)
.fontSize(50)
.fontWeight(FontWeight.Bold)
Button() {
Text('next page')
.fontSize(20)
.fontWeight(FontWeight.Bold)
}.type(ButtonType.Capsule)
.margin({
top: 20
})
.backgroundColor('#0D9FFB')
.width('35%')
.height('5%')
.onClick(()=>{
})
}
.width('100%')
}
.height('100%')
}
}
\ 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 TestRunner from '@ohos.application.testRunner'
import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry'
var abilityDelegator = undefined
var abilityDelegatorArguments = undefined
function translateParamsToString(parameters) {
const keySet = new Set([
'-s class', '-s notClass', '-s suite', '-s it',
'-s level', '-s testType', '-s size', '-s timeout',
'-s dryRun'
])
let targetParams = '';
for (const key in parameters) {
if (keySet.has(key)) {
targetParams = `${targetParams} ${key} ${parameters[key]}`
}
}
return targetParams.trim()
}
async function onAbilityCreateCallback() {
console.log("onAbilityCreateCallback");
}
async function addAbilityMonitorCallback(err: any) {
console.info("addAbilityMonitorCallback : " + JSON.stringify(err))
}
export default class OpenHarmonyTestRunner implements TestRunner {
constructor() {
}
onPrepare() {
console.info("OpenHarmonyTestRunner OnPrepare ")
}
async onRun() {
console.log('OpenHarmonyTestRunner onRun run')
abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
var testAbilityName = abilityDelegatorArguments.bundleName + '.MainAbility'
let lMonitor = {
abilityName: testAbilityName,
onAbilityCreate: onAbilityCreateCallback,
};
abilityDelegator.addAbilityMonitor(lMonitor, addAbilityMonitorCallback)
var cmd = 'aa start -d 0 -a com.example.actsabilitypermissiontest.MainAbility' + ' -b ' + abilityDelegatorArguments.bundleName
cmd += ' '+translateParamsToString(abilityDelegatorArguments.parameters)
var debug = abilityDelegatorArguments.parameters["-D"]
if (debug == 'true')
{
cmd += ' -D'
}
console.info('cmd : '+cmd)
abilityDelegator.executeShellCommand(cmd,
(err: any, d: any) => {
console.info('executeShellCommand : err : ' + JSON.stringify(err));
console.info('executeShellCommand : data : ' + d.stdResult);
console.info('executeShellCommand : data : ' + d.exitCode);
})
console.info('OpenHarmonyTestRunner onRun end')
}
};
\ No newline at end of file
...@@ -14,7 +14,7 @@ ...@@ -14,7 +14,7 @@
*/ */
// @ts-nocheck // @ts-nocheck
import osaccount from '@ohos.account.osAccount' import osaccount from '@ohos.account.osAccount'
import {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from "deccjsunit/index" import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from "@ohos/hypium"
import commonEvent from '@ohos.commonEvent' import commonEvent from '@ohos.commonEvent'
var AbilityPermission1 = { var AbilityPermission1 = {
events: ["ACTS_AbilityPermission_0100_Start_CommonEvent"] events: ["ACTS_AbilityPermission_0100_Start_CommonEvent"]
...@@ -29,7 +29,7 @@ var AbilityPermission6 = { ...@@ -29,7 +29,7 @@ var AbilityPermission6 = {
events: ["ACTS_AbilityPermission_0600_Start_CommonEvent"] events: ["ACTS_AbilityPermission_0600_Start_CommonEvent"]
} }
const START_ABILITY_TIMEOUT = 3000; const START_ABILITY_TIMEOUT = 3000;
export default function abilityPermissionTest(abilityContext) { export default function abilityPermissionTest() {
describe('ActsAbilityPermissionTest', function () { describe('ActsAbilityPermissionTest', function () {
var osAccountManager = osaccount.getAccountManager(); var osAccountManager = osaccount.getAccountManager();
var userA; var userA;
...@@ -72,7 +72,7 @@ export default function abilityPermissionTest(abilityContext) { ...@@ -72,7 +72,7 @@ export default function abilityPermissionTest(abilityContext) {
Subscriber = data; Subscriber = data;
commonEvent.subscribe(Subscriber, SubscribeCallBack); commonEvent.subscribe(Subscriber, SubscribeCallBack);
console.debug("====>start startAbility_100====>"); console.debug("====>start startAbility_100====>");
await abilityContext.startAbilityWithAccount( await globalThis.abilityContext.startAbilityWithAccount(
{ {
bundleName: 'com.example.actsabilitypermissiontest', bundleName: 'com.example.actsabilitypermissiontest',
abilityName: 'com.example.actsabilitypermissiontest.MainAbility2' abilityName: 'com.example.actsabilitypermissiontest.MainAbility2'
...@@ -118,7 +118,7 @@ export default function abilityPermissionTest(abilityContext) { ...@@ -118,7 +118,7 @@ export default function abilityPermissionTest(abilityContext) {
Subscriber = data; Subscriber = data;
commonEvent.subscribe(Subscriber, SubscribeCallBack); commonEvent.subscribe(Subscriber, SubscribeCallBack);
console.debug("====>start startAbility_0300====>"); console.debug("====>start startAbility_0300====>");
await abilityContext.startAbilityWithAccount( await globalThis.abilityContext.startAbilityWithAccount(
{ {
bundleName: 'com.example.actssystemappuonehundredonerelytest', bundleName: 'com.example.actssystemappuonehundredonerelytest',
abilityName: 'com.example.actssystemappuonehundredonerelytest.MainAbility' abilityName: 'com.example.actssystemappuonehundredonerelytest.MainAbility'
...@@ -158,7 +158,7 @@ export default function abilityPermissionTest(abilityContext) { ...@@ -158,7 +158,7 @@ export default function abilityPermissionTest(abilityContext) {
function SubscribeCallBack(err, data) { function SubscribeCallBack(err, data) {
expect(data.event == "ACTS_AbilityPermission_0400_Start_CommonEvent").assertTrue(); expect(data.event == "ACTS_AbilityPermission_0400_Start_CommonEvent").assertTrue();
console.debug("====>0400 Subscribe CallBack data:====>" + JSON.stringify(data)); console.debug("====>0400 Subscribe CallBack data:====>" + JSON.stringify(data));
abilityContext.disconnectAbility(globalThis.number).then((data) => { globalThis.abilityContext.disconnectAbility(globalThis.number).then((data) => {
console.debug("====>data is====>" + JSON.stringify(data)); console.debug("====>data is====>" + JSON.stringify(data));
}) })
console.log('====>disconnectAbility finish'); console.log('====>disconnectAbility finish');
...@@ -191,7 +191,7 @@ export default function abilityPermissionTest(abilityContext) { ...@@ -191,7 +191,7 @@ export default function abilityPermissionTest(abilityContext) {
Subscriber = data; Subscriber = data;
commonEvent.subscribe(Subscriber, SubscribeCallBack); commonEvent.subscribe(Subscriber, SubscribeCallBack);
console.debug("====>0400start connectAbility====>"); console.debug("====>0400start connectAbility====>");
globalThis.number = await abilityContext.connectAbilityWithAccount( globalThis.number = await globalThis.abilityContext.connectAbilityWithAccount(
{ {
bundleName: 'com.example.actsabilitypermissiontest', bundleName: 'com.example.actsabilitypermissiontest',
abilityName: 'com.example.actsabilitypermissiontest.ServiceAbility', abilityName: 'com.example.actsabilitypermissiontest.ServiceAbility',
...@@ -253,7 +253,7 @@ export default function abilityPermissionTest(abilityContext) { ...@@ -253,7 +253,7 @@ export default function abilityPermissionTest(abilityContext) {
commonEvent.subscribe(Subscriber, SubscribeCallBackF); commonEvent.subscribe(Subscriber, SubscribeCallBackF);
}) })
console.debug("====>0600start connectAbility====>"); console.debug("====>0600start connectAbility====>");
connId = await abilityContext.connectAbilityWithAccount( connId = await globalThis.abilityContext.connectAbilityWithAccount(
{ {
bundleName: 'com.example.actssystemappuonehundredonerelytest', bundleName: 'com.example.actssystemappuonehundredonerelytest',
abilityName: 'com.example.actssystemappuonehundredonerelytest.ServiceAbility', abilityName: 'com.example.actssystemappuonehundredonerelytest.ServiceAbility',
......
...@@ -14,6 +14,6 @@ ...@@ -14,6 +14,6 @@
*/ */
import abilityPermissionText from './AbilityPermission.test.ets' import abilityPermissionText from './AbilityPermission.test.ets'
export default function testsuite(context) { export default function testsuite() {
abilityPermissionText(context) abilityPermissionText()
} }
\ No newline at end of file
{ {
"src": [ "src": [
"pages/index/index", "MainAbility/pages/index/index",
"pages/second/second" "MainAbility/pages/second/second"
] ]
} }
\ No newline at end of file
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册