diff --git a/ability/ability_runtime/BUILD.gn b/ability/ability_runtime/BUILD.gn index 210862eb137be98d63099f37c73b290dd702b2ab..416aba7bf55969fde96025cc33ae19c77af7c402 100644 --- a/ability/ability_runtime/BUILD.gn +++ b/ability/ability_runtime/BUILD.gn @@ -22,6 +22,7 @@ group("ability_runtime") { "abilitymontior:ActsAbilityMonitorTest", "abilitymultiinstance:abilitymultiinstance", "abilitystagemonitor:abilitystagemonitor", + "actsrevokequickfixtest:ActsRevokeQuickFixApp", "actsabilitydelegatorcase:ActsAbilityDelegatorCaseTest", "actsabilitymanageretstest:ActsAbilityManagerEtsTest", "actsabilityusertest:ActsAbilityuserTest", diff --git a/ability/ability_runtime/actsrevokequickfixtest/AppScope/app.json b/ability/ability_runtime/actsrevokequickfixtest/AppScope/app.json new file mode 100644 index 0000000000000000000000000000000000000000..72545ccbee97003988b84ddb387b9b754895be72 --- /dev/null +++ b/ability/ability_runtime/actsrevokequickfixtest/AppScope/app.json @@ -0,0 +1,19 @@ +{ + "app": { + "bundleName": "com.acts.actsrevokequickfixapp", + "vendor": "example", + "versionCode": 1000000, + "versionName": "1.0.0", + "icon": "$media:app_icon", + "label": "$string:app_name", + "distributedNotificationEnabled": true, + "keepAlive" : true, + "singleUser": true, + "minAPIVersion": 10, + "targetAPIVersion": 10, + "car": { + "apiCompatibleVersion": 10, + "singleUser": false + } + } +} diff --git a/ability/ability_runtime/actsrevokequickfixtest/AppScope/resources/base/element/string.json b/ability/ability_runtime/actsrevokequickfixtest/AppScope/resources/base/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..fc7a8551b5ff0250a37bfef11984749fd25ef1dc --- /dev/null +++ b/ability/ability_runtime/actsrevokequickfixtest/AppScope/resources/base/element/string.json @@ -0,0 +1,8 @@ +{ + "string": [ + { + "name": "app_name", + "value": "ActsRevokeQuickFixApp" + } + ] +} diff --git a/ability/ability_runtime/actsrevokequickfixtest/AppScope/resources/base/media/app_icon.png b/ability/ability_runtime/actsrevokequickfixtest/AppScope/resources/base/media/app_icon.png new file mode 100644 index 0000000000000000000000000000000000000000..ce307a8827bd75456441ceb57d530e4c8d45d36c Binary files /dev/null and b/ability/ability_runtime/actsrevokequickfixtest/AppScope/resources/base/media/app_icon.png differ diff --git a/ability/ability_runtime/actsrevokequickfixtest/BUILD.gn b/ability/ability_runtime/actsrevokequickfixtest/BUILD.gn new file mode 100644 index 0000000000000000000000000000000000000000..eed77929255b6780c75b35202107ef6119f8ac99 --- /dev/null +++ b/ability/ability_runtime/actsrevokequickfixtest/BUILD.gn @@ -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("//test/xts/tools/build/suite.gni") + +ohos_js_hap_suite("ActsRevokeQuickFixApp") { + hap_profile = "entry/src/main/module.json" + js_build_mode = "debug" + deps = [ + ":actsrevokequickfixapp_js_assets", + ":actsrevokequickfixapp_resources", + ] + ets2abc = true + certificate_profile = "signature/openharmony_sx.p7b" + hap_name = "ActsRevokeQuickFixApp" + subsystem_name = "ability" + part_name = "ability_runtime" +} + +ohos_app_scope("actsrevokequickfixapp_app_profile") { + app_profile = "AppScope/app.json" + sources = [ "AppScope/resources" ] +} + +ohos_js_assets("actsrevokequickfixapp_js_assets") { + source_dir = "entry/src/main/ets" +} + +ohos_resources("actsrevokequickfixapp_resources") { + sources = [ "entry/src/main/resources" ] + deps = [ ":actsrevokequickfixapp_app_profile" ] + hap_profile = "entry/src/main/module.json" +} diff --git a/ability/ability_runtime/actsrevokequickfixtest/Test.json b/ability/ability_runtime/actsrevokequickfixtest/Test.json new file mode 100644 index 0000000000000000000000000000000000000000..41077d57b2d529f6916d26d63ab6f7c3b39aca5b --- /dev/null +++ b/ability/ability_runtime/actsrevokequickfixtest/Test.json @@ -0,0 +1,26 @@ +{ + "description": "Configuration for aceceshi Tests", + "driver": { + "type": "OHJSUnitTest", + "test-timeout": "600000", + "bundle-name": "com.acts.actsrevokequickfixapp", + "module-name": "entry_test", + "shell-timeout": "600000" + }, + "kits": [ + { + "test-file-name": [ + "ActsRevokeQuickFixApp.hap" + ], + "type": "AppInstallKit", + "cleanup-apps": true + }, + { + "type": "ShellKit", + "run-command": [ + "power-shell wakeup", + "power-shell setmode 602" + ] + } + ] +} \ No newline at end of file diff --git a/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts new file mode 100644 index 0000000000000000000000000000000000000000..94579b9c1535bc11ee56ee53b48fc90a9977e33a --- /dev/null +++ b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts @@ -0,0 +1,71 @@ +import hilog from '@ohos.hilog'; +import TestRunner from '@ohos.application.testRunner' +import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry' + +var abilityDelegator = undefined +var abilityDelegatorArguments = undefined + +function translateParamsToString(parameters) { + const keySet = new Set([ + '-s class', '-s notClass', '-s suite', '-s it', + '-s level', '-s testType', '-s size', '-s timeout', + '-s dryRun' + ]) + let targetParams = ''; + for (const key in parameters) { + if (keySet.has(key)) { + targetParams = `${targetParams} ${key} ${parameters[key]}` + } + } + return targetParams.trim() +} + +async function onAbilityCreateCallback() { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'onAbilityCreateCallback'); +} + +async function addAbilityMonitorCallback(err: any) { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', 'addAbilityMonitorCallback : %{public}s', JSON.stringify(err) ?? ''); +} + +export default class OpenHarmonyTestRunner implements TestRunner { + constructor() { + } + + onPrepare() { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner OnPrepare '); + } + + async onRun() { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner onRun run'); + abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments() + abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator() + var testAbilityName = abilityDelegatorArguments.bundleName + '.TestAbility' + let lMonitor = { + abilityName: testAbilityName, + onAbilityCreate: onAbilityCreateCallback, + }; + abilityDelegator.addAbilityMonitor(lMonitor, addAbilityMonitorCallback) + var cmd = 'aa start -d 0 -a TestAbility' + ' -b ' + abilityDelegatorArguments.bundleName + cmd += ' '+translateParamsToString(abilityDelegatorArguments.parameters) + var debug = abilityDelegatorArguments.parameters['-D'] + if (debug == 'true') + { + cmd += ' -D' + } + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', 'cmd : %{public}s', cmd); + abilityDelegator.executeShellCommand(cmd, + (err: any, d: any) => { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', 'executeShellCommand : err : %{public}s', JSON.stringify(err) ?? ''); + hilog.info(0x0000, 'testTag', 'executeShellCommand : data : %{public}s', d.stdResult ?? ''); + hilog.info(0x0000, 'testTag', 'executeShellCommand : data : %{public}s', d.exitCode ?? ''); + }) + hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner onRun end'); + } +} \ No newline at end of file diff --git a/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/ets/test/Ability.test.ets b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/ets/test/Ability.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..521c524676f6f4bb95fbf8c002953fb9c43e5835 --- /dev/null +++ b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/ets/test/Ability.test.ets @@ -0,0 +1,150 @@ +/* + * 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 hilog from '@ohos.hilog'; +import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from '@ohos/hypium'; +import quickFixManager from '@ohos.app.ability.quickFixManager'; + +export default function abilityTest() { + describe('ActsAbilityTest', function () { + beforeAll(function () {}) + beforeEach(function () {}) + afterEach(function () {}) + afterAll(function () {}) + + /* + * @tc.number: Acts_applyQuickFixRevoke_1300 + * @tc.name: Apply quick fix to support undo. + * @tc.desc: The passed-in exception parameter undefined calls revokeQuickFix, + * and there is an exception return value. + */ + it('Acts_applyQuickFixRevoke_1300',0, function (done) { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'it begin'); + try { + quickFixManager.revokeQuickFix(undefined).then(() => { + console.info("====>Acts_applyQuickFixRevoke_1300 revokeQuickFix " +" ok"); + }).catch((err) => { + console.info("====>Acts_applyQuickFixRevoke_1300 revokeQuickFix " +" failed, error code is ", JSON.stringify((err))); + }) + } catch (err){ + console.info("====>Acts_applyQuickFixRevoke_1300 try revokeQuickFix " +" failed, error code is ", JSON.stringify((err))); + expect(err.code).assertEqual(401) + } + done() + }) + + /* + * @tc.number: Acts_applyQuickFixRevoke_1400 + * @tc.name: Apply quick fix to support undo. + * @tc.desc: An exception parameter null is passed in to call revokeQuickFix, + * and there is an exception return value. + */ + it('Acts_applyQuickFixRevoke_1400',0, function (done) { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'it begin'); + try { + quickFixManager.revokeQuickFix(null).then(() => { + console.info("====>Acts_applyQuickFixRevoke_1400 revokeQuickFix " +" ok"); + }).catch((err) => { + console.info("====>Acts_applyQuickFixRevoke_1400 revokeQuickFix " +" failed, error code is ", JSON.stringify((err))); + }) + } catch (err){ + console.info("====>Acts_applyQuickFixRevoke_1400 try revokeQuickFix " +" failed, error code is ", JSON.stringify((err))); + expect(err.code).assertEqual(401) + } + done() + }) + + /* + * @tc.number: Acts_applyQuickFixRevoke_1500 + * @tc.name: Apply quick fix to support undo. + * @tc.desc: Non-system application calls revokeQuickFix, with abnormal return value. + */ + it('Acts_applyQuickFixRevoke_1500',0, function (done) { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'it begin'); + try { + quickFixManager.revokeQuickFix("com.ohos.quickfixno").then(() => { + console.info("====>Acts_applyQuickFixRevoke_1500 revokeQuickFix " +" ok"); + }).catch((err) => { + console.info("====>Acts_applyQuickFixRevoke_1500 revokeQuickFix " +" failed, error code is ", JSON.stringify((err))); + }) + } catch (err) { + console.info("====>Acts_applyQuickFixRevoke_1500 try revokeQuickFix " +" failed, error code is ", JSON.stringify((err))); + expect(err.code).assertEqual(202) + } + done() + }) + + /* + * @tc.number: Acts_applyQuickFixRevoke_1600 + * @tc.name: Apply quick fix to support undo. + * @tc.desc: The passed-in exception parameter undefined calls revokeQuickFix, + * and there is an exception return value. + */ + it('Acts_applyQuickFixRevoke_1600',0, function (done) { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'it begin'); + try { + quickFixManager.revokeQuickFix(undefined, (err) => { + console.info("====>Acts_applyQuickFixRevoke_1600 revokeQuickFix " + err.code); + }) + } catch (err) { + console.info("====>Acts_applyQuickFixRevoke_1600 try revokeQuickFix " + err.code); + expect(err.code).assertEqual(401) + } + done() + }) + + /* + * @tc.number: Acts_applyQuickFixRevoke_1700 + * @tc.name: Apply quick fix to support undo. + * @tc.desc: An exception parameter null is passed in to call revokeQuickFix, + * and there is an exception return value. + */ + it('Acts_applyQuickFixRevoke_1700',0, function (done) { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'it begin'); + try { + quickFixManager.revokeQuickFix(null, (err) => { + console.info("====>Acts_applyQuickFixRevoke_1700 revokeQuickFix " + err.code); + }) + } catch (err) { + console.info("====>Acts_applyQuickFixRevoke_1700 try revokeQuickFix " + err.code); + expect(err.code).assertEqual(401) + } + done() + }) + + /* + * @tc.number: Acts_applyQuickFixRevoke_1800 + * @tc.name: Apply quick fix to support undo. + * @tc.desc: Non-system application calls revokeQuickFix, with abnormal return value. + */ + it('Acts_applyQuickFixRevoke_1800',0, function (done) { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'it begin'); + try { + quickFixManager.revokeQuickFix("com.ohos.quickfixno", (err) => { + console.info("====>Acts_applyQuickFixRevoke_1600 revokeQuickFix " + err.code); + }) + } catch (err) { + console.info("====>Acts_applyQuickFixRevoke_1600 try revokeQuickFix " + err.code); + expect(err.code).assertEqual(202) + } + done() + }) + }) +} \ No newline at end of file diff --git a/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/ets/test/List.test.ets b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/ets/test/List.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..cb2e22661cde4c6c3e986a6718061d089e25fcd5 --- /dev/null +++ b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/ets/test/List.test.ets @@ -0,0 +1,19 @@ +/* + * 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 abilityTest from './Ability.test' + +export default function testsuite() { + abilityTest() +} \ No newline at end of file diff --git a/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/ets/testability/TestAbility.ets b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/ets/testability/TestAbility.ets new file mode 100644 index 0000000000000000000000000000000000000000..3481c0ac6fc316f0ea75f55806e9ea1f4299b358 --- /dev/null +++ b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/ets/testability/TestAbility.ets @@ -0,0 +1,71 @@ +/* + * 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 hilog from '@ohos.hilog'; +import Ability from '@ohos.app.ability.UIAbility' +import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry' +import { Hypium } from '@ohos/hypium' +import testsuite from '../test/List.test' +import Window from '@ohos.window' + +export default class TestAbility extends Ability { + onCreate(want, launchParam) { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onCreate'); + hilog.info(0x0000, 'testTag', '%{public}s', 'want param:' + JSON.stringify(want) ?? ''); + hilog.info(0x0000, 'testTag', '%{public}s', 'launchParam:'+ JSON.stringify(launchParam) ?? ''); + var abilityDelegator: any + abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator() + var abilityDelegatorArguments: any + abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments() + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'start run testcase!!!'); + Hypium.hypiumTest(abilityDelegator, abilityDelegatorArguments, testsuite) + } + + onDestroy() { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onDestroy'); + } + + onWindowStageCreate(windowStage: Window.WindowStage) { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onWindowStageCreate'); + windowStage.loadContent('testability/pages/Index', (err, data) => { + if (err.code) { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.ERROR); + hilog.error(0x0000, 'testTag', 'Failed to load the content. Cause: %{public}s', JSON.stringify(err) ?? ''); + return; + } + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', 'Succeeded in loading the content. Data: %{public}s', + JSON.stringify(data) ?? ''); + }); + } + + onWindowStageDestroy() { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onWindowStageDestroy'); + } + + onForeground() { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onForeground'); + } + + onBackground() { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onBackground'); + } +} \ No newline at end of file diff --git a/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/ets/testability/pages/Index.ets b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/ets/testability/pages/Index.ets new file mode 100644 index 0000000000000000000000000000000000000000..431674fc5573a62cfd4d76547115834080634060 --- /dev/null +++ b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/ets/testability/pages/Index.ets @@ -0,0 +1,49 @@ +/* + * 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 hilog from '@ohos.hilog'; + +@Entry +@Component +struct Index { + aboutToAppear() { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', '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/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/module.json b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/module.json new file mode 100644 index 0000000000000000000000000000000000000000..99584e296520bad74fd46235dc22e671077a3e01 --- /dev/null +++ b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/module.json @@ -0,0 +1,37 @@ +{ + "module": { + "name": "entry_test", + "type": "feature", + "description": "$string:module_test_desc", + "mainElement": "TestAbility", + "deviceTypes": [ + "default", + "tablet" + ], + "deliveryWithInstall": true, + "installationFree": false, + "pages": "$profile:test_pages", + "abilities": [ + { + "name": "TestAbility", + "srcEntrance": "./ets/testability/TestAbility.ets", + "description": "$string:TestAbility_desc", + "icon": "$media:icon", + "label": "$string:TestAbility_label", + "visible": true, + "startWindowIcon": "$media:icon", + "startWindowBackground": "$color:start_window_background", + "skills": [ + { + "actions": [ + "action.system.home" + ], + "entities": [ + "entity.system.home" + ] + } + ] + } + ] + } +} diff --git a/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/resources/base/element/color.json b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/resources/base/element/color.json new file mode 100644 index 0000000000000000000000000000000000000000..3c712962da3c2751c2b9ddb53559afcbd2b54a02 --- /dev/null +++ b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/resources/base/element/color.json @@ -0,0 +1,8 @@ +{ + "color": [ + { + "name": "start_window_background", + "value": "#FFFFFF" + } + ] +} \ No newline at end of file diff --git a/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/resources/base/element/string.json b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/resources/base/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..65d8fa5a7cf54aa3943dcd0214f58d1771bc1f6c --- /dev/null +++ b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/resources/base/element/string.json @@ -0,0 +1,16 @@ +{ + "string": [ + { + "name": "module_test_desc", + "value": "test ability description" + }, + { + "name": "TestAbility_desc", + "value": "the test ability" + }, + { + "name": "TestAbility_label", + "value": "test label" + } + ] +} \ No newline at end of file diff --git a/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/resources/base/media/icon.png b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/resources/base/media/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..ce307a8827bd75456441ceb57d530e4c8d45d36c Binary files /dev/null and b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/resources/base/media/icon.png differ diff --git a/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/resources/base/profile/test_pages.json b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/resources/base/profile/test_pages.json new file mode 100644 index 0000000000000000000000000000000000000000..b7e7343cacb32ce982a45e76daad86e435e054fe --- /dev/null +++ b/ability/ability_runtime/actsrevokequickfixtest/entry/src/main/resources/base/profile/test_pages.json @@ -0,0 +1,5 @@ +{ + "src": [ + "testability/pages/Index" + ] +} diff --git a/ability/ability_runtime/actsrevokequickfixtest/signature/openharmony_sx.p7b b/ability/ability_runtime/actsrevokequickfixtest/signature/openharmony_sx.p7b new file mode 100644 index 0000000000000000000000000000000000000000..e6b36b667f779a1bbcc989384f480139ffbba979 Binary files /dev/null and b/ability/ability_runtime/actsrevokequickfixtest/signature/openharmony_sx.p7b differ