diff --git a/ability/ability_runtime/actsuiextensiontest/BUILD.gn b/ability/ability_runtime/actsuiextensiontest/BUILD.gn index 6d93bd1f189249b5959035ef3ba1383639f6250e..26bcedf140b1e4261a2bd985300f0e69a2a0d376 100644 --- a/ability/ability_runtime/actsuiextensiontest/BUILD.gn +++ b/ability/ability_runtime/actsuiextensiontest/BUILD.gn @@ -19,6 +19,7 @@ group("actsuiextensiontest") { deps = [ "uiextensionprovider:UIExtensionProvider", "uiextensiontest:UIExtensionTest", + "actsabilityusertest:ActsAmsStartAbilityUser", ] } } diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/AppScope/app.json b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/AppScope/app.json new file mode 100644 index 0000000000000000000000000000000000000000..8c4bd449f34c37954d13a71b057eb7165cb30b1b --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/AppScope/app.json @@ -0,0 +1,21 @@ +{ + "app": { + "bundleName": "com.example.actsabilityusertest", + "vendor": "huawei", + "versionCode": 1000000, + "versionName": "1.0.0", + "debug": false, + "icon" : "$media:icon", + "label" : "$string:app_name", + "description" : "$string:description_application", + "distributedNotificationEnabled": true, + "keepAlive" : true, + "singleUser": true, + "minAPIVersion": 9, + "targetAPIVersion": 9, + "car": { + "apiCompatibleVersion": 9, + "singleUser": false + } + } +} diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/AppScope/resources/base/element/string.json b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/AppScope/resources/base/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..351f3d3f88bfed2e67a83773ddfd3fd438639824 --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/AppScope/resources/base/element/string.json @@ -0,0 +1,8 @@ +{ + "string": [ + { + "name": "app_name", + "value": "actsabilityusertest" + } + ] +} diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/AppScope/resources/base/media/app_icon.png b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/AppScope/resources/base/media/app_icon.png new file mode 100644 index 0000000000000000000000000000000000000000..ce307a8827bd75456441ceb57d530e4c8d45d36c Binary files /dev/null and b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/AppScope/resources/base/media/app_icon.png differ diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/BUILD.gn b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/BUILD.gn new file mode 100644 index 0000000000000000000000000000000000000000..3254019661ec791ce86bd109318cdd349094a22d --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/BUILD.gn @@ -0,0 +1,44 @@ +# 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("//test/xts/tools/build/suite.gni") + +ohos_js_hap_suite("ActsAmsStartAbilityUser") { + hap_profile = "entry/src/main/module.json" + js_build_mode = "debug" + deps = [ + ":actsamsstartabilityuser_js_assets", + ":actsamsstartabilityuser_resources", + ] + ets2abc = true + certificate_profile = "signature/openharmony_sx.p7b" + hap_name = "ActsAmsStartAbilityUser" + + subsystem_name = "ability" + part_name = "ability_runtime" +} + +ohos_app_scope("actsamsstartabilityuser_app_profile") { + app_profile = "AppScope/app.json" + sources = [ "AppScope/resources" ] +} + +ohos_js_assets("actsamsstartabilityuser_js_assets") { + source_dir = "entry/src/main/ets" +} + +ohos_resources("actsamsstartabilityuser_resources") { + sources = [ "entry/src/main/resources" ] + deps = [ ":actsamsstartabilityuser_app_profile" ] + hap_profile = "entry/src/main/module.json" +} diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/Test.json b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/Test.json new file mode 100644 index 0000000000000000000000000000000000000000..2d0e54614f0b93a1255e4354ddd28948e822b7de --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/Test.json @@ -0,0 +1,20 @@ +{ + "description": "Configuration for aceceshi Tests", + "driver": { + "type": "OHJSUnitTest", + "test-timeout": "600000", + "bundle-name": "com.example.actsabilityusertest", + "module-name": "entry", + "shell-timeout": "600000" + }, + "kits": [ + { + "test-file-name": [ + "ActsAmsStartAbilityUser.hap" + ], + "type": "AppInstallKit", + "cleanup-apps": true + } + ] +} + diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/Application/AbilityStage.ts b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/Application/AbilityStage.ts new file mode 100644 index 0000000000000000000000000000000000000000..11200f672cfa3a981668dbdee5a700935bf7be99 --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/Application/AbilityStage.ts @@ -0,0 +1,7 @@ +import AbilityStage from "@ohos.app.ability.AbilityStage" + +export default class MyAbilityStage extends AbilityStage { + onCreate() { + console.log("[Demo] MyAbilityStage onCreate") + } +} \ No newline at end of file diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/MainAbility/MainAbility.ts b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/MainAbility/MainAbility.ts new file mode 100644 index 0000000000000000000000000000000000000000..cc7d5abd399f1a84fd0c2f735d01d795d9db6d01 --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/MainAbility/MainAbility.ts @@ -0,0 +1,38 @@ +import Ability from '@ohos.app.ability.UIAbility' +import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry' +import { Hypium } from '@ohos/hypium' +import testsuite from '../test/List.test' + +export default class MainAbility extends Ability { + onCreate(want, launchParam) { + console.log('MainAbility onCreate') + } + + onDestroy() { + console.log('MainAbility onDestroy') + } + + onWindowStageCreate(windowStage) { + console.log('MainAbility onWindowStageCreate') + windowStage.setUIContent(this.context, 'MainAbility/pages/index', null) + } + + onWindowStageDestroy() { + console.log('MainAbility onWindowStageDestroy') + } + + onForeground() { + console.log('MainAbility onForeground') + setTimeout(()=>{ + this.context.terminateSelf().then((data) => { + console.info("com.example.actsabilityusertest MainAbility terminateSelf data = " + JSON.stringify(data)); + }).catch((err) => { + console.info("com.example.actsabilityusertest MainAbility terminateSelf err = " + JSON.stringify(err)); + }); + }, 2000) + } + + onBackground() { + console.log('MainAbility onBackground') + } +}; \ No newline at end of file diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/MainAbility/pages/index.ets b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/MainAbility/pages/index.ets new file mode 100644 index 0000000000000000000000000000000000000000..9d55879f3923d5f6a95525162dc5ebb865d7aa28 --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/MainAbility/pages/index.ets @@ -0,0 +1,49 @@ +/* +* 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('MainAbility 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 diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/MainAbility2/MainAbility2.ts b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/MainAbility2/MainAbility2.ts new file mode 100644 index 0000000000000000000000000000000000000000..fc504de21e882b2ff226b8649dfe5add942062f2 --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/MainAbility2/MainAbility2.ts @@ -0,0 +1,60 @@ +/* + * 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.app.ability.UIAbility' +import commonEventManager from '@ohos.commonEventManager' + +function PublishCallBackOne() { + console.debug("====>Publish CallBack ACTS_StartAbility_0100_CommonEvent====>"); + globalThis.ability2Context.terminateSelf().then(()=>{ + console.debug("====>publish ACTS_TerminateSelf_CommonEvent finish====>") + }); + console.debug("====>terminateSelf succese====>") +} + +export default class MainAbility2 extends Ability { + + onCreate(want, launchParam) { + console.log("MainAbility2 onCreate"); + } + + onDestroy() { + // Ability is destroying, release resources for this ability + console.log("MainAbility2 onDestroy"); + } + + onWindowStageCreate(windowStage) { + // Main window is created, set main page for this ability + console.log("MainAbility2 onWindowStageCreate"); + windowStage.setUIContent(this.context, "pages/index2", null); + let onResultEvent = 'ACTS_UIExtension_StartAbility_OnResult'; + globalThis.ability2Context = this.context; + commonEventManager.publish(onResultEvent, PublishCallBackOne); + } + + onWindowStageDestroy() { + // Main window is destroyed, release UI related resources + console.log("MainAbility2 onWindowStageDestroy"); + } + + onForeground() { + // Ability has brought to foreground + console.log("MainAbility2 onForeground"); + } + + onBackground() { + // Ability has back to background + console.log("MainAbility2 onBackground"); + } +}; diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/MainAbility3/MainAbility3.ts b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/MainAbility3/MainAbility3.ts new file mode 100644 index 0000000000000000000000000000000000000000..6de55627a65e56013fa829b706cdfac17789c6a6 --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/MainAbility3/MainAbility3.ts @@ -0,0 +1,59 @@ +/* + * 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.app.ability.UIAbility' + +export default class MainAbility3 extends Ability { + + onCreate(want, launchParam) { + console.log("MainAbility3 onCreate"); + } + + onDestroy() { + // Ability is destroying, release resources for this ability + console.log("MainAbility3 onDestroy"); + } + + onWindowStageCreate(windowStage) { + // Main window is created, set main page for this ability + console.log("MainAbility3 onWindowStageCreate"); + windowStage.setUIContent(this.context, "pages/index3", null); + globalThis.abilityContext3 = this.context; + globalThis.abilityContext3.terminateSelfWithResult( + { + resultCode:1, + want:{ + action:'ACTION' + } + },()=>{ + console.debug("====>terminateSelfWithResult succese====>") + }); + console.debug("====>terminateSelf end====>") + } + + onWindowStageDestroy() { + // Main window is destroyed, release UI related resources + console.log("MainAbility3 onWindowStageDestroy"); + } + + onForeground() { + // Ability has brought to foreground + console.log("MainAbility3 onForeground"); + } + + onBackground() { + // Ability has back to background + console.log("MainAbility3 onBackground"); + } +}; diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts new file mode 100644 index 0000000000000000000000000000000000000000..8bcafe1a40fc3b9702796858d60586b21049c85c --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts @@ -0,0 +1,58 @@ +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' + ]) + 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 MainAbilityName = abilityDelegatorArguments.bundleName + '.MainAbility' + let lMonitor = { + abilityName: MainAbilityName, + onAbilityCreate: onAbilityCreateCallback, + }; + abilityDelegator.addAbilityMonitor(lMonitor, addAbilityMonitorCallback) + var cmd = 'aa start -d 0 -a MainAbility' + ' -b ' + abilityDelegatorArguments.bundleName + cmd += ' '+translateParamsToString(abilityDelegatorArguments.parameters) + 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 diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/pages/index.ets b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/pages/index.ets new file mode 100644 index 0000000000000000000000000000000000000000..3bb1376bf16a11bb8882e58381c6f1499069e0bd --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/pages/index.ets @@ -0,0 +1,32 @@ +/* +* 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. +*/ + +@Entry +@Component +struct Index { + @State message: string = 'Hello World' + + build() { + Row() { + Column() { + Text(this.message) + .fontSize(50) + .fontWeight(FontWeight.Bold) + } + .width('100%') + } + .height('100%') + } +} \ No newline at end of file diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/pages/index2.ets b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/pages/index2.ets new file mode 100644 index 0000000000000000000000000000000000000000..ae4dc02582f7c4aaf7583dee23b1f2383a481cb0 --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/pages/index2.ets @@ -0,0 +1,32 @@ +/* +* 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. +*/ + +@Entry +@Component +struct Index { + @State message: string = 'Hello World3' + + build() { + Row() { + Column() { + Text(this.message) + .fontSize(50) + .fontWeight(FontWeight.Bold) + } + .width('100%') + } + .height('100%') + } +} \ No newline at end of file diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/pages/index3.ets b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/pages/index3.ets new file mode 100644 index 0000000000000000000000000000000000000000..ae4dc02582f7c4aaf7583dee23b1f2383a481cb0 --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/pages/index3.ets @@ -0,0 +1,32 @@ +/* +* 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. +*/ + +@Entry +@Component +struct Index { + @State message: string = 'Hello World3' + + build() { + Row() { + Column() { + Text(this.message) + .fontSize(50) + .fontWeight(FontWeight.Bold) + } + .width('100%') + } + .height('100%') + } +} \ No newline at end of file diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/test/Ability.test.ets b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/test/Ability.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..cb614e6ab96718e6cb197d65e3f4503c92b4d478 --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/test/Ability.test.ets @@ -0,0 +1,225 @@ +/* + * 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 {describe, beforeAll, beforeEach, afterEach, afterAll, it, expect} from '@ohos/hypium' +import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry' +import commonEvent from '@ohos.commonEvent' +var subscriberInfo_MainAbility = { + events: ["ACTS_StartAbility_CommonEvent"] +}; +const START_ABILITY_TIMEOUT = 4000; +export default function abilityTest() { + describe('ACTS_StartAbility_Test', function () { + + /* + * @tc.number : ACTS_StartAbility_Callback_Successfully_0100 + * @tc.name : start new ability + * @tc.desc : Starting mainability2 with startability succeeded.(callback) + */ + it('ACTS_StartAbility_Callback_Successfully_0100', 0, async function (done) { + var Subscriber + var flag = true + var startresult = false + + function SubscribeCallBack(err, data) { + expect(data.event == "ACTS_StartAbility_CommonEvent").assertTrue(); + console.log("====>0100 Subscribe CallBack data:====>" + JSON.stringify(data)); + if (data.event == "ACTS_StartAbility_CommonEvent") { + startresult = true + } + commonEvent.unsubscribe(Subscriber, UnSubscribeCallback); + } + + function UnSubscribeCallback() { + console.log("====>UnSubscribeCallback====>"); + flag = false + expect(startresult).assertEqual(true); + done(); + } + + await commonEvent.createSubscriber(subscriberInfo_MainAbility).then((data) => { + console.log("====>Create Subscriber====>"); + data.getSubscribeInfo().then(async (SubscribeInfo) => { + console.log("====>SubscribeInfo is====>" + JSON.stringify(SubscribeInfo)); + Subscriber = data; + commonEvent.subscribe(Subscriber, SubscribeCallBack); + console.log("====>start startAbility====>"); + globalThis.abilityContext.startAbility( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility2' + }, () => { + console.log("====>startAbility end====>"); + }) + }) + }) + + function timeout() { + if (flag == true) { + expect().assertFail(); + console.log('ACTS_StartAbility_Callback_Successfully_0100 - timeout') + commonEvent.unsubscribe(Subscriber, UnSubscribeCallback) + } + } + + setTimeout(timeout, START_ABILITY_TIMEOUT); + }) + + /* + * @tc.number : ACTS_StartAbility_Callback_Error_0200 + * @tc.name : start new ability + * @tc.desc : Starting mainability2 with startability failed.(callback) + */ + it('ACTS_StartAbility_Callback_Error_0200', 0, async function (done) { + var AbilityDelegatorArgs = AbilityDelegatorRegistry.getArguments() + console.log("====>getArguments is====>" + JSON.stringify(AbilityDelegatorArgs)); + var Subscriber + + function SubscribeCallBack(err, data) { + expect().assertFail(); + console.log("====>0200 Subscribe CallBack data:====>" + JSON.stringify(data)); + commonEvent.unsubscribe(Subscriber, UnSubscribeCallback); + } + + function UnSubscribeCallback() { + console.log("====>UnSubscribeCallback====>"); + done(); + } + + await commonEvent.createSubscriber(subscriberInfo_MainAbility).then((data) => { + console.log("====>Create Subscriber====>"); + data.getSubscribeInfo().then(async (SubscribeInfo) => { + console.log("====>SubscribeInfo is====>" + JSON.stringify(SubscribeInfo)); + Subscriber = data; + commonEvent.subscribe(Subscriber, SubscribeCallBack); + console.log("====>start startAbility====>"); + await globalThis.abilityContext.startAbility( + { + bundleName: 'com.example.error', + abilityName: 'com.example.error.MainAbility2' + }, () => { + console.log("====>startAbility end====>"); + }) + }) + }) + + function timeout() { + console.log('ACTS_StartAbility_Callback_Error_0200 - timeout'); + commonEvent.unsubscribe(Subscriber, UnSubscribeCallback) + } + + setTimeout(timeout, START_ABILITY_TIMEOUT); + }) + + /* + * @tc.number : ACTS_StartAbility_Promise_Successfully_0100 + * @tc.name : start new ability + * @tc.desc : Starting mainability2 with startability succeeded.(callback) + */ + it('ACTS_StartAbility_Promise_Successfully_0100', 0, async function (done) { + var Subscriber + var flag = true + var startresult = false + + function SubscribeCallBack(err, data) { + expect(data.event == "ACTS_StartAbility_CommonEvent").assertTrue(); + console.log("====>0100 Subscribe CallBack data:====>" + JSON.stringify(data)); + if (data.event == "ACTS_StartAbility_CommonEvent") { + startresult = true + } + commonEvent.unsubscribe(Subscriber, UnSubscribeCallback); + } + + function UnSubscribeCallback() { + console.log("====>UnSubscribeCallback====>"); + flag = false + expect(startresult).assertEqual(true); + done(); + } + + commonEvent.createSubscriber(subscriberInfo_MainAbility).then((data) => { + console.log("====>Create Subscriber====>"); + data.getSubscribeInfo().then(async (SubscribeInfo) => { + console.log("====>SubscribeInfo is====>" + JSON.stringify(SubscribeInfo)); + Subscriber = data; + commonEvent.subscribe(Subscriber, SubscribeCallBack); + console.log("====>start startAbility====>"); + await globalThis.abilityContext.startAbility( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility3' + }).then(() => { + console.log("====>startAbility end====>"); + }) + }) + }) + + function timeout() { + if (flag == true) { + expect().assertFail(); + console.log('ACTS_StartAbility_Promise_Successfully_0100 - timeout'); + commonEvent.unsubscribe(Subscriber, UnSubscribeCallback) + } + } + + setTimeout(timeout, START_ABILITY_TIMEOUT); + }) + + /* + * @tc.number : ACTS_StartAbility_Promise_Error_0200 + * @tc.name : start new ability + * @tc.desc : Starting mainability2 with startability failed.(callback) + */ + it('ACTS_StartAbility_Promise_Error_0200', 0, async function (done) { + var AbilityDelegatorArgs = AbilityDelegatorRegistry.getArguments() + console.log("====>getArguments is====>" + JSON.stringify(AbilityDelegatorArgs)); + var Subscriber + + function SubscribeCallBack(err, data) { + expect().assertFail(); + console.log("====>0200 Subscribe CallBack data:====>" + JSON.stringify(data)); + commonEvent.unsubscribe(Subscriber, UnSubscribeCallback); + } + + function UnSubscribeCallback() { + console.log("====>UnSubscribeCallback====>"); + done(); + } + + commonEvent.createSubscriber(subscriberInfo_MainAbility).then((data) => { + console.log("====>Create Subscriber====>"); + data.getSubscribeInfo().then(async (SubscribeInfo) => { + console.log("====>SubscribeInfo is====>" + JSON.stringify(SubscribeInfo)); + Subscriber = data; + commonEvent.subscribe(Subscriber, SubscribeCallBack); + console.log("====>start startAbility====>"); + globalThis.abilityContext.startAbility( + { + bundleName: 'com.example.error', + abilityName: 'com.example.error.MainAbility2' + }).then(() => { + console.log("====>startAbility end====>"); + }) + }) + }) + + function timeout() { + console.log('ACTS_StartAbility_Promise_Error_0200 - timeout'); + commonEvent.unsubscribe(Subscriber, UnSubscribeCallback) + } + + setTimeout(timeout, START_ABILITY_TIMEOUT); + }) + }) +} \ No newline at end of file diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/test/List.test.ets b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/test/List.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..caa07c3911a97aed3eab456f7864b1d430eb4e79 --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/test/List.test.ets @@ -0,0 +1,20 @@ +/* +* 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 abilityTest from './Ability.test' + +export default function testsuite() { + abilityTest() +} \ No newline at end of file diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/module.json b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/module.json new file mode 100644 index 0000000000000000000000000000000000000000..f71b4500b9ed72930114fc2b86b05ba804a32b8c --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/module.json @@ -0,0 +1,53 @@ +{ + "module": { + "name": "entry", + "type": "entry", + "srcEntrance": "./ets/Application/AbilityStage.ts", + "description": "$string:entry_desc", + "mainElement": "MainAbility", + "deviceTypes": [ + "default", + "tablet" + ], + "deliveryWithInstall": true, + "installationFree": false, + "pages": "$profile:main_pages", + "uiSyntax": "ets", + "abilities": [ + { + "name": "MainAbility", + "srcEntrance": "./ets/MainAbility/MainAbility.ts", + "description": "$string:MainAbility_desc", + "icon": "$media:icon", + "label": "$string:MainAbility_label", + "visible": true, + "skills": [ + { + "entities": [ + "entity.system.home" + ], + "actions": [ + "action.system.home" + ] + } + ] + }, + { + "name": "MainAbility2", + "srcEntrance": "./ets/MainAbility2/MainAbility2.ts", + "description": "$string:MainAbility2_desc", + "icon": "$media:icon", + "label": "$string:MainAbility2_label", + "visible": true + }, + { + "name": "MainAbility3", + "srcEntrance": "./ets/MainAbility3/MainAbility3.ts", + "description": "$string:MainAbility3_desc", + "icon": "$media:icon", + "label": "$string:MainAbility3_label", + "visible": true + } + ] + } +} \ No newline at end of file diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/resources/base/element/string.json b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/resources/base/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..a74dd0a469fb6b096665fc61dc0c4540caa4808d --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/resources/base/element/string.json @@ -0,0 +1,40 @@ +{ + "string": [ + { + "name": "entry_desc", + "value": "description" + }, + { + "name": "MainAbility_desc", + "value": "description" + }, + { + "name": "MainAbility_label", + "value": "label" + }, + { + "name": "MainAbility2_desc", + "value": "description" + }, + { + "name": "MainAbility2_label", + "value": "label" + }, + { + "name": "MainAbility3_desc", + "value": "description" + }, + { + "name": "MainAbility3_label", + "value": "label" + }, + { + "name": "app_name", + "value": "actsabilityusertest" + }, + { + "name": "description_application", + "value": "demo for test" + } + ] +} \ No newline at end of file diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/resources/base/media/icon.png b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/resources/base/media/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..ce307a8827bd75456441ceb57d530e4c8d45d36c Binary files /dev/null and b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/resources/base/media/icon.png differ diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/resources/base/profile/main_pages.json b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/resources/base/profile/main_pages.json new file mode 100644 index 0000000000000000000000000000000000000000..e291133c8b3c329611da5af30c299ec10589c7c2 --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/resources/base/profile/main_pages.json @@ -0,0 +1,5 @@ +{ + "src": [ + "pages/index" + ] +} \ No newline at end of file diff --git a/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/signature/openharmony_sx.p7b b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/signature/openharmony_sx.p7b new file mode 100644 index 0000000000000000000000000000000000000000..d9b8311673d4f0f6dda7c0044f41d107f7706ea2 Binary files /dev/null and b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/signature/openharmony_sx.p7b differ diff --git a/ability/ability_runtime/actsuiextensiontest/uiextensionprovider/entry/src/main/ets/pages/index.ets b/ability/ability_runtime/actsuiextensiontest/uiextensionprovider/entry/src/main/ets/pages/index.ets index fcb29a89f45a9e971ad6b21c9ea030a8f2798cc6..5e38650f88bb2591aa8c6b9451e60f7b0055d37f 100644 --- a/ability/ability_runtime/actsuiextensiontest/uiextensionprovider/entry/src/main/ets/pages/index.ets +++ b/ability/ability_runtime/actsuiextensiontest/uiextensionprovider/entry/src/main/ets/pages/index.ets @@ -18,6 +18,9 @@ import commonEventManager from '@ohos.commonEventManager' import Logger from '../model/Logger' import common from '@ohos.app.ability.common'; let context= getContext(this) as common.UIExtensionContext; +import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from '@ohos/hypium' +import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry' + const TAG: string = '[UIExtAbility]' const sleepTimeOne = 1000; @@ -50,10 +53,24 @@ struct Index { let appearEvent = 'ACTS_UIExtension_AboutToAppear'; let terminateSelfWithResultEvent = 'ACTS_UIExtension_TerminateSelfWithResult'; let sendDataEvent = 'ACTS_UIExtension_SendData'; + let startAbilityEvent = 'ACTS_UIExtension_StartAbility'; + let startAbilityOpsEvent = 'ACTS_UIExtension_StartAbility_Options'; + let startAbilityEventPromise = 'ACTS_UIExtension_StartAbility_Promise'; + let startAbilityOpsEventPromise = 'ACTS_UIExtension_StartAbility_Options_Promise'; + + let startAbilityForResultEvent = 'ACTS_UIExtension_StartAbilityForResult'; + let startAbilityForResultOpsEvent = 'ACTS_UIExtension_StartAbilityForResult_Options'; + let startAbilityForResultEventPromise = 'ACTS_UIExtension_StartAbilityForResult_Promise'; + let startAbilityForResultOpsEventPromise = 'ACTS_UIExtension_StartAbilityForResult_Options_Promise'; var subscriber; + var startresult = false; var subscribeInfo = { - events: [terminateSelfWithResultEvent, sendDataEvent] + events: [startAbilityEvent, startAbilityOpsEvent, startAbilityEventPromise, + startAbilityOpsEventPromise, startAbilityForResultEvent, + startAbilityForResultOpsEvent, startAbilityForResultEventPromise, + startAbilityForResultOpsEventPromise, + terminateSelfWithResultEvent, sendDataEvent] } commonEventManager.createSubscriber(subscribeInfo).then(async (data) => { console.log(TAG + "createSubscriber data : " + JSON.stringify(data)); @@ -100,7 +117,178 @@ struct Index { }).catch((err)=>{ console.log(TAG + "setWindowPrivacyModeFalsePromise : " + JSON.stringify(err)); }) + } else if(data.event == startAbilityEvent) { + this.session.startAbility( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility2', + parameters:{ + "ability.params.backToOtherMissionStack":true, + }, + }, () => { + console.log(TAG + "====>startAbilityEvent end====>" ); + }); + commonEventManager.unsubscribe(subscriber, async (err, data) => { + console.log(TAG + "UnSubscribeInfoCallback : " + JSON.stringify(data)); + }); + } else if(data.event == startAbilityOpsEvent) { + this.session.startAbility( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility2', + parameters:{ + "ability.params.backToOtherMissionStack":true, + }, + }, + { + windowMode: 0, + displayId: 15 + }, () => { + console.log(TAG + "====>startAbilityOpsEvent end====>" ); + }); + commonEventManager.unsubscribe(subscriber, async (err, data) => { + console.log(TAG + "UnSubscribeInfoCallback : " + JSON.stringify(data)); + }); + } else if(data.event == startAbilityEventPromise) { + this.session.startAbility( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility2', + parameters:{ + "ability.params.backToOtherMissionStack":true, + }, + }).then((data)=>{ + console.log(TAG + "====>startAbilityEventPromise end====>"); + console.log(TAG + "====>data is====>" + JSON.stringify(data)); + }); + commonEventManager.unsubscribe(subscriber, async (err, data) => { + console.log(TAG + "UnSubscribeInfoCallback : " + JSON.stringify(data)); + }); + } else if(data.event == startAbilityOpsEventPromise) { + this.session.startAbility( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility2', + parameters:{ + "ability.params.backToOtherMissionStack":true, + }, + }, + { + windowMode: 0, + displayId: 15 + }).then((data)=>{ + console.log(TAG + "====>startAbilityOpsEventPromise end====>"); + console.log(TAG + "====>data is====>" + JSON.stringify(data)); + }); + commonEventManager.unsubscribe(subscriber, async (err, data) => { + console.log(TAG + "UnSubscribeInfoCallback : " + JSON.stringify(data)); + }); + } else if(data.event == startAbilityForResultEvent) { + var flag = true + this.session.startAbilityForResult( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility3', + parameters:{ + "ability.params.backToOtherMissionStack":true, + }, + }, (err,data) => { + console.log(TAG + "====>startAbilityForResultEvent end====>" + JSON.stringify(data)); + if(data.resultCode == 1 && data.want.action=='ACTION') { + commonEventManager.publish('ACTS_UIExtension_StartAbilityForResult_OnResult', (err) => { + if (err) { + console.log(TAG + `publish ACTS_UIExtension_StartAbilityForResult_OnResult failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'ACTS_UIExtension_StartAbilityForResult_OnResult success'); + } + }); + } + }) + commonEventManager.unsubscribe(subscriber, async (err, data) => { + console.log(TAG + "UnSubscribeInfoCallback : " + JSON.stringify(data)); + }); + } else if(data.event == startAbilityForResultOpsEvent) { + var flag = true + this.session.startAbilityForResult( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility3', + parameters:{ + "ability.params.backToOtherMissionStack":true, + }, + }, + { + windowMode: 0, + displayId: 15 + }, (err,data) => { + console.log(TAG + "====>startAbilityForResultOpsEvent end====>" + JSON.stringify(data)); + if(data.resultCode == 1 && data.want.action=='ACTION') { + commonEventManager.publish('ACTS_UIExtension_StartAbilityForResult_Options_OnResult', (err) => { + if (err) { + console.log(TAG + `publish ACTS_UIExtension_StartAbilityForResult_Options_OnResult failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'ACTS_UIExtension_StartAbilityForResult_Options_OnResult success'); + } + }); + } + }) + commonEventManager.unsubscribe(subscriber, async (err, data) => { + console.log(TAG + "UnSubscribeInfoCallback : " + JSON.stringify(data)); + }); + } else if(data.event == startAbilityForResultEventPromise) { + var flag = true + this.session.startAbilityForResult( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility3', + parameters:{ + "ability.params.backToOtherMissionStack":true, + }, + }).then((data) => { + console.log(TAG + "====>startAbilityForResultEventPromise end====>" + JSON.stringify(data)); + if(data.resultCode == 1 && data.want.action=='ACTION') { + commonEventManager.publish('ACTS_UIExtension_StartAbilityForResult_Promise_OnResult', (err) => { + if (err) { + console.log(TAG + `publish ACTS_UIExtension_StartAbilityForResult_Promise_OnResult failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'ACTS_UIExtension_StartAbilityForResult_Promise_OnResult success'); + } + }); + } + }) + commonEventManager.unsubscribe(subscriber, async (err, data) => { + console.log(TAG + "UnSubscribeInfoCallback : " + JSON.stringify(data)); + }); + } else if(data.event == startAbilityForResultOpsEventPromise) { + var flag = true + this.session.startAbilityForResult( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility3', + parameters:{ + "ability.params.backToOtherMissionStack":true, + }, + }, + { + windowMode: 0, + displayId: 15 + }).then((data) => { + console.log(TAG + "====>startAbilityForResultOpsEventPromise end====>" + JSON.stringify(data)); + if(data.resultCode == 1 && data.want.action=='ACTION') { + commonEventManager.publish('ACTS_UIExtension_StartAbilityForResult_Options_Promise_OnResult', (err) => { + if (err) { + console.log(TAG + `publish ACTS_UIExtension_StartAbilityForResult_Options_Promise_OnResult failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'ACTS_UIExtension_StartAbilityForResult_Options_Promise_OnResult success'); + } + }); + } + }) + commonEventManager.unsubscribe(subscriber, async (err, data) => { + console.log(TAG + "UnSubscribeInfoCallback : " + JSON.stringify(data)); + }); } + }); }).catch((error) => { console.log(TAG + "createSubscriber error : " + JSON.stringify(error)); diff --git a/ability/ability_runtime/actsuiextensiontest/uiextensiontest/Test.json b/ability/ability_runtime/actsuiextensiontest/uiextensiontest/Test.json index 3c8a08595653cfd59b650c895caef8566c0ab70a..c1aacac7fdc9de4ec8524343853500a82f60106f 100644 --- a/ability/ability_runtime/actsuiextensiontest/uiextensiontest/Test.json +++ b/ability/ability_runtime/actsuiextensiontest/uiextensiontest/Test.json @@ -12,7 +12,8 @@ { "test-file-name": [ "UIExtensionTest.hap", - "UIextensionProvider.hap" + "UIextensionProvider.hap", + "ActsAmsStartAbilityUser.hap" ], "type": "AppInstallKit", "cleanup-apps": true diff --git a/ability/ability_runtime/actsuiextensiontest/uiextensiontest/entry/src/main/ets/test/Ability.test.ets b/ability/ability_runtime/actsuiextensiontest/uiextensiontest/entry/src/main/ets/test/Ability.test.ets index a4a7ac8f73c8e38229687a2e41e5c9ba86c8c764..d67c03d7f07d6200b0e9e70c4f20f76adb966064 100644 --- a/ability/ability_runtime/actsuiextensiontest/uiextensiontest/entry/src/main/ets/test/Ability.test.ets +++ b/ability/ability_runtime/actsuiextensiontest/uiextensiontest/entry/src/main/ets/test/Ability.test.ets @@ -144,5 +144,466 @@ export default function abilityTest() { done(); }) }) + it('ACTS_UIExtension_StartAbility_001',0, async function (done) { + TAG = 'ACTS_UIExtension_StartAbility_001 == '; + console.log(TAG + "begin"); + + let appearEvent = 'ACTS_UIExtension_AboutToAppear'; + let onResultEvent = 'ACTS_UIExtension_StartAbility_OnResult'; + let startAbilityEvent = 'ACTS_UIExtension_StartAbility'; + var flag = true + + function UnSubscribeCallback() { + console.log(TAG + "UnSubscribeInfoCallback"); + flag = false; + done(); + } + + function timeout() { + if(flag == true) { + expect().assertFail(); + console.debug(TAG + 'StartAbility - timeout'); + commonEventManager.unsubscribe(subscriber, UnSubscribeCallback) + } + } + + var subscriber; + var subscribeInfo = { + events: [appearEvent, onResultEvent] + } + await commonEventManager.createSubscriber(subscribeInfo).then(async (data) => { + console.log(TAG + "createSubscriber data : " + JSON.stringify(data)); + subscriber = data; + + commonEventManager.subscribe(subscriber, async (err, data) => { + console.log(TAG + "SubscribeInfoCallback : " + JSON.stringify(data)); + + if (data.event == appearEvent) { + commonEventManager.publish(startAbilityEvent, (err) => { + if (err) { + console.log(TAG + `publish ACTS_UIExtension_StartAbility_001 failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'publish ACTS_UIExtension_StartAbility_001 success'); + } + }); + } else if (data.event == onResultEvent) { + setTimeout(async () => { + commonEventManager.unsubscribe(subscriber, UnSubscribeCallback); + }, sleepTimeOne); + } + }); + }).catch((error) => { + console.log(TAG + "createSubscriber err : " + JSON.stringify(error)); + expect().assertFail(); + done(); + }) + + setTimeout(timeout, 10000); + }) + + + it('ACTS_UIExtension_StartAbility_Options_001',0, async function (done) { + TAG = 'ACTS_UIExtension_StartAbility_Options_001 == '; + console.log(TAG + "begin"); + + let appearEvent = 'ACTS_UIExtension_AboutToAppear'; + let onResultEvent = 'ACTS_UIExtension_StartAbility_OnResult'; + let startAbilityOpsEvent = 'ACTS_UIExtension_StartAbility_Options'; + + var flag = true + + function UnSubscribeCallback() { + console.log(TAG + "UnSubscribeInfoCallback"); + flag = false; + done(); + } + + function timeout() { + if(flag == true) { + expect().assertFail(); + console.debug(TAG + 'StartAbility_Options - timeout'); + commonEventManager.unsubscribe(subscriber, UnSubscribeCallback) + } + } + + var subscriber; + var subscribeInfo = { + events: [appearEvent, onResultEvent] + } + await commonEventManager.createSubscriber(subscribeInfo).then(async (data) => { + console.log(TAG + "createSubscriber data : " + JSON.stringify(data)); + subscriber = data; + + commonEventManager.subscribe(subscriber, async (err, data) => { + console.log(TAG + "SubscribeInfoCallback : " + JSON.stringify(data)); + + if (data.event == appearEvent) { + commonEventManager.publish(startAbilityOpsEvent, (err) => { + if (err) { + console.log(TAG + `publish ACTS_UIExtension_StartAbility_Options_001 failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'publish ACTS_UIExtension_StartAbility_Options_001 success'); + } + }); + } else if (data.event == onResultEvent) { + setTimeout(async () => { + commonEventManager.unsubscribe(subscriber, UnSubscribeCallback); + }, sleepTimeOne); + } + }); + }).catch((error) => { + console.log(TAG + "createSubscriber err : " + JSON.stringify(error)); + expect().assertFail(); + done(); + }) + + setTimeout(timeout, 10000); + }) + + it('ACTS_UIExtension_StartAbility_Promise_001',0, async function (done) { + TAG = 'ACTS_UIExtension_StartAbility_Promise_001 == '; + console.log(TAG + "begin"); + + let appearEvent = 'ACTS_UIExtension_AboutToAppear'; + let onResultEvent = 'ACTS_UIExtension_StartAbility_OnResult'; + let startAbilityEventPromise = 'ACTS_UIExtension_StartAbility_Promise'; + + var flag = true + + function UnSubscribeCallback() { + console.log(TAG + "UnSubscribeInfoCallback"); + flag = false; + done(); + } + + function timeout() { + if(flag == true) { + expect().assertFail(); + console.debug(TAG + 'StartAbility_Promise - timeout'); + commonEventManager.unsubscribe(subscriber, UnSubscribeCallback) + } + } + + var subscriber; + var subscribeInfo = { + events: [appearEvent, onResultEvent] + } + await commonEventManager.createSubscriber(subscribeInfo).then(async (data) => { + console.log(TAG + "createSubscriber data : " + JSON.stringify(data)); + subscriber = data; + + commonEventManager.subscribe(subscriber, async (err, data) => { + console.log(TAG + "SubscribeInfoCallback : " + JSON.stringify(data)); + + if (data.event == appearEvent) { + commonEventManager.publish(startAbilityEventPromise, (err) => { + if (err) { + console.log(TAG + `publish ACTS_UIExtension_StartAbility_Promise_001 failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'publish ACTS_UIExtension_StartAbility_Promise_001 success'); + } + }); + } else if (data.event == onResultEvent) { + setTimeout(async () => { + commonEventManager.unsubscribe(subscriber, UnSubscribeCallback); + }, sleepTimeOne); + } + }); + }).catch((error) => { + console.log(TAG + "createSubscriber err : " + JSON.stringify(error)); + expect().assertFail(); + done(); + }) + + setTimeout(timeout, 10000); + }) + it('ACTS_UIExtension_StartAbility_Options_Promise_001',0, async function (done) { + TAG = 'ACTS_UIExtension_StartAbility_Options_Promise_001 == '; + console.log(TAG + "begin"); + + let appearEvent = 'ACTS_UIExtension_AboutToAppear'; + let onResultEvent = 'ACTS_UIExtension_StartAbility_OnResult'; + let startAbilityOpsEventPromise = 'ACTS_UIExtension_StartAbility_Options_Promise'; + + var flag = true + + function UnSubscribeCallback() { + console.log(TAG + "UnSubscribeInfoCallback"); + flag = false; + done(); + } + + function timeout() { + if(flag == true) { + expect().assertFail(); + console.debug(TAG + 'StartAbility_Options_Promise - timeout'); + commonEventManager.unsubscribe(subscriber, UnSubscribeCallback) + } + } + + var subscriber; + var subscribeInfo = { + events: [appearEvent, onResultEvent] + } + await commonEventManager.createSubscriber(subscribeInfo).then(async (data) => { + console.log(TAG + "createSubscriber data : " + JSON.stringify(data)); + subscriber = data; + + commonEventManager.subscribe(subscriber, async (err, data) => { + console.log(TAG + "SubscribeInfoCallback : " + JSON.stringify(data)); + + if (data.event == appearEvent) { + commonEventManager.publish(startAbilityOpsEventPromise, (err) => { + if (err) { + console.log(TAG + `publish ACTS_UIExtension_StartAbility_Options_Promise_001 failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'publish ACTS_UIExtension_StartAbility_Options_Promise_001 success'); + } + }); + } else if (data.event == onResultEvent) { + setTimeout(async () => { + commonEventManager.unsubscribe(subscriber, UnSubscribeCallback); + }, sleepTimeOne); + } + }); + }).catch((error) => { + console.log(TAG + "createSubscriber err : " + JSON.stringify(error)); + expect().assertFail(); + done(); + }) + setTimeout(timeout, 10000); + }) + + it('ACTS_UIExtension_StartAbilityForResult_001',0, async function (done) { + TAG = 'ACTS_UIExtension_StartAbilityForResult_001 == '; + console.log(TAG + "begin"); + + let appearEvent = 'ACTS_UIExtension_AboutToAppear'; + let onResultEvent = 'ACTS_UIExtension_StartAbilityForResult_OnResult'; + let startAbilityForResultEvent = 'ACTS_UIExtension_StartAbilityForResult'; + + var flag = true + + function UnSubscribeCallback() { + console.log(TAG + "UnSubscribeInfoCallback"); + flag = false; + done(); + } + + function timeout() { + if(flag == true) { + expect().assertFail(); + console.debug(TAG + 'StartAbilityForResult - timeout'); + commonEventManager.unsubscribe(subscriber, UnSubscribeCallback) + } + } + + var subscriber; + var subscribeInfo = { + events: [appearEvent, onResultEvent] + } + await commonEventManager.createSubscriber(subscribeInfo).then(async (data) => { + console.log(TAG + "createSubscriber data : " + JSON.stringify(data)); + subscriber = data; + + commonEventManager.subscribe(subscriber, async (err, data) => { + console.log(TAG + "SubscribeInfoCallback : " + JSON.stringify(data)); + + if (data.event == appearEvent) { + commonEventManager.publish(startAbilityForResultEvent, (err) => { + if (err) { + console.log(TAG + `publish ACTS_UIExtension_StartAbilityForResultEvent failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'publish ACTS_UIExtension_StartAbilityForResultEvent success'); + } + }); + } + else if (data.event == onResultEvent) { + setTimeout(async () => { + commonEventManager.unsubscribe(subscriber, UnSubscribeCallback); + }, sleepTimeOne); + } + }); + }).catch((error) => { + console.log(TAG + "createSubscriber err : " + JSON.stringify(error)); + expect().assertFail(); + done(); + }) + setTimeout(timeout, 10000); + + }) + it('ACTS_UIExtension_StartAbilityForResult_Options_001',0, async function (done) { + TAG = 'ACTS_UIExtension_StartAbilityForResult_Options_001 == '; + console.log(TAG + "begin"); + + let appearEvent = 'ACTS_UIExtension_AboutToAppear'; + let onResultEvent = 'ACTS_UIExtension_StartAbilityForResult_Options_OnResult'; + let startAbilityForResultOpsEvent = 'ACTS_UIExtension_StartAbilityForResult_Options'; + + var flag = true + + function UnSubscribeCallback() { + console.log(TAG + "UnSubscribeInfoCallback"); + flag = false; + done(); + } + + function timeout() { + if(flag == true) { + expect().assertFail(); + console.debug(TAG + 'StartAbilityForResult_Options - timeout'); + commonEventManager.unsubscribe(subscriber, UnSubscribeCallback) + } + } + + var subscriber; + var subscribeInfo = { + events: [appearEvent, onResultEvent] + } + await commonEventManager.createSubscriber(subscribeInfo).then(async (data) => { + console.log(TAG + "createSubscriber data : " + JSON.stringify(data)); + subscriber = data; + + commonEventManager.subscribe(subscriber, async (err, data) => { + console.log(TAG + "SubscribeInfoCallback : " + JSON.stringify(data)); + + if (data.event == appearEvent) { + commonEventManager.publish(startAbilityForResultOpsEvent, (err) => { + if (err) { + console.log(TAG + `publish ACTS_UIExtension_StartAbilityForResult_Options_001 failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'publish ACTS_UIExtension_StartAbilityForResult_Options_001 success'); + } + }); + } + else if (data.event == onResultEvent) { + setTimeout(async () => { + commonEventManager.unsubscribe(subscriber, UnSubscribeCallback); + }, sleepTimeOne); + } + }); + }).catch((error) => { + console.log(TAG + "createSubscriber err : " + JSON.stringify(error)); + expect().assertFail(); + done(); + }) + setTimeout(timeout, 10000); + }) + it('ACTS_UIExtension_StartAbilityForResult_Promise_001',0, async function (done) { + TAG = 'ACTS_UIExtension_StartAbilityForResult_Promise_001 == '; + console.log(TAG + "begin"); + + let appearEvent = 'ACTS_UIExtension_AboutToAppear'; + let onResultEvent = 'ACTS_UIExtension_StartAbilityForResult_Promise_OnResult'; + let startAbilityForResultEventPromise = 'ACTS_UIExtension_StartAbilityForResult_Promise'; + + var flag = true + + function UnSubscribeCallback() { + console.log(TAG + "UnSubscribeInfoCallback"); + flag = false; + done(); + } + + function timeout() { + if(flag == true) { + expect().assertFail(); + console.debug(TAG + 'StartAbilityForResult_Promise - timeout'); + commonEventManager.unsubscribe(subscriber, UnSubscribeCallback) + } + } + + var subscriber; + var subscribeInfo = { + events: [appearEvent, onResultEvent] + } + await commonEventManager.createSubscriber(subscribeInfo).then(async (data) => { + console.log(TAG + "createSubscriber data : " + JSON.stringify(data)); + subscriber = data; + + commonEventManager.subscribe(subscriber, async (err, data) => { + console.log(TAG + "SubscribeInfoCallback : " + JSON.stringify(data)); + + if (data.event == appearEvent) { + commonEventManager.publish(startAbilityForResultEventPromise, (err) => { + if (err) { + console.log(TAG + `publish ACTS_UIExtension_StartAbilityForResult_Promise_001 failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'publish ACTS_UIExtension_StartAbilityForResult_Promise_001 success'); + } + }); + } + else if (data.event == onResultEvent) { + setTimeout(async () => { + commonEventManager.unsubscribe(subscriber, UnSubscribeCallback); + }, sleepTimeOne); + } + }); + }).catch((error) => { + console.log(TAG + "createSubscriber err : " + JSON.stringify(error)); + expect().assertFail(); + done(); + }) + setTimeout(timeout, 10000); + }) + + + it('ACTS_UIExtension_StartAbilityForResult_Options_Promise_001',0, async function (done) { + TAG = 'ACTS_UIExtension_StartAbilityForResult_Options_Promise_001 == '; + console.log(TAG + "begin"); + + let appearEvent = 'ACTS_UIExtension_AboutToAppear'; + let onResultEvent = 'ACTS_UIExtension_StartAbilityForResult_Options_Promise_OnResult'; + let startAbilityForResultOpsEventPromise = 'ACTS_UIExtension_StartAbilityForResult_Options_Promise'; + + var flag = true + + function UnSubscribeCallback() { + console.log(TAG + "UnSubscribeInfoCallback"); + flag = false; + done(); + } + + function timeout() { + if(flag == true) { + expect().assertFail(); + console.debug(TAG + 'StartAbilityForResult_Options_Promise - timeout'); + commonEventManager.unsubscribe(subscriber, UnSubscribeCallback) + } + } + + var subscriber; + var subscribeInfo = { + events: [appearEvent, onResultEvent] + } + await commonEventManager.createSubscriber(subscribeInfo).then(async (data) => { + console.log(TAG + "createSubscriber data : " + JSON.stringify(data)); + subscriber = data; + + commonEventManager.subscribe(subscriber, async (err, data) => { + console.log(TAG + "SubscribeInfoCallback : " + JSON.stringify(data)); + + if (data.event == appearEvent) { + commonEventManager.publish(startAbilityForResultOpsEventPromise, (err) => { + if (err) { + console.log(TAG + `publish ACTS_UIExtension_StartAbilityForResult_Options_Promise_001 failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'publish ACTS_UIExtension_StartAbilityForResult_Options_Promise_001 success'); + } + }); + } + else if (data.event == onResultEvent) { + setTimeout(async () => { + commonEventManager.unsubscribe(subscriber, UnSubscribeCallback); + }, sleepTimeOne); + } + }); + }).catch((error) => { + console.log(TAG + "createSubscriber err : " + JSON.stringify(error)); + expect().assertFail(); + done(); + }) + setTimeout(timeout, 10000); + }) }) } \ No newline at end of file