diff --git a/ability/ability_runtime/actsuiextensiontest/BUILD.gn b/ability/ability_runtime/actsuiextensiontest/BUILD.gn index 6d93bd1f189249b5959035ef3ba1383639f6250e..77fc6b05761a2cdae3ae86e98a6a60fc73c4a771 100644 --- a/ability/ability_runtime/actsuiextensiontest/BUILD.gn +++ b/ability/ability_runtime/actsuiextensiontest/BUILD.gn @@ -17,6 +17,7 @@ group("actsuiextensiontest") { testonly = true if (is_standard_system) { deps = [ + "actsabilityusertest:StartAbilityByUIContentSession", "uiextensionprovider:UIExtensionProvider", "uiextensiontest:UIExtensionTest", ] 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..75fb41d517dd40572e1df3d239be4786f8780a86 --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/BUILD.gn @@ -0,0 +1,44 @@ +# Copyright (c) 2023 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("StartAbilityByUIContentSession") { + hap_profile = "entry/src/main/module.json" + js_build_mode = "debug" + deps = [ + ":startabilitybyuicontentsession_js_assets", + ":startabilitybyuicontentsession_resources", + ] + ets2abc = true + certificate_profile = "signature/openharmony_sx.p7b" + hap_name = "StartAbilityByUIContentSession" + + subsystem_name = "ability" + part_name = "ability_runtime" +} + +ohos_app_scope("startabilitybyuicontentsession_app_profile") { + app_profile = "AppScope/app.json" + sources = [ "AppScope/resources" ] +} + +ohos_js_assets("startabilitybyuicontentsession_js_assets") { + source_dir = "entry/src/main/ets" +} + +ohos_resources("startabilitybyuicontentsession_resources") { + sources = [ "entry/src/main/resources" ] + deps = [ ":startabilitybyuicontentsession_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..c5a305694ef2346af0ce030a483d869daefcee9c --- /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": [ + "StartAbilityByUIContentSession.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..ed9341d1ac0e65bfb8d7b9c0cc29ee4b28549151 --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/MainAbility/MainAbility.ts @@ -0,0 +1,43 @@ +/* + * Copyright (c) 2023 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 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, 'pages/index', null); + } + + onWindowStageDestroy() { + console.log('MainAbility onWindowStageDestroy'); + } + + onForeground() { + console.log('MainAbility onForeground'); + } + + onBackground() { + console.log('MainAbility onBackground'); + } +}; \ 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..f27bc33743ae71d5854ca986a1d009b094558dff --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/MainAbility2/MainAbility2.ts @@ -0,0 +1,73 @@ +/* + * Copyright (c) 2023 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'; + +const sleepTimeOne = 1000; + +function publishCallBack() { + console.log('====>Publish CallBack ACTS_StartAbilityEvent====>'); + globalThis.ability2Context.terminateSelf().then(()=>{ + console.log('====>terminateSelf success====>'); + }); +} + +function timeout() { + globalThis.ability2Context.startAbility( + { + bundleName: 'com.example.uiextensiontest', + abilityName: 'TestAbility', + } + ).then(()=>{ + console.log('====>start com.example.uiextensiontest.TestAbility finish====>'); + }); +} + +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); + } + + onWindowStageDestroy() { + // Main window is destroyed, release UI related resources + console.log('MainAbility2 onWindowStageDestroy'); + } + + onForeground() { + // Ability has brought to foreground + console.log('MainAbility2 onForeground'); + globalThis.ability2Context = this.context; + setTimeout(timeout, sleepTimeOne); + } + + onBackground() { + // Ability has back to background + console.log('MainAbility2 onBackground'); + let onResultEvent = 'ACTS_UIExtension_StartAbility_OnResult'; + commonEventManager.publish(onResultEvent, publishCallBack); + } +}; 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..93d7668ce5621426cbcd5cd9100a5b29b6249eef --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/MainAbility3/MainAbility3.ts @@ -0,0 +1,72 @@ +/* + * Copyright (c) 2023 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'; + +const sleepTimeOne = 1000; + +function timeout() { + globalThis.ability3Context.startAbility( + { + bundleName: 'com.example.uiextensiontest', + abilityName: 'TestAbility' + } + ).then(()=>{ + console.log('====>start com.example.uiextensiontest.TestAbility finish====>'); + }); +} + +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); + } + + onWindowStageDestroy() { + // Main window is destroyed, release UI related resources + console.log('MainAbility3 onWindowStageDestroy'); + } + + onForeground() { + // Ability has brought to foreground + console.log('MainAbility3 onForeground'); + globalThis.ability3Context = this.context; + setTimeout(timeout, sleepTimeOne); + } + + onBackground() { + // Ability has back to background + console.log('MainAbility3 onBackground'); + globalThis.ability3Context.terminateSelfWithResult( + { + resultCode:1, + want:{ + action:'ACTION' + } + }, ()=>{ + console.debug('====>terminateSelfWithResult success====>'); + }); + } +}; 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..b2ec8539b46c8bd581f03c0afffc235a308e2c27 --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/pages/index.ets @@ -0,0 +1,32 @@ +/* +* Copyright (c) 2023 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..7102122d0e3d324446c8e89f81575be365fc87f2 --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/pages/index2.ets @@ -0,0 +1,32 @@ +/* +* Copyright (c) 2023 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 World2' + + 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..288d67612cd5654270fe86eea7ca3b0c251f3441 --- /dev/null +++ b/ability/ability_runtime/actsuiextensiontest/actsabilityusertest/entry/src/main/ets/pages/index3.ets @@ -0,0 +1,32 @@ +/* +* Copyright (c) 2023 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/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..6fa75d76bf2b5d2cd6df1bf1eda5864f9e402ef7 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,7 @@ import commonEventManager from '@ohos.commonEventManager' import Logger from '../model/Logger' import common from '@ohos.app.ability.common'; let context= getContext(this) as common.UIExtensionContext; + const TAG: string = '[UIExtAbility]' const sleepTimeOne = 1000; @@ -50,10 +51,24 @@ struct Index { let appearEvent = 'ACTS_UIExtension_AboutToAppear'; let terminateSelfWithResultEvent = 'ACTS_UIExtension_TerminateSelfWithResult'; let sendDataEvent = 'ACTS_UIExtension_SendData'; + let startAbilityEvent1 = 'ACTS_UIExtension_StartAbility_001'; + let startAbilityEvent2 = 'ACTS_UIExtension_StartAbility_002'; + let startAbilityEvent3 = 'ACTS_UIExtension_StartAbility_003'; + let startAbilityEvent4 = 'ACTS_UIExtension_StartAbility_004'; + + let startAbilityForResultEvent1 = 'ACTS_UIExtension_StartAbilityForResult_001'; + let startAbilityForResultEvent2 = 'ACTS_UIExtension_StartAbilityForResult_002'; + let startAbilityForResultEvent3 = 'ACTS_UIExtension_StartAbilityForResult_003'; + let startAbilityForResultEvent4 = 'ACTS_UIExtension_StartAbilityForResult_004'; var subscriber; + var startresult = false; var subscribeInfo = { - events: [terminateSelfWithResultEvent, sendDataEvent] + events: [startAbilityEvent1, startAbilityEvent2, startAbilityEvent3, + startAbilityEvent4, startAbilityForResultEvent1, + startAbilityForResultEvent2, startAbilityForResultEvent3, + startAbilityForResultEvent4, + terminateSelfWithResultEvent, sendDataEvent] } commonEventManager.createSubscriber(subscribeInfo).then(async (data) => { console.log(TAG + "createSubscriber data : " + JSON.stringify(data)); @@ -100,7 +115,154 @@ struct Index { }).catch((err)=>{ console.log(TAG + "setWindowPrivacyModeFalsePromise : " + JSON.stringify(err)); }) + } else if(data.event == startAbilityEvent1) { + this.session.startAbility( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility2', + }, () => { + console.log(TAG + "====>startAbilityEvent1 end====>" ); + }); + commonEventManager.unsubscribe(subscriber, async (err, data) => { + console.log(TAG + "UnSubscribeInfoCallback : " + JSON.stringify(data)); + }); + } else if(data.event == startAbilityEvent2) { + this.session.startAbility( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility2', + }, + { + windowMode: 0 + }, () => { + console.log(TAG + "====>startAbilityEvent2 end====>" ); + }); + commonEventManager.unsubscribe(subscriber, async (err, data) => { + console.log(TAG + "UnSubscribeInfoCallback : " + JSON.stringify(data)); + }); + } else if(data.event == startAbilityEvent3) { + this.session.startAbility( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility2', + }).then((data)=>{ + console.log(TAG + "====>startAbilityEvent3 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 == startAbilityEvent4) { + this.session.startAbility( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility2', + }, + { + windowMode: 0 + }).then((data)=>{ + console.log(TAG + "====>startAbilityEvent4 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 == startAbilityForResultEvent1) { + var flag = true + this.session.startAbilityForResult( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility3' + }, (err,data) => { + console.log(TAG + "====>startAbilityForResultEvent1 end====>" + JSON.stringify(data)); + if(data.resultCode == 1 && data.want.action=='ACTION') { + commonEventManager.publish('ACTS_UIExtension_StartAbilityForResult_001_OnResult', (err) => { + if (err) { + console.log(TAG + `publish ACTS_UIExtension_StartAbilityForResult_001_OnResult failed, + code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'ACTS_UIExtension_StartAbilityForResult_001_OnResult success'); + } + }); + } + }) + commonEventManager.unsubscribe(subscriber, async (err, data) => { + console.log(TAG + "UnSubscribeInfoCallback : " + JSON.stringify(data)); + }); + } else if(data.event == startAbilityForResultEvent2) { + var flag = true + this.session.startAbilityForResult( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility3' + }, + { + windowMode: 0 + }, (err,data) => { + console.log(TAG + "====>startAbilityForResultEvent2 end====>" + JSON.stringify(data)); + if(data.resultCode == 1 && data.want.action=='ACTION') { + commonEventManager.publish('ACTS_UIExtension_StartAbilityForResult_002_OnResult', (err) => { + if (err) { + console.log(TAG + `publish ACTS_UIExtension_StartAbilityForResult_002_OnResult failed, + code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'ACTS_UIExtension_StartAbilityForResult_002_OnResult success'); + } + }); + } + }) + commonEventManager.unsubscribe(subscriber, async (err, data) => { + console.log(TAG + "UnSubscribeInfoCallback : " + JSON.stringify(data)); + }); + } else if(data.event == startAbilityForResultEvent3) { + var flag = true + this.session.startAbilityForResult( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility3' + }).then((data) => { + console.log(TAG + "====>startAbilityForResultEvent3 end====>" + JSON.stringify(data)); + if(data.resultCode == 1 && data.want.action=='ACTION') { + commonEventManager.publish('ACTS_UIExtension_StartAbilityForResult_003_OnResult', (err) => { + if (err) { + console.log(TAG + `publish ACTS_UIExtension_StartAbilityForResult_003_OnResult failed, + code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'ACTS_UIExtension_StartAbilityForResult_003_OnResult success'); + } + }); + } + }) + commonEventManager.unsubscribe(subscriber, async (err, data) => { + console.log(TAG + "UnSubscribeInfoCallback : " + JSON.stringify(data)); + }); + } else if(data.event == startAbilityForResultEvent4) { + var flag = true + this.session.startAbilityForResult( + { + bundleName: 'com.example.actsabilityusertest', + abilityName: 'MainAbility3' + }, + { + windowMode: 0 + }).then((data) => { + console.log(TAG + "====>startAbilityForResultEvent4 end====>" + JSON.stringify(data)); + if(data.resultCode == 1 && data.want.action=='ACTION') { + commonEventManager.publish('ACTS_UIExtension_StartAbilityForResult_004_OnResult', (err) => { + if (err) { + console.log(TAG + `publish ACTS_UIExtension_StartAbilityForResult_004_OnResult failed, + code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'ACTS_UIExtension_StartAbilityForResult_004_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..b94f41d9a6ae3cc70528335b0e62a7f9c71740cb 100644 --- a/ability/ability_runtime/actsuiextensiontest/uiextensiontest/Test.json +++ b/ability/ability_runtime/actsuiextensiontest/uiextensiontest/Test.json @@ -12,10 +12,18 @@ { "test-file-name": [ "UIExtensionTest.hap", - "UIextensionProvider.hap" + "UIExtensionProvider.hap", + "StartAbilityByUIContentSession.hap" ], "type": "AppInstallKit", "cleanup-apps": true + }, + { + "type": "ShellKit", + "run-command": [ + "power-shell wakeup", + "power-shell setmode 602" + ] } ] } diff --git a/ability/ability_runtime/actsuiextensiontest/uiextensiontest/entry/src/main/ets/TestAbility/TestAbility.ets b/ability/ability_runtime/actsuiextensiontest/uiextensiontest/entry/src/main/ets/TestAbility/TestAbility.ets index b86e86f3b7a489e125d05621d361ed714fd2d09d..a5f4cccdc186f94b1f96da87c2f1fa31f313cc9a 100644 --- a/ability/ability_runtime/actsuiextensiontest/uiextensiontest/entry/src/main/ets/TestAbility/TestAbility.ets +++ b/ability/ability_runtime/actsuiextensiontest/uiextensiontest/entry/src/main/ets/TestAbility/TestAbility.ets @@ -61,4 +61,9 @@ export default class TestAbility extends Ability { hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onBackground'); } + + onNewWant(want, launchParam) { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onNewWant'); + } } \ No newline at end of file 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..7512b60fa225d409d3e42e5f5ea0b4c8a1982c73 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,507 @@ export default function abilityTest() { done(); }) }) + + /* + * @tc.number : ACTS_UIExtension_StartAbility_001 + * @tc.name : start new ability by UIContentSession + * @tc.desc : Starting mainability2 by UIContentSession with startability succeeded.(callback) + */ + 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_001'; + var flag = true + + function UnSubscribeCallback() { + console.log(TAG + "UnSubscribeInfoCallback"); + flag = false; + done(); + } + + function timeout() { + if(flag == true) { + expect().assertFail(); + console.debug(TAG + 'StartAbility_001 - 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, 5000); + }) + + /* + * @tc.number : ACTS_UIExtension_StartAbility_002 + * @tc.name : start new ability by UIContentSession + * @tc.desc : Starting mainability2 by UIContentSession with the parameter startability with options succeeded.(callback) + */ + it('ACTS_UIExtension_StartAbility_002',0, async function (done) { + TAG = 'ACTS_UIExtension_StartAbility_002 == '; + console.log(TAG + "begin"); + + let appearEvent = 'ACTS_UIExtension_AboutToAppear'; + let onResultEvent = 'ACTS_UIExtension_StartAbility_OnResult'; + let startAbilityOpsEvent = 'ACTS_UIExtension_StartAbility_002'; + + var flag = true + + function UnSubscribeCallback() { + console.log(TAG + "UnSubscribeInfoCallback"); + flag = false; + done(); + } + + function timeout() { + if(flag == true) { + expect().assertFail(); + console.debug(TAG + 'StartAbility_002 - 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_002 failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'publish ACTS_UIExtension_StartAbility_002 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, 5000); + }) + + /* + * @tc.number : ACTS_UIExtension_StartAbility_003 + * @tc.name : start new ability by UIContentSession + * @tc.desc : Starting mainability2 by UIContentSession with startability succeeded.(promise) + */ + it('ACTS_UIExtension_StartAbility_003',0, async function (done) { + TAG = 'ACTS_UIExtension_StartAbility_003 == '; + console.log(TAG + "begin"); + + let appearEvent = 'ACTS_UIExtension_AboutToAppear'; + let onResultEvent = 'ACTS_UIExtension_StartAbility_OnResult'; + let startAbilityEventPromise = 'ACTS_UIExtension_StartAbility_003'; + + var flag = true + + function UnSubscribeCallback() { + console.log(TAG + "UnSubscribeInfoCallback"); + flag = false; + done(); + } + + function timeout() { + if(flag == true) { + expect().assertFail(); + console.debug(TAG + 'StartAbility_003 - 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_003 failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'publish ACTS_UIExtension_StartAbility_003 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, 5000); + }) + + /* + * @tc.number : ACTS_UIExtension_StartAbility_004 + * @tc.name : start new ability by UIContentSession + * @tc.desc : Starting mainability2 by UIContentSession with the parameter startability with options succeeded.(promise) + */ + it('ACTS_UIExtension_StartAbility_004',0, async function (done) { + TAG = 'ACTS_UIExtension_StartAbility_004 == '; + console.log(TAG + "begin"); + + let appearEvent = 'ACTS_UIExtension_AboutToAppear'; + let onResultEvent = 'ACTS_UIExtension_StartAbility_OnResult'; + let startAbilityOpsEventPromise = 'ACTS_UIExtension_StartAbility_004'; + + var flag = true + + function UnSubscribeCallback() { + console.log(TAG + "UnSubscribeInfoCallback"); + flag = false; + done(); + } + + function timeout() { + if(flag == true) { + expect().assertFail(); + console.debug(TAG + 'StartAbility_004 - 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_004 failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'publish ACTS_UIExtension_StartAbility_004 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, 5000); + }) + + /* + * @tc.number : ACTS_UIExtension_StartAbilityForResult_001 + * @tc.name : start new ability for result by UIContentSession + * @tc.desc : Starting mainability3 by UIContentSession with startAbilityforresult succeeded.(callback) + */ + 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_001_OnResult'; + let startAbilityForResultEvent = 'ACTS_UIExtension_StartAbilityForResult_001'; + + var flag = true + + function UnSubscribeCallback() { + console.log(TAG + "UnSubscribeInfoCallback"); + flag = false; + done(); + } + + function timeout() { + if(flag == true) { + expect().assertFail(); + console.debug(TAG + 'StartAbilityForResult_001 - 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_StartAbilityForResult_001 failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'publish ACTS_UIExtension_StartAbilityForResult_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, 5000); + + }) + + /* + * @tc.number : ACTS_UIExtension_StartAbilityForResult_002 + * @tc.name : start new ability for result by UIContentSession + * @tc.desc : Starting mainability3 by UIContentSession with the parameter startabilityforresult with options succeeded.(callback) + */ + it('ACTS_UIExtension_StartAbilityForResult_002',0, async function (done) { + TAG = 'ACTS_UIExtension_StartAbilityForResult_002 == '; + console.log(TAG + "begin"); + + let appearEvent = 'ACTS_UIExtension_AboutToAppear'; + let onResultEvent = 'ACTS_UIExtension_StartAbilityForResult_002_OnResult'; + let startAbilityForResultOpsEvent = 'ACTS_UIExtension_StartAbilityForResult_002'; + + var flag = true + + function UnSubscribeCallback() { + console.log(TAG + "UnSubscribeInfoCallback"); + flag = false; + done(); + } + + function timeout() { + if(flag == true) { + expect().assertFail(); + console.debug(TAG + 'StartAbilityForResult_002 - 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_002 failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'publish ACTS_UIExtension_StartAbilityForResult_002 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, 5000); + }) + + /* + * @tc.number : ACTS_UIExtension_StartAbilityForResult_003 + * @tc.name : start new ability for result by UIContentSession + * @tc.desc : Starting mainability3 by UIContentSession with startabilityforresult succeeded.(promise) + */ + it('ACTS_UIExtension_StartAbilityForResult_003',0, async function (done) { + TAG = 'ACTS_UIExtension_StartAbilityForResult_003 == '; + console.log(TAG + "begin"); + + let appearEvent = 'ACTS_UIExtension_AboutToAppear'; + let onResultEvent = 'ACTS_UIExtension_StartAbilityForResult_003_OnResult'; + let startAbilityForResultEventPromise = 'ACTS_UIExtension_StartAbilityForResult_003'; + + var flag = true + + function UnSubscribeCallback() { + console.log(TAG + "UnSubscribeInfoCallback"); + flag = false; + done(); + } + + function timeout() { + if(flag == true) { + expect().assertFail(); + console.debug(TAG + 'StartAbilityForResult_003 - 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_003 failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'publish ACTS_UIExtension_StartAbilityForResult_003 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, 5000); + }) + + /* + * @tc.number : ACTS_UIExtension_StartAbilityForResult_004 + * @tc.name : start new ability for result by UIContentSession + * @tc.desc : Starting mainability2 by UIContentSession with the parameter startabilityforresult with options succeeded.(promise) + */ + it('ACTS_UIExtension_StartAbilityForResult_004',0, async function (done) { + TAG = 'ACTS_UIExtension_StartAbilityForResult_004 == '; + console.log(TAG + "begin"); + + let appearEvent = 'ACTS_UIExtension_AboutToAppear'; + let onResultEvent = 'ACTS_UIExtension_StartAbilityForResult_004_OnResult'; + let startAbilityForResultOpsEventPromise = 'ACTS_UIExtension_StartAbilityForResult_004'; + + var flag = true + + function UnSubscribeCallback() { + console.log(TAG + "UnSubscribeInfoCallback"); + flag = false; + done(); + } + + function timeout() { + if(flag == true) { + expect().assertFail(); + console.debug(TAG + 'StartAbilityForResult_004 - 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_004 failed, code is ${err.code}, message is ${err.message}`); + } else { + console.log(TAG + 'publish ACTS_UIExtension_StartAbilityForResult_004 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, 5000); + }) }) } \ No newline at end of file