From fc2885060a5a83c45ae60b8f9c94ee0a05933cc2 Mon Sep 17 00:00:00 2001 From: shilei Date: Thu, 13 Oct 2022 22:57:52 +0800 Subject: [PATCH] add Signed-off-by: shilei Change-Id: I03e7124a209ab7f97c61cf4ad6d1ac22d9ad60eb --- .../bundle_standard/bundlemanager/BUILD.gn | 1 + .../AppScope/app.json | 21 + .../resources/base/element/string.json | 8 + .../actsbmsbundlemanagerstagetest/BUILD.gn | 42 ++ .../actsbmsbundlemanagerstagetest/Test.json | 27 ++ .../src/main/ets/Application/AbilityStage.ts | 9 + .../src/main/ets/FormAbility/FormAbility.ts | 37 ++ .../src/main/ets/MainAbility/MainAbility.ts | 36 ++ .../ets/MainAbility/pages/index/index.ets | 57 +++ .../ets/MainAbility/pages/second/second.ets | 43 ++ .../main/ets/ServiceAbility/FormAbility.ts | 37 ++ .../src/main/ets/TestAbility/TestAbility.ts | 30 ++ .../src/main/ets/TestAbility/pages/index.ets | 48 ++ .../ets/TestRunner/OpenHarmonyTestRunner.ts | 58 +++ .../ets/test/GetProfileByAbility.test.ets | 410 +++++++++++++++++ .../GetProfileByExtensionAbility.test.ets | 411 ++++++++++++++++++ .../entry/src/main/ets/test/List.test.ets | 22 + .../entry/src/main/module.json | 123 ++++++ .../main/resources/base/element/string.json | 40 ++ .../src/main/resources/base/media/icon.png | Bin 0 -> 15458 bytes .../resources/base/profile/form_config.json | 6 + .../resources/base/profile/form_config1.txt | 1 + .../main/resources/base/profile/invalid.txt | 5 + .../resources/base/profile/main_pages.json | 6 + .../base/profile/shortcuts_config.json | 6 + .../signature/openharmony_sx.p7b | Bin 0 -> 3466 bytes .../entry/src/main/module.json | 1 - 27 files changed, 1484 insertions(+), 1 deletion(-) create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/AppScope/app.json create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/AppScope/resources/base/element/string.json create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/BUILD.gn create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/Test.json create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/Application/AbilityStage.ts create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/FormAbility/FormAbility.ts create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/MainAbility/MainAbility.ts create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/MainAbility/pages/index/index.ets create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/MainAbility/pages/second/second.ets create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/ServiceAbility/FormAbility.ts create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/TestAbility/TestAbility.ts create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/TestAbility/pages/index.ets create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/test/GetProfileByAbility.test.ets create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/test/GetProfileByExtensionAbility.test.ets create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/test/List.test.ets create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/module.json create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/element/string.json create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/media/icon.png create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/form_config.json create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/form_config1.txt create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/invalid.txt create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/main_pages.json create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/shortcuts_config.json create mode 100755 bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/signature/openharmony_sx.p7b diff --git a/bundlemanager/bundle_standard/bundlemanager/BUILD.gn b/bundlemanager/bundle_standard/bundlemanager/BUILD.gn index d8e793c9b..cbe48a104 100644 --- a/bundlemanager/bundle_standard/bundlemanager/BUILD.gn +++ b/bundlemanager/bundle_standard/bundlemanager/BUILD.gn @@ -18,6 +18,7 @@ group("bundlemanager") { if (is_standard_system) { deps = [ "actsbmsaccesstokentest:ActsBmsAccessTokenTest", + "actsbmsbundlemanagerstagetest:ActsBmsBundleMgrStageEtsTest", "actsbmsetsmodulenametest:ActsBmsEtsModuleNameTest", "actsbmsetsunpermissiontest:ActsBmsEtsUnPermissionTest", "actsbmsgetinfostest:ActsBmsGetInfosTest", diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/AppScope/app.json b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/AppScope/app.json new file mode 100755 index 000000000..c971f6f40 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/AppScope/app.json @@ -0,0 +1,21 @@ +{ + "app":{ + "bundleName":"ohos.acts.bundle.stage.test", + "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":8, + "targetAPIVersion":8, + "car":{ + "apiCompatibleVersion":8, + "singleUser":false + } + } +} diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/AppScope/resources/base/element/string.json b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/AppScope/resources/base/element/string.json new file mode 100755 index 000000000..ee69f9a86 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/AppScope/resources/base/element/string.json @@ -0,0 +1,8 @@ +{ + "string":[ + { + "name":"app_name", + "value":"ohosProject" + } + ] +} \ No newline at end of file diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/BUILD.gn b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/BUILD.gn new file mode 100755 index 000000000..47bb7942b --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/BUILD.gn @@ -0,0 +1,42 @@ +# 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("ActsBmsBundleMgrStageEtsTest") { + hap_profile = "entry/src/main/module.json" + deps = [ + ":actbmsstageetstest_js_assets", + ":actbmsstageetstest_resources", + ] + ets2abc = true + certificate_profile = "signature/openharmony_sx.p7b" + hap_name = "ActsBmsBundleMgrStageEtsTest" + subsystem_name = "bundlemanager" + part_name = "bundle_framework" +} + +ohos_app_scope("actbmsstageetstest_app_profile") { + app_profile = "AppScope/app.json" + sources = [ "AppScope/resources" ] +} + +ohos_js_assets("actbmsstageetstest_js_assets") { + source_dir = "entry/src/main/ets" +} + +ohos_resources("actbmsstageetstest_resources") { + sources = [ "entry/src/main/resources" ] + deps = [ ":actbmsstageetstest_app_profile" ] + hap_profile = "entry/src/main/module.json" +} diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/Test.json b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/Test.json new file mode 100755 index 000000000..4de66a324 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/Test.json @@ -0,0 +1,27 @@ +{ + "description": "Configuration for hjunit demo Tests", + "driver": { + "type": "OHJSUnitTest", + "test-timeout": "180000", + "bundle-name": "ohos.acts.bundle.stage.test", + "module-name": "phone", + "shell-timeout": "600000", + "testcase-timeout": 70000 + }, + "kits": [ + { + "test-file-name": [ + "ActsBmsBundleMgrStageEtsTest.hap" + ], + "type": "AppInstallKit", + "cleanup-apps": true + }, + { + "type": "ShellKit", + "teardown-command":[ + "bm uninstall -n ohos.acts.bundle.stage.test" + ] + } + ] +} + diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/Application/AbilityStage.ts b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/Application/AbilityStage.ts new file mode 100755 index 000000000..51cb02ba3 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/Application/AbilityStage.ts @@ -0,0 +1,9 @@ +import AbilityStage from "@ohos.application.AbilityStage" + +export default class MyAbilityStage extends AbilityStage { + onCreate() { + console.log("[Demo] MyAbilityStage onCreate") + globalThis.stageOnCreateRun = 1; + globalThis.stageContext = this.context; + } +} diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/FormAbility/FormAbility.ts b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/FormAbility/FormAbility.ts new file mode 100755 index 000000000..2f94ce176 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/FormAbility/FormAbility.ts @@ -0,0 +1,37 @@ +import FormExtension from '@ohos.application.FormExtension'; +import formBindingData from '@ohos.application.formBindingData'; +import formInfo from '@ohos.application.formInfo'; + +export default class FormAbility extends FormExtension { + onCreate(want) { + // Called to return a FormBindingData object. + let formData = {}; + return formBindingData.createFormBindingData(formData); + } + + onCastToNormal(formId) { + // Called when the form provider is notified that a temporary form is successfully + // converted to a normal form. + } + + onUpdate(formId) { + // Called to notify the form provider to update a specified form. + } + + onVisibilityChange(newStatus) { + // Called when the form provider receives form events from the system. + } + + onEvent(formId, message) { + // Called when a specified message event defined by the form provider is triggered. + } + + onDestroy(formId) { + // Called to notify the form provider that a specified form has been destroyed. + } + + onAcquireFormState(want) { + // Called to return a {@link FormState} object. + return formInfo.FormState.READY; + } +}; \ No newline at end of file diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/MainAbility/MainAbility.ts b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/MainAbility/MainAbility.ts new file mode 100755 index 000000000..87b6463a2 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/MainAbility/MainAbility.ts @@ -0,0 +1,36 @@ +import Ability from '@ohos.application.Ability' + +export default class MainAbility extends Ability { + onCreate(want,launchParam){ + // Ability is creating, initialize resources for this ability + console.log("[Demo] MainAbility onCreate") + globalThis.abilityWant = want; + } + + onDestroy() { + // Ability is destroying, release resources for this ability + console.log("[Demo] MainAbility onDestroy") + } + + onWindowStageCreate(windowStage) { + // Main window is created, set main page for this ability + console.log("[Demo] MainAbility onWindowStageCreate") + globalThis.abilityContext = this.context + windowStage.setUIContent(this.context, "MainAbility/pages/index/index", null) + } + + onWindowStageDestroy() { + //Main window is destroyed, release UI related resources + console.log("[Demo] MainAbility onWindowStageDestroy") + } + + onForeground() { + // Ability has brought to foreground + console.log("[Demo] MainAbility onForeground") + } + + onBackground() { + // Ability has back to background + console.log("[Demo] MainAbility onBackground") + } +}; \ No newline at end of file diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/MainAbility/pages/index/index.ets b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/MainAbility/pages/index/index.ets new file mode 100755 index 000000000..f172d89b0 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/MainAbility/pages/index/index.ets @@ -0,0 +1,57 @@ +/* + * 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'; + +import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry' +import { Hypium } from '@ohos/hypium' +import testsuite from '../../../test/List.test' + + +@Entry +@Component +struct Index { + + aboutToAppear(){ + console.info("start run testcase!!!!") + var abilityDelegator: any + abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator() + var abilityDelegatorArguments: any + abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments() + console.info('start run testcase!!!') + Hypium.hypiumTest(abilityDelegator, abilityDelegatorArguments, testsuite) + } + + build() { + Flex({ direction:FlexDirection.Column, alignItems:ItemAlign.Center, justifyContent: FlexAlign.Center }) { + Text('Hello World') + .fontSize(50) + .fontWeight(FontWeight.Bold) + Button() { + Text('next page') + .fontSize(25) + .fontWeight(FontWeight.Bold) + }.type(ButtonType.Capsule) + .margin({ + top: 20 + }) + .backgroundColor('#0D9FFB') + .onClick(() => { + + }) + } + .width('100%') + .height('100%') + } +} \ No newline at end of file diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/MainAbility/pages/second/second.ets b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/MainAbility/pages/second/second.ets new file mode 100755 index 000000000..f9009a3e8 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/MainAbility/pages/second/second.ets @@ -0,0 +1,43 @@ +/* + * 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 '@system.router'; + +@Entry +@Component +struct Second { + private content: string = "Second Page" + + build() { + Flex({ direction: FlexDirection.Column,alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) { + Text(`${this.content}`) + .fontSize(50) + .fontWeight(FontWeight.Bold) + Button() { + Text('back to index') + .fontSize(20) + .fontWeight(FontWeight.Bold) + }.type(ButtonType.Capsule) + .margin({ + top: 20 + }) + .backgroundColor('#0D9FFB') + .onClick(() => { + router.back() + }) + } + .width('100%') + .height('100%') + } +} \ No newline at end of file diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/ServiceAbility/FormAbility.ts b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/ServiceAbility/FormAbility.ts new file mode 100755 index 000000000..2f94ce176 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/ServiceAbility/FormAbility.ts @@ -0,0 +1,37 @@ +import FormExtension from '@ohos.application.FormExtension'; +import formBindingData from '@ohos.application.formBindingData'; +import formInfo from '@ohos.application.formInfo'; + +export default class FormAbility extends FormExtension { + onCreate(want) { + // Called to return a FormBindingData object. + let formData = {}; + return formBindingData.createFormBindingData(formData); + } + + onCastToNormal(formId) { + // Called when the form provider is notified that a temporary form is successfully + // converted to a normal form. + } + + onUpdate(formId) { + // Called to notify the form provider to update a specified form. + } + + onVisibilityChange(newStatus) { + // Called when the form provider receives form events from the system. + } + + onEvent(formId, message) { + // Called when a specified message event defined by the form provider is triggered. + } + + onDestroy(formId) { + // Called to notify the form provider that a specified form has been destroyed. + } + + onAcquireFormState(want) { + // Called to return a {@link FormState} object. + return formInfo.FormState.READY; + } +}; \ No newline at end of file diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/TestAbility/TestAbility.ts b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/TestAbility/TestAbility.ts new file mode 100755 index 000000000..fb7ef2b1e --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/TestAbility/TestAbility.ts @@ -0,0 +1,30 @@ +import Ability from '@ohos.application.Ability' + +export default class TestAbility extends Ability { + onCreate(want, launchParam) { + console.log('TestAbility onCreate') + } + + onDestroy() { + console.log('TestAbility onDestroy') + } + + onWindowStageCreate(windowStage) { + console.log('TestAbility onWindowStageCreate') + windowStage.setUIContent(this.context, 'TestAbility/pages/index', null) + + globalThis.abilityContext = this.context; + } + + onWindowStageDestroy() { + console.log('TestAbility onWindowStageDestroy') + } + + onForeground() { + console.log('TestAbility onForeground') + } + + onBackground() { + console.log('TestAbility onBackground') + } +}; \ No newline at end of file diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/TestAbility/pages/index.ets b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/TestAbility/pages/index.ets new file mode 100755 index 000000000..b93567f96 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/TestAbility/pages/index.ets @@ -0,0 +1,48 @@ +/* + * Copyright (c) 2022 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +import router from '@ohos.router'; + +@Entry +@Component +struct Index { + aboutToAppear() { + console.info('TestAbility index aboutToAppear') + } + @State message: string = 'Hello World' + build() { + Row() { + Column() { + Text(this.message) + .fontSize(50) + .fontWeight(FontWeight.Bold) + Button() { + Text('next page') + .fontSize(20) + .fontWeight(FontWeight.Bold) + }.type(ButtonType.Capsule) + .margin({ + top: 20 + }) + .backgroundColor('#0D9FFB') + .width('35%') + .height('5%') + .onClick(()=>{ + }) + } + .width('100%') + } + .height('100%') + } + } \ No newline at end of file diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts new file mode 100755 index 000000000..3149248af --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/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 testAbilityName = abilityDelegatorArguments.bundleName + '.MainAbility' + let lMonitor = { + abilityName: testAbilityName, + onAbilityCreate: onAbilityCreateCallback, + }; + abilityDelegator.addAbilityMonitor(lMonitor, addAbilityMonitorCallback) + var cmd = 'aa start -d 0 -a ohos.acts.bundle.stage.test.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/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/test/GetProfileByAbility.test.ets b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/test/GetProfileByAbility.test.ets new file mode 100755 index 000000000..5b84529d1 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/test/GetProfileByAbility.test.ets @@ -0,0 +1,410 @@ +/** + * 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 manager from '@ohos.bundle.bundleManager'; +import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from "@ohos/hypium" + +const MODULE_NAME = "phone" +const MODULE_NAME_TEST = "phone1" +const ABILITY_NAME = "ohos.acts.bundle.stage.test.MainAbility" +const ABILITY_NAME1 = "ohos.acts.bundle.stage.test.MainAbility1" +const ABILITY_NAME_TEST = "ohos.acts.bundle.stage.test.MainAbilityTest" +const METADATA_NAME = "ohos.ability.form" +const METADATA_NAME1 = "ohos.ability.form1" +const METADATA_NAME2 = "ohos.ability.form2" +const METADATA_NAME3 = "ohos.ability.form3" +const METADATA_NAME4 = "ohos.ability.form4" +const METADATA_NAME_TEST = "ohos.test.form" +const PROFILE_JSON_STRING = "{\"src\":[\"MainAbility/pages/index/index\",\"MainAbility/pages/second/second\"]}" +const ERROR_ABILITY_NOT_EXIST = 17700003 +const ERROR_PROFILE_NOT_EXIST = 17700024 +const ERROR_MODULE_NOT_EXIST = 17700002 + +export default function getProfileByAbility() { + describe('getProfileByAbility', function () { + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0011 + * @tc.name: getProfileByAbilityInvalidModulePro + * @tc.desc: Check the invalid moduleName (by promise) + * @tc.level 0 + */ + it('getProfileByAbilityInvalidModulePro', 0, async function (done) { + await manager.getProfileByAbility(MODULE_NAME_TEST, ABILITY_NAME, METADATA_NAME).then(data => { + console.info("getProfileByAbilityInvalidModulePro success" + JSON.stringify(data)) + expect(data).assertFail() + done() + }).catch(err => { + console.info("getProfileByAbilityInvalidModulePro failed" + JSON.stringify(err)) + expect(err.code).assertEqual(ERROR_ABILITY_NOT_EXIST) + done() + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0015 + * @tc.name: getProfileByAbilityEmptyModulePro + * @tc.desc: Check the empty moduleName (by promise) + * @tc.level 0 + */ + it('getProfileByAbilityEmptyModulePro', 0, async function (done) { + await manager.getProfileByAbility('', ABILITY_NAME, METADATA_NAME).then(data => { + console.info("getProfileByAbilityEmptyModulePro success" + JSON.stringify(data)) + expect(data).assertFail() + done() + }).catch(err => { + console.info("getProfileByAbilityEmptyModulePro failed" + JSON.stringify(err)) + expect(err.code).assertEqual(ERROR_MODULE_NOT_EXIST) + done() + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0017 + * @tc.name: getProfileByAbilityInvalidModuleCall + * @tc.desc: Check the invalid moduleName (by callback) + * @tc.level 0 + */ + it('getProfileByAbilityInvalidModuleCall', 0, async function (done) { + manager.getProfileByAbility(MODULE_NAME_TEST, ABILITY_NAME, METADATA_NAME, (err, data) => { + expect(err.code).assertEqual(ERROR_ABILITY_NOT_EXIST); + console.error('[getProfileByAbilityInvalidModuleCall]Operation failed. Cause: ' + JSON.stringify(err)); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0034 + * @tc.name: getProfileByAbilityEmptyModuleCall + * @tc.desc: Check the empty moduleName (by callback) + * @tc.level 0 + */ + it('getProfileByAbilityEmptyModuleCall', 0, async function (done) { + manager.getProfileByAbility('', ABILITY_NAME, METADATA_NAME, (err, data) => { + expect(err.code).assertEqual(ERROR_MODULE_NOT_EXIST); + console.error('[getProfileByAbilityEmptyModuleCall]Operation failed. Cause: ' + JSON.stringify(err)); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0012 + * @tc.name: getProfileByAbilityInvalidAbilityPro + * @tc.desc: Check the invalid abilityName (by promise) + * @tc.level 0 + */ + it('getProfileByAbilityInvalidAbilityPro', 0, async function (done) { + await manager.getProfileByAbility(MODULE_NAME, ABILITY_NAME_TEST, METADATA_NAME).then(data => { + console.info("getProfileByAbilityInvalidAbilityPro success" + JSON.stringify(data)) + expect(data).assertFail() + done() + }).catch(err => { + console.info("getProfileByAbilityInvalidAbilityPro failed" + JSON.stringify(err)) + expect(err.code).assertEqual(ERROR_ABILITY_NOT_EXIST) + done() + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0029 + * @tc.name: getProfileByAbilityEmptyAbilityPro + * @tc.desc: Check the empty abilityName (by promise) + * @tc.level 0 + */ + it('getProfileByAbilityEmptyAbilityPro', 0, async function (done) { + await manager.getProfileByAbility(MODULE_NAME, '', METADATA_NAME).then(data => { + console.info("getProfileByAbilityEmptyAbilityPro success" + JSON.stringify(data)) + expect(data).assertFail() + done() + }).catch(err => { + console.info("getProfileByAbilityEmptyAbilityPro failed" + JSON.stringify(err)) + expect(err.code).assertEqual(ERROR_ABILITY_NOT_EXIST) + done() + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0022 + * @tc.name: getProfileByAbilityInvalidAbilityCall + * @tc.desc: Check the invalid abilityName (by callback) + * @tc.level 0 + */ + it('getProfileByAbilityInvalidAbilityCall', 0, async function (done) { + manager.getProfileByAbility(MODULE_NAME, ABILITY_NAME_TEST, METADATA_NAME, (err, data) => { + expect(err.code).assertEqual(ERROR_ABILITY_NOT_EXIST); + console.error('[getProfileByAbilityInvalidAbilityCall]Operation failed. Cause: ' + JSON.stringify(err)); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0029 + * @tc.name: getProfileByAbilityEmptyAbilityCall + * @tc.desc: Check the empty abilityName (by callback) + * @tc.level 0 + */ + it('getProfileByAbilityEmptyAbilityCall', 0, async function (done) { + manager.getProfileByAbility(MODULE_NAME, '', METADATA_NAME, (err, data) => { + expect(err.code).assertEqual(ERROR_ABILITY_NOT_EXIST); + console.error('[getProfileByAbilityEmptyAbilityCall]Operation failed. Cause: ' + JSON.stringify(err)); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0024 + * @tc.name: getProfileByAbilityCallback + * @tc.desc: Check the valid metadataName (by callback) + * @tc.level 0 + */ + it('getProfileByAbilityCallback', 0, async function (done) { + manager.getProfileByAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME, (err, data) => { + console.info('[getProfileByAbilityCallback] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect(Array.isArray(data)).assertTrue(); + expect(typeof data[0]).assertEqual("string"); + expect(data[0]).assertEqual(PROFILE_JSON_STRING); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0026 + * @tc.name: getProfileByAbilityInvalidMetaDataCall + * @tc.desc: Check the invalid metadataName (by callback) + * @tc.level 0 + */ + it('getProfileByAbilityInvalidMetaDataCall', 0, async function (done) { + manager.getProfileByAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME_TEST, (err, data) => { + expect(err.code).assertEqual(ERROR_PROFILE_NOT_EXIST); + console.error('[getProfileByAbilityInvalidMetaDataCall]Operation failed. Cause: ' + JSON.stringify(err)); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0036 + * @tc.name: getProfileByAbilityEmptyMetaDataCall + * @tc.desc: Check the empty metadataName (by callback) + * @tc.level 0 + */ + it('getProfileByAbilityEmptyMetaDataCall', 0, async function (done) { + manager.getProfileByAbility(MODULE_NAME, ABILITY_NAME, '', (err, data) => { + console.info('[getProfileByAbilityEmptyMetaDataCall] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect(Array.isArray(data)).assertTrue(); + expect(typeof data[0]).assertEqual("string"); + expect(data[0]).assertEqual(PROFILE_JSON_STRING); + expect(typeof data[1]).assertEqual("string"); + expect(data[1]).assertEqual(PROFILE_JSON_STRING); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0002 + * @tc.name: getProfileByAbilityPromise + * @tc.desc: Check the valid metadataName (by promise) + * @tc.level 0 + */ + it('getProfileByAbilityPromise', 0, async function (done) { + await manager.getProfileByAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME).then(data => { + console.info('[getProfileByAbilityPromise] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect(Array.isArray(data)).assertTrue(); + expect(typeof data[0]).assertEqual("string"); + expect(data[0]).assertEqual(PROFILE_JSON_STRING); + done(); + }).catch(err => { + console.error('[getProfileByAbilityPromise]Operation failed. Cause: ' + JSON.stringify(err)); + expect().assertFail(); + done(); + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0004 + * @tc.name: getProfileByAbilityInvalidMetaDataPro + * @tc.desc: Check the invalid metadataName (by promise) + * @tc.level 0 + */ + it('getProfileByAbilityInvalidMetaDataPro', 0, async function (done) { + await manager.getProfileByAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME_TEST).then(data => { + console.info('[getProfileByAbilityInvalidMetaDataPro] getApplicationInfo callback data is: ' + JSON.stringify(data)); + done() + }).catch(err => { + console.error('[getProfileByAbilityInvalidMetaDataPro]Operation failed. Cause: ' + JSON.stringify(err)); + expect(err.code).assertEqual(ERROR_PROFILE_NOT_EXIST); + done(); + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0030 + * @tc.name: getProfileByAbilityEmptyMetaDataPro + * @tc.desc: Check the empty metadataName (by promise) + * @tc.level 0 + */ + it('getProfileByAbilityEmptyMetaDataPro', 0, async function (done) { + await manager.getProfileByAbility(MODULE_NAME, ABILITY_NAME, '').then(data => { + console.info('[getProfileByAbilityEmptyMetaDataPro] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect(Array.isArray(data)).assertTrue(); + expect(typeof data[0]).assertEqual("string"); + expect(data[0]).assertEqual(PROFILE_JSON_STRING); + expect(typeof data[1]).assertEqual("string"); + expect(data[1]).assertEqual(PROFILE_JSON_STRING); + done(); + }).catch(err => { + console.error('[getProfileByAbilityEmptyMetaDataPro]Operation failed. Cause: ' + JSON.stringify(err)); + expect().assertFail(); + done(); + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0009 + * @tc.name: getProfileByAbilityNoMetaDataPro + * @tc.desc: without metadataName (by promise) + * @tc.level 0 + */ + it('getProfileByAbilityNoMetaDataPro', 0, async function (done) { + await manager.getProfileByAbility(MODULE_NAME, ABILITY_NAME).then(data => { + console.info('[getProfileByAbilityNoMetaDataPro] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect(Array.isArray(data)).assertTrue(); + expect(typeof data[0]).assertEqual("string"); + expect(data[0]).assertEqual(PROFILE_JSON_STRING); + expect(typeof data[1]).assertEqual("string"); + expect(data[1]).assertEqual(PROFILE_JSON_STRING); + done(); + }).catch(err => { + console.error('[getProfileByAbilityNoMetaDataPro]Operation failed. Cause: ' + JSON.stringify(err)); + expect().assertFail(); + done(); + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0048 + * @tc.name: getProfileByAbilityNoProfilePro + * @tc.desc: no profile configured under the ability (by promise) + * @tc.level 0 + */ + it('getProfileByAbilityNoProfilePro', 0, async function (done) { + await manager.getProfileByAbility(MODULE_NAME, ABILITY_NAME1).then(data => { + console.info('[getProfileByAbilityNoProfilePro] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect(data).assertFail() + done(); + }).catch(err => { + console.error('[getProfileByAbilityNoProfilePro]Operation failed. Cause: ' + JSON.stringify(err)); + expect(err.code).assertEqual(ERROR_PROFILE_NOT_EXIST); + done(); + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0045 + * @tc.name: getProfileByAbilityNotPrefixPro + * @tc.desc: resource has no prefix '$profile:' (by promise) + * @tc.level 0 + */ + it('getProfileByAbilityNotPrefixPro', 0, async function (done) { + await manager.getProfileByAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME2).then(data => { + console.info('[getProfileByAbilityNotPrefixPro] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect(data).assertFail() + done(); + }).catch(err => { + console.error('[getProfileByAbilityNotPrefixPro]Operation failed. Cause: ' + JSON.stringify(err)); + expect(err.code).assertEqual(ERROR_PROFILE_NOT_EXIST); + done(); + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0044 + * @tc.name: getProfileByAbilityNotPrefixCall + * @tc.desc: resource has no prefix '$profile:' (by callback) + * @tc.level 0 + */ + it('getProfileByAbilityNotPrefixCall', 0, async function (done) { + manager.getProfileByAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME2, (err, data) => { + expect(err.code).assertEqual(ERROR_PROFILE_NOT_EXIST); + console.error('[getProfileByAbilityNotPrefixCall]Operation failed. Cause: ' + JSON.stringify(err)); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0007 + * @tc.name: getProfileByAbilityNotSuffixPro + * @tc.desc: profile is .txt suffix (by promise) + * @tc.level 0 + */ + it('getProfileByAbilityNotSuffixPro', 0, async function (done) { + await manager.getProfileByAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME3).then(data => { + console.info('[getProfileByAbilityNotSuffixPro] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect(Array.isArray(data)).assertTrue(); + expect(typeof data[0]).assertEqual("string"); + done(); + }).catch(err => { + console.error('[getProfileByAbilityNotSuffixPro]Operation failed. Cause: ' + JSON.stringify(err)); + expect().assertFail(); + done(); + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0040 + * @tc.name: getProfileByAbilityNotSuffixCall + * @tc.desc: profile is .txt suffix (by callback) + * @tc.level 0 + */ + it('getProfileByAbilityNotSuffixCall', 0, async function (done) { + manager.getProfileByAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME3, (err, data) => { + console.info('[getProfileByAbilityNotSuffixCall] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect(Array.isArray(data)).assertTrue(); + expect(typeof data[0]).assertEqual("string"); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0008 + * @tc.name: getProfileByAbilityNoJsonPro + * @tc.desc: profile is invalid json format (by promise) + * @tc.level 0 + */ + it('getProfileByAbilityNoJsonPro', 0, async function (done) { + await manager.getProfileByAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME4).then(data => { + console.info('[getProfileByAbilityNoJsonPro] data is: ' + JSON.stringify(data)); + expect().assertFail(); + done(); + }).catch(err => { + console.error('[getProfileByAbilityNoJsonPro] Operation failed. Cause: ' + JSON.stringify(err)); + expect(err.code).assertEqual(ERROR_PROFILE_NOT_EXIST); + done(); + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0046 + * @tc.name: getProfileByAbilityNoJsonCall + * @tc.desc: profile is invalid json format (by callback) + * @tc.level 0 + */ + it('getProfileByAbilityNoJsonCall', 0, async function (done) { + manager.getProfileByAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME4, (err, data) => { + console.info('[getProfileByAbilityNoJsonCall] err: ' + JSON.stringify(err)); + expect(err.code).assertEqual(ERROR_PROFILE_NOT_EXIST); + done(); + }); + }) + }) +} \ No newline at end of file diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/test/GetProfileByExtensionAbility.test.ets b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/test/GetProfileByExtensionAbility.test.ets new file mode 100755 index 000000000..506c80b65 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/test/GetProfileByExtensionAbility.test.ets @@ -0,0 +1,411 @@ +/** + * 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 manager from '@ohos.bundle.bundleManager'; +import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from "@ohos/hypium" + +const MODULE_NAME = "phone" +const MODULE_NAME_TEST = "phone1" +const ABILITY_NAME = "Form" +const ABILITY_NAME1 = "Form1" +const ABILITY_NAME_TEST = "FromTest" +const METADATA_NAME = "ohos.extension.form" +const METADATA_NAME1 = "ohos.extension.form1" +const METADATA_NAME2 = "ohos.extension.form2" +const METADATA_NAME3 = "ohos.extension.form3" +const METADATA_NAME4 = "ohos.extension.form4" +const METADATA_NAME_TEST = "ohos.test.form" +const PROFILE_JSON_STRING = "{\"src\":[\"MainAbility/pages/index/index\",\"MainAbility/pages/second/second\"]}" +const ERROR_ABILITY_NOT_EXIST = 17700003 +const ERROR_PROFILE_NOT_EXIST = 17700024 +const ERROR_MODULE_NOT_EXIST = 17700002 + +export default function getProfileByExtensionAbility() { + describe('getProfileByExtensionAbility', function () { + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0011 + * @tc.name: getProfileByExtensionAbilityInvalidModulePro + * @tc.desc: Check the invalid moduleName (by promise) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityInvalidModulePro', 0, async function (done) { + await manager.getProfileByExtensionAbility(MODULE_NAME_TEST, ABILITY_NAME, METADATA_NAME).then(data => { + console.info("getProfileByExtensionAbilityInvalidModulePro success" + JSON.stringify(data)) + expect(data).assertFail() + done() + }).catch(err => { + console.info("getProfileByExtensionAbilityInvalidModulePro failed" + JSON.stringify(err)) + expect(err.code).assertEqual(ERROR_ABILITY_NOT_EXIST) + done() + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0015 + * @tc.name: getProfileByExtensionAbilityEmptyModulePro + * @tc.desc: Check the empty moduleName (by promise) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityEmptyModulePro', 0, async function (done) { + await manager.getProfileByExtensionAbility('', ABILITY_NAME, METADATA_NAME).then(data => { + console.info("getProfileByExtensionAbilityEmptyModulePro success" + JSON.stringify(data)) + expect(data).assertFail() + done() + }).catch(err => { + console.info("getProfileByExtensionAbilityEmptyModulePro failed" + JSON.stringify(err)) + expect(err.code).assertEqual(ERROR_MODULE_NOT_EXIST) + done() + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0017 + * @tc.name: getProfileByExtensionAbilityInvalidModuleCall + * @tc.desc: Check the invalid moduleName (by callback) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityInvalidModuleCall', 0, async function (done) { + manager.getProfileByExtensionAbility(MODULE_NAME_TEST, ABILITY_NAME, METADATA_NAME, (err, data) => { + expect(err.code).assertEqual(ERROR_ABILITY_NOT_EXIST); + console.error('[getProfileByExtensionAbilityInvalidModuleCall]Operation failed. Cause: ' + JSON.stringify(err)); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0034 + * @tc.name: getProfileByExtensionAbilityEmptyModuleCall + * @tc.desc: Check the empty moduleName (by callback) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityEmptyModuleCall', 0, async function (done) { + manager.getProfileByExtensionAbility('', ABILITY_NAME, METADATA_NAME, (err, data) => { + expect(err.code).assertEqual(ERROR_MODULE_NOT_EXIST); + console.error('[getProfileByExtensionAbilityEmptyModuleCall]Operation failed. Cause: ' + JSON.stringify(err)); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0012 + * @tc.name: getProfileByExtensionAbilityInvalidAbilityPro + * @tc.desc: Check the invalid abilityName (by promise) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityInvalidAbilityPro', 0, async function (done) { + await manager.getProfileByExtensionAbility(MODULE_NAME, ABILITY_NAME_TEST, METADATA_NAME).then(data => { + console.info("getProfileByExtensionAbilityInvalidAbilityPro success" + JSON.stringify(data)) + expect(data).assertFail() + done() + }).catch(err => { + console.info("getProfileByExtensionAbilityInvalidAbilityPro failed" + JSON.stringify(err)) + expect(err.code).assertEqual(ERROR_ABILITY_NOT_EXIST) + done() + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0029 + * @tc.name: getProfileByExtensionAbilityEmptyAbilityPro + * @tc.desc: Check the empty abilityName (by promise) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityEmptyAbilityPro', 0, async function (done) { + await manager.getProfileByExtensionAbility(MODULE_NAME, '', METADATA_NAME).then(data => { + console.info("getProfileByExtensionAbilityEmptyAbilityPro success" + JSON.stringify(data)) + expect(data).assertFail() + done() + }).catch(err => { + console.info("getProfileByExtensionAbilityEmptyAbilityPro failed" + JSON.stringify(err)) + expect(err.code).assertEqual(ERROR_ABILITY_NOT_EXIST) + done() + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0022 + * @tc.name: getProfileByExtensionAbilityInvalidAbilityCall + * @tc.desc: Check the invalid abilityName (by callback) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityInvalidAbilityCall', 0, async function (done) { + manager.getProfileByExtensionAbility(MODULE_NAME, ABILITY_NAME_TEST, METADATA_NAME, (err, data) => { + expect(err.code).assertEqual(ERROR_ABILITY_NOT_EXIST); + console.error('[getProfileByExtensionAbilityInvalidAbilityCall]Operation failed. Cause: ' + JSON.stringify(err)); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0029 + * @tc.name: getProfileByExtensionAbilityEmptyAbilityCall + * @tc.desc: Check the empty abilityName (by callback) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityEmptyAbilityCall', 0, async function (done) { + manager.getProfileByExtensionAbility(MODULE_NAME, '', METADATA_NAME, (err, data) => { + expect(err.code).assertEqual(ERROR_ABILITY_NOT_EXIST); + console.error('[getProfileByExtensionAbilityEmptyAbilityCall]Operation failed. Cause: ' + JSON.stringify(err)); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0024 + * @tc.name: getProfileByExtensionAbilityCallback + * @tc.desc: Check the valid metadataName (by callback) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityCallback', 0, async function (done) { + manager.getProfileByExtensionAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME, (err, data) => { + console.info('[getProfileByExtensionAbilityCallback] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect(Array.isArray(data)).assertTrue(); + expect(typeof data[0]).assertEqual("string"); + expect(data[0]).assertEqual(PROFILE_JSON_STRING); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0026 + * @tc.name: getProfileByExtensionAbilityInvalidMetaDataCall + * @tc.desc: Check the invalid metadataName (by callback) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityInvalidMetaDataCall', 0, async function (done) { + manager.getProfileByExtensionAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME_TEST, (err, data) => { + expect(err.code).assertEqual(ERROR_PROFILE_NOT_EXIST); + console.error('[getProfileByExtensionAbilityInvalidMetaDataCall]Operation failed. Cause: ' + JSON.stringify(err)); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0036 + * @tc.name: getProfileByExtensionAbilityEmptyMetaDataCall + * @tc.desc: Check the empty metadataName (by callback) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityEmptyMetaDataCall', 0, async function (done) { + manager.getProfileByExtensionAbility(MODULE_NAME, ABILITY_NAME, '', (err, data) => { + console.info('[getProfileByExtensionAbilityEmptyMetaDataCall] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect(Array.isArray(data)).assertTrue(); + expect(typeof data[0]).assertEqual("string"); + expect(data[0]).assertEqual(PROFILE_JSON_STRING); + expect(typeof data[1]).assertEqual("string"); + expect(data[1]).assertEqual(PROFILE_JSON_STRING); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0002 + * @tc.name: getProfileByExtensionAbilityPromise + * @tc.desc: Check the valid metadataName (by promise) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityPromise', 0, async function (done) { + await manager.getProfileByExtensionAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME).then(data => { + console.info('[getProfileByExtensionAbilityPromise] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect(Array.isArray(data)).assertTrue(); + expect(typeof data[0]).assertEqual("string"); + expect(data[0]).assertEqual(PROFILE_JSON_STRING); + done(); + }).catch(err => { + console.error('[getProfileByExtensionAbilityPromise]Operation failed. Cause: ' + JSON.stringify(err)); + expect().assertFail(); + done(); + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0004 + * @tc.name: getProfileByExtensionAbilityInvalidMetaDataPro + * @tc.desc: Check the invalid metadataName (by promise) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityInvalidMetaDataPro', 0, async function (done) { + await manager.getProfileByExtensionAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME_TEST).then(data => { + console.info('[getProfileByExtensionAbilityInvalidMetaDataPro] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect().assertFail(); + done() + }).catch(err => { + console.error('[getProfileByExtensionAbilityInvalidMetaDataPro]Operation failed. Cause: ' + JSON.stringify(err)); + expect(err.code).assertEqual(ERROR_PROFILE_NOT_EXIST); + done(); + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0030 + * @tc.name: getProfileByExtensionAbilityEmptyMetaDataPro + * @tc.desc: Check the empty metadataName (by promise) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityEmptyMetaDataPro', 0, async function (done) { + await manager.getProfileByExtensionAbility(MODULE_NAME, ABILITY_NAME, '').then(data => { + console.info('[getProfileByExtensionAbilityEmptyMetaDataPro] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect(Array.isArray(data)).assertTrue(); + expect(typeof data[0]).assertEqual("string"); + expect(data[0]).assertEqual(PROFILE_JSON_STRING); + expect(typeof data[1]).assertEqual("string"); + expect(data[1]).assertEqual(PROFILE_JSON_STRING); + done(); + }).catch(err => { + console.error('[getProfileByExtensionAbilityEmptyMetaDataPro]Operation failed. Cause: ' + JSON.stringify(err)); + expect().assertFail(); + done(); + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0009 + * @tc.name: getProfileByExtensionAbilityNoMetaDataPro + * @tc.desc: without metadataName (by promise) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityNoMetaDataPro', 0, async function (done) { + await manager.getProfileByExtensionAbility(MODULE_NAME, ABILITY_NAME).then(data => { + console.info('[getProfileByExtensionAbilityNoMetaDataPro] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect(Array.isArray(data)).assertTrue(); + expect(typeof data[0]).assertEqual("string"); + expect(data[0]).assertEqual(PROFILE_JSON_STRING); + expect(typeof data[1]).assertEqual("string"); + expect(data[1]).assertEqual(PROFILE_JSON_STRING); + done(); + }).catch(err => { + console.error('[getProfileByExtensionAbilityNoMetaDataPro]Operation failed. Cause: ' + JSON.stringify(err)); + expect().assertFail(); + done(); + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0048 + * @tc.name: getProfileByExtensionAbilityNoProfilePro + * @tc.desc: no profile configured under the ability (by promise) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityNoProfilePro', 0, async function (done) { + await manager.getProfileByExtensionAbility(MODULE_NAME, ABILITY_NAME1).then(data => { + console.info('[getProfileByExtensionAbilityNoProfilePro] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect().assertFail(); + done(); + }).catch(err => { + console.error('[getProfileByExtensionAbilityNoProfilePro]Operation failed. Cause: ' + JSON.stringify(err)); + expect(err.code).assertEqual(ERROR_PROFILE_NOT_EXIST); + done(); + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0045 + * @tc.name: getProfileByExtensionAbilityNotPrefixPro + * @tc.desc: resource has no prefix '$profile:' (by promise) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityNotPrefixPro', 0, async function (done) { + await manager.getProfileByExtensionAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME2).then(data => { + console.info('[getProfileByExtensionAbilityNotPrefixPro] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect().assertFail(); + done(); + }).catch(err => { + console.error('[getProfileByExtensionAbilityNotPrefixPro]Operation failed. Cause: ' + JSON.stringify(err)); + expect(err.code).assertEqual(ERROR_PROFILE_NOT_EXIST); + done(); + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0044 + * @tc.name: getProfileByExtensionAbilityNotPrefixCall + * @tc.desc: resource has no prefix '$profile:' (by callback) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityNotPrefixCall', 0, async function (done) { + manager.getProfileByExtensionAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME2, (err, data) => { + expect(err.code).assertEqual(ERROR_PROFILE_NOT_EXIST); + console.error('[getProfileByExtensionAbilityNotPrefixCall]Operation failed. Cause: ' + JSON.stringify(err)); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0007 + * @tc.name: getProfileByExtensionAbilityNotSuffixPro + * @tc.desc: profile is .txt suffix (by promise) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityNotSuffixPro', 0, async function (done) { + await manager.getProfileByExtensionAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME3).then(data => { + console.info('[getProfileByExtensionAbilityNotSuffixPro] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect(Array.isArray(data)).assertTrue(); + expect(typeof data[0]).assertEqual("string"); + done(); + }).catch(err => { + console.error('[getProfileByExtensionAbilityNotSuffixPro]Operation failed. Cause: ' + JSON.stringify(err)); + expect().assertFail(); + done(); + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0040 + * @tc.name: getProfileByExtensionAbilityNotSuffixCall + * @tc.desc: profile is .txt suffix (by callback) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityNotSuffixCall', 0, async function (done) { + manager.getProfileByExtensionAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME3, (err, data) => { + console.info('[getProfileByExtensionAbilityNotSuffixCall] getApplicationInfo callback data is: ' + JSON.stringify(data)); + expect(Array.isArray(data)).assertTrue(); + expect(typeof data[0]).assertEqual("string"); + done(); + }); + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0008 + * @tc.name: getProfileByExtensionAbilityNoJsonPro + * @tc.desc: profile is invalid json format (by promise) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityNoJsonPro', 0, async function (done) { + await manager.getProfileByExtensionAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME4).then(data => { + console.info('[getProfileByExtensionAbilityNoJsonPro] data is: ' + JSON.stringify(data)); + expect().assertFail(); + done(); + }).catch(err => { + console.error('[getProfileByExtensionAbilityNoJsonPro] Operation failed. Cause: ' + JSON.stringify(err)); + expect(err.code).assertEqual(ERROR_PROFILE_NOT_EXIST); + done(); + }) + }) + + /* + * @tc.number: SUB_BMS_APPINFO_QUERYMETAFILE_0046 + * @tc.name: getProfileByExtensionAbilityNoJsonCall + * @tc.desc: profile is invalid json format (by callback) + * @tc.level 0 + */ + it('getProfileByExtensionAbilityNoJsonCall', 0, async function (done) { + manager.getProfileByExtensionAbility(MODULE_NAME, ABILITY_NAME, METADATA_NAME4, (err, data) => { + console.info('[getProfileByExtensionAbilityNoJsonCall] err: ' + JSON.stringify(err)); + expect(err.code).assertEqual(ERROR_PROFILE_NOT_EXIST); + done(); + }); + }) + }) +} \ No newline at end of file diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/test/List.test.ets b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/test/List.test.ets new file mode 100755 index 000000000..9f75ecfa4 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/ets/test/List.test.ets @@ -0,0 +1,22 @@ +/* + * 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 getProfileByAbility from './GetProfileByAbility.test.ets'; +import getProfileByExtensionAbility from './GetProfileByExtensionAbility.test.ets'; + +export default function testsuite() { + getProfileByAbility(); + getProfileByExtensionAbility(); +} \ No newline at end of file diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/module.json b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/module.json new file mode 100755 index 000000000..7c6599d81 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/module.json @@ -0,0 +1,123 @@ +{ + "module": { + "name": "phone", + "type": "entry", + "srcEntrance": "./ets/Application/AbilityStage.ts", + "description": "$string:phone_entry_dsc", + "mainElement": "MainAbility", + "deviceTypes": [ + "default" + ], + "deliveryWithInstall": true, + "installationFree": false, + "uiSyntax": "ets", + "pages": "$profile:main_pages", + "abilities": [ + { + "name": "ohos.acts.bundle.stage.test.MainAbility", + "srcEntrance": "./ets/MainAbility/MainAbility.ts", + "description": "$string:phone_entry_main", + "icon": "$media:icon", + "label": "$string:entry_label", + "visible": true, + "orientation": "portrait", + "skills": [ + { + "actions": [ + "action.system.home" + ], + "entities":[ + "entity.system.home" + ] + } + ], + "metadata": [ + { + "name": "ohos.ability.form", + "value": "", + "resource": "$profile:shortcuts_config" + }, + { + "name": "ohos.ability.form1", + "value": "", + "resource": "$profile:form_config" + }, + { + "name": "ohos.ability.form2", + "value": "", + "resource": "@profile:form_config" + }, + { + "name": "ohos.ability.form3", + "value": "", + "resource": "$profile:form_config1" + }, + { + "name": "ohos.ability.form4", + "value": "", + "resource": "$profile:invalid" + } + ] + }, + { + "name": "ohos.acts.bundle.stage.test.MainAbility1", + "srcEntrance": "./ets/MainAbility/MainAbility.ts", + "description": "$string:phone_entry_main", + "icon": "$media:icon", + "label": "$string:entry_label", + "visible": true, + "orientation": "portrait", + "skills": [] + } + ], + "extensionAbilities": [ + { + "description": "$string:form_description", + "descriptionId": 16777219, + "icon": "$media:icon", + "iconId": 16777225, + "metadata": [ + { + "name": "ohos.extension.form", + "value": "", + "resource": "$profile:shortcuts_config" + }, + { + "name": "ohos.extension.form1", + "value": "", + "resource": "$profile:form_config" + }, + { + "name": "ohos.extension.form2", + "value": "", + "resource": "@profile:form_config" + }, + { + "name": "ohos.extension.form3", + "value": "", + "resource": "$profile:form_config1" + }, + { + "name": "ohos.extension.form4", + "value": "", + "resource": "$profile:invalid" + } + ], + "name": "Form", + "srcEntrance": "./ets/FormAbility/FormAbility.ts", + "type": "form", + "visible": true + }, + { + "description": "$string:form_description", + "descriptionId": 16777219, + "icon": "$media:icon", + "iconId": 16777225, + "name": "Form1", + "srcEntrance": "./ets/FormAbility/FormAbility.ts", + "type": "form", + "visible": true + } + ] + } +} diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/element/string.json b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/element/string.json new file mode 100755 index 000000000..c9962d9e0 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/element/string.json @@ -0,0 +1,40 @@ +{ + "string": [ + { + "name": "phone_entry_dsc", + "value": "i am an entry for phone" + }, + { + "name": "phone_entry_main", + "value": "the phone entry ability" + }, + { + "name": "entry_label", + "value": "ActsContextTest" + }, + { + "name": "form_description", + "value": "my form" + }, + { + "name": "serviceability_description", + "value": "my whether" + }, + { + "name": "description_application", + "value": "demo for test" + }, + { + "name": "app_name", + "value": "Demo" + }, + { + "name": "form_FormAbility_desc", + "value": "form_description" + }, + { + "name": "form_FormAbility_label", + "value": "form_label" + } + ] +} diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/media/icon.png b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/media/icon.png new file mode 100755 index 0000000000000000000000000000000000000000..474a55588fd7216113dd42073aadf254d4dba023 GIT binary patch literal 15458 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 Y0jIQKqpXab7ytkO07*qoM6N<$f;yQ2zW@LL literal 0 HcmV?d00001 diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/form_config.json b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/form_config.json new file mode 100755 index 000000000..e892d4472 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/form_config.json @@ -0,0 +1,6 @@ +{ + "src": [ + "MainAbility/pages/index/index", + "MainAbility/pages/second/second" + ] +} \ No newline at end of file diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/form_config1.txt b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/form_config1.txt new file mode 100755 index 000000000..77beb4dc5 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/form_config1.txt @@ -0,0 +1 @@ +{"forms" :[{"colorMode" : "auto","defaultDimension" : "2*2","description" : "$string:16777219","formConfigAbility" : "ability://xxxxx","formVisibleNotify" : false,"isDefault" : true,"name" : "Form_Js","scheduledUpdateTime" : "10:30","src" : "pages/card/index","supportDimensions" :["2*2"],"updateDuration" : 1,"updateEnabled" : true,"window" :{"autoDesignWidth" : true,"designWidth" : 720}}]} \ No newline at end of file diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/invalid.txt b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/invalid.txt new file mode 100755 index 000000000..cdca51a17 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/invalid.txt @@ -0,0 +1,5 @@ +{ + "src": [ + "MainAbility/pages/index/index", + "MainAbility/pages/second/second" +} \ No newline at end of file diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/main_pages.json b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/main_pages.json new file mode 100755 index 000000000..02221db61 --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/main_pages.json @@ -0,0 +1,6 @@ +{ + "src": [ + "MainAbility/pages/index/index", + "MainAbility/pages/second/second" + ] +} \ No newline at end of file diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/shortcuts_config.json b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/shortcuts_config.json new file mode 100755 index 000000000..010134e5c --- /dev/null +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/entry/src/main/resources/base/profile/shortcuts_config.json @@ -0,0 +1,6 @@ +{ + "src": [ + "MainAbility/pages/index/index", + "MainAbility/pages/second/second" + ] +} \ No newline at end of file diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/signature/openharmony_sx.p7b b/bundlemanager/bundle_standard/bundlemanager/actsbmsbundlemanagerstagetest/signature/openharmony_sx.p7b new file mode 100755 index 0000000000000000000000000000000000000000..3a7eb6dc682f3ce734ec103281c9727559e00085 GIT binary patch literal 3466 zcmcgvYj6|S6}BFhF-F+LfPn%w;$Z^FzAH<%kbFrM_Xz$QH4cl+sPQTcokNzq~_;i1CpT#!s5m6ysSGWm>@ANSBin01%R z71FX2*1cec$QdQw0YdC2JydeIn`j~eREP+RQ`C(ig4E*SAVoH_>kJ^{BEq!a<9Fe7 zlC?PbLr{&*P@qK37M)tBge_>w>mV_mPKm{pO4vzwVMd3*ULA@XmBn!tj3HicqpzXf zSZOk;V8#k#8Z4%a!+OMPs77GB1#U1H*%{0x2KCxi)h5$yl%XqKn(AnkM&0bJQA7y~ zT8kkr4GdXPWehV}N|1oF!RK=Yp(ZEU;H}nF`y8axg4Sb7G=+j=82%{AWJ4IICQxs; znL|#A)N2ALqxHEASUt*M^>8!G!J>;9Em*9E^%_(SF{~boJ@C~d6lRJrN>hrX24(ar zOFe4E5M3`XA6DTYA6YY|vB0+8eMT%Os$gnsWIDS|Pdg})}VGK$bwm9uZ zrO6bkk$Kz=cCA4wYXY_sSc}IXNqr^aMpaZqZPwL7ge@2|+T&Fk2dQT;PekjpS``45 z2Xw$OXV1?d>83ic$KYpXC+qk?O^h{fp(yZjDPO zHdaIxl)+l<#W9%CD3y(xDom16Y&*0$W%$72GwKA zgsrf?YV7MHE-F~muL6tMhEPNk5t;?!p#WQTBoz+gfs`2%dkCD4Cd*#rV>?7|sE!>X zVyhf?1tQ7v#sdM0A>86#d(K=o#MXMyA4&GJ6e7&dANIRw7BnC-M~%QhJ$C4#^Btnew&0wgS@0SD>tW~x4=T+L1-eFkPPv1$Mg@up->>%hS(hxC}A)@ zPbh(a1V|tW`<2z^38e~1QUdjvAoL?i08rFRqVP#1D#Mh=A0P_My`3D`L9QSpl?E=S zFCRQk1`kQ&*PP=1ySsDmr*Pw;5yyTr_0?VKvL(Xye9pgiP5awR7tUWCk8LmemUrgs zBP4gaWmf*-zjv5cWsdyo%hHoPa`}-_uWmMjN|4Xe88?wX3XEJl{G*mG(a3*fZJgcJ zGkJdZ*Xav3i8Wwo5|GW|{D;ryaWfW!aY=h9ewMla;(kCqYOXp%EIIsF-*_0mhn725}?N=u4+bqk8 z?YJLVc=@yJeXM>|tbUI5=_mW5eEC2w!1p7MZYr44dvy6vIyy5&(T|7-l0x!+B1)N0 zkx3KCc_^Or>A&EoiFnR5K33Y(ysAOCWZiY4{>c5Q)K@MzID3A#IBQ+g!K-%r={ajR zy^#3f&G+qm&2miB9$JlT-Pv)gyY8-~bI8yh*V2_AXohWmQF!6N)=hWoM%{JoYnCNgP2xCFPapYkWynFnMi>Jxrj;$NViZ`5n zhvHB4+Y9NnTrlbNNx!1z?wpum9=@gRR>w;~KdV{weH6VM+S0Us-7T=D(YUJl+_t>4 z(>qUUMzy4~I>K2UUGCG-c;c;@1DQO<)9craAX$l|zmAgT)9Hv$kkEt;Umab)Cr`F( z*}GfnzPJKUF63Vt^V-e#=_ShD+Xdh4x?VWu__>#be>zaMWnswHdUWAWLVKG!-+a#u zYW9D)W@>5W8(n+eUOQ&p)|;)ZIX6$YPiVcfXx{$m`FE}!ySU;9v30Wx-~*b|V>R-B zXza1gZNLq~^Q8fT3xel=CSURjeSOg%?v(rLb{s9;aOqIa(Q~<%7I<=um$lZ9TNjV^ zb?Lr2d$nuCnXBi9vCZnpAd1;h9^Po~nj*gYhHd9Nt5@f|9eA#1WMb^Sr56ls;ma%V zOCdYm=6zTC+H)TkK?x4bifktPY5)ySJ)cy~Y4nG+6;DM6KgV@;ro;4gW_JNU^ z4rQ~Kq6Ekx_9;>#k(Skh;)hW_B;psyxeDQ|J*_4GEIWRn{_sb4Zr{ij489rr{KgrT z@!;&OgTUYiH#wKD0VsDu+S&^Dvl$yFe74GR)R&|G3ze&0jsO4v literal 0 HcmV?d00001 diff --git a/bundlemanager/bundle_standard/bundlemanager/actsbmsstageetstest/entry/src/main/module.json b/bundlemanager/bundle_standard/bundlemanager/actsbmsstageetstest/entry/src/main/module.json index 69858ac37..7c6599d81 100644 --- a/bundlemanager/bundle_standard/bundlemanager/actsbmsstageetstest/entry/src/main/module.json +++ b/bundlemanager/bundle_standard/bundlemanager/actsbmsstageetstest/entry/src/main/module.json @@ -6,7 +6,6 @@ "description": "$string:phone_entry_dsc", "mainElement": "MainAbility", "deviceTypes": [ - "default", "default" ], "deliveryWithInstall": true, -- GitLab