diff --git a/account/appaccount/BUILD.gn b/account/appaccount/BUILD.gn index e7a6ccf9e6955d67b45489c0672679ee734a5271..b6ed289e5c91063c75f277fe232e4f4b4ffb15d1 100644 --- a/account/appaccount/BUILD.gn +++ b/account/appaccount/BUILD.gn @@ -1,4 +1,4 @@ -# Copyright (c) 2021 Huawei Device Co., Ltd. +# Copyright (c) 2021-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 @@ -20,6 +20,7 @@ group("appaccount_hap") { "actsaccountoperatetest:ActsAccountOperateTest", "actsaccounttest:ActsAccountTest", "actsaccounttstest:ActsAccountTsTest", + "actsappaccountplugintest:ActsAppAccountPluginTest", "actsgetaccountsbyowner:ActsGetAccountsByOwnerTest", "actsgetallaccounts:ActsGetAllAccountsTest", "actssetcheckdatasyncenable:ActsSetCheckDataSyncEnableTest", diff --git a/account/appaccount/actsappaccountplugintest/AppScope/app.json b/account/appaccount/actsappaccountplugintest/AppScope/app.json new file mode 100644 index 0000000000000000000000000000000000000000..7b036316e68acc0208587b135cae28ba08724ea1 --- /dev/null +++ b/account/appaccount/actsappaccountplugintest/AppScope/app.json @@ -0,0 +1,21 @@ +{ + "app": { + "bundleName": "com.example.accountplugintest", + "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": 10, + "targetAPIVersion": 10, + "car": { + "apiCompatibleVersion": 10, + "singleUser": false + } + } +} \ No newline at end of file diff --git a/account/appaccount/actsappaccountplugintest/AppScope/resources/base/element/string.json b/account/appaccount/actsappaccountplugintest/AppScope/resources/base/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..ee69f9a861d9dc269ed6638735d52674583498e1 --- /dev/null +++ b/account/appaccount/actsappaccountplugintest/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/account/appaccount/actsappaccountplugintest/AppScope/resources/base/media/app_icon.png b/account/appaccount/actsappaccountplugintest/AppScope/resources/base/media/app_icon.png new file mode 100644 index 0000000000000000000000000000000000000000..ce307a8827bd75456441ceb57d530e4c8d45d36c Binary files /dev/null and b/account/appaccount/actsappaccountplugintest/AppScope/resources/base/media/app_icon.png differ diff --git a/account/appaccount/actsappaccountplugintest/BUILD.gn b/account/appaccount/actsappaccountplugintest/BUILD.gn new file mode 100644 index 0000000000000000000000000000000000000000..427ee0b10427304ca6efa7c403b9cd3179d1ae03 --- /dev/null +++ b/account/appaccount/actsappaccountplugintest/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("ActsAppAccountPluginTest") { + hap_profile = "entry/src/main/module.json" + js_build_mode = "debug" + deps = [ + ":ActsAppAccountPluginTest_js_assets", + ":ActsAppAccountPluginTest_resources", + ] + ets2abc = true + certificate_profile = "signature/openharmony_sx.p7b" + hap_name = "ActsAppAccountPluginTest" + subsystem_name = "account" + part_name = "os_account" +} + +ohos_app_scope("ActsAppAccountPluginTest_app_profile") { + app_profile = "AppScope/app.json" + sources = [ "AppScope/resources" ] +} + +ohos_js_assets("ActsAppAccountPluginTest_js_assets") { + source_dir = "entry/src/main/ets" +} + +ohos_resources("ActsAppAccountPluginTest_resources") { + sources = [ "entry/src/main/resources" ] + deps = [ ":ActsAppAccountPluginTest_app_profile" ] + hap_profile = "entry/src/main/module.json" +} diff --git a/account/appaccount/actsappaccountplugintest/Test.json b/account/appaccount/actsappaccountplugintest/Test.json new file mode 100644 index 0000000000000000000000000000000000000000..60be1ec6231be2bbb56f96f1a112d7081546fde1 --- /dev/null +++ b/account/appaccount/actsappaccountplugintest/Test.json @@ -0,0 +1,26 @@ +{ + "description": "Configuration for hjunit demo Tests", + "driver": { + "type": "OHJSUnitTest", + "test-timeout": "360000", + "bundle-name": "com.example.accountplugintest", + "module-name": "phone", + "shell-timeout": "360000", + "testcase-timeout": 150000 + }, + "kits": [ + { + "test-file-name": [ + "ActsAppAccountPluginTest.hap" + ], + "type": "AppInstallKit", + "cleanup-apps": true + }, + { + "type": "ShellKit", + "teardown-command":[ + "bm uninstall -n com.example.accountplugintest" + ] + } + ] +} \ No newline at end of file diff --git a/account/appaccount/actsappaccountplugintest/entry/src/main/ets/Application/AbilityStage.ts b/account/appaccount/actsappaccountplugintest/entry/src/main/ets/Application/AbilityStage.ts new file mode 100644 index 0000000000000000000000000000000000000000..b0e0206ea9fb5ce94ef140d69510b6280969dd8e --- /dev/null +++ b/account/appaccount/actsappaccountplugintest/entry/src/main/ets/Application/AbilityStage.ts @@ -0,0 +1,9 @@ +import AbilityStage from "@ohos.app.ability.AbilityStage" + +export default class MyAbilityStage extends AbilityStage { + onCreate() { + console.log("[Demo] MyAbilityStage onCreate") + globalThis.stageOnCreateRun = 1; + globalThis.stageContext = this.context; + } +} diff --git a/account/appaccount/actsappaccountplugintest/entry/src/main/ets/MainAbility/MainAbility.ts b/account/appaccount/actsappaccountplugintest/entry/src/main/ets/MainAbility/MainAbility.ts new file mode 100644 index 0000000000000000000000000000000000000000..4d66065e88c907379883364a43ec02989cfd626b --- /dev/null +++ b/account/appaccount/actsappaccountplugintest/entry/src/main/ets/MainAbility/MainAbility.ts @@ -0,0 +1,37 @@ +import Ability from '@ohos.app.ability.UIAbility' + +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 windowStage="+ windowStage) + globalThis.windowStage = windowStage + 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/account/appaccount/actsappaccountplugintest/entry/src/main/ets/MainAbility/pages/index/index.ets b/account/appaccount/actsappaccountplugintest/entry/src/main/ets/MainAbility/pages/index/index.ets new file mode 100644 index 0000000000000000000000000000000000000000..711196ed231e4aac18cef28a864ad98fb887f027 --- /dev/null +++ b/account/appaccount/actsappaccountplugintest/entry/src/main/ets/MainAbility/pages/index/index.ets @@ -0,0 +1,56 @@ +/* + * Copyright (c) 2021-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 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/account/appaccount/actsappaccountplugintest/entry/src/main/ets/TestAbility/TestAbility.ts b/account/appaccount/actsappaccountplugintest/entry/src/main/ets/TestAbility/TestAbility.ts new file mode 100644 index 0000000000000000000000000000000000000000..8028a70f8af44690b95a08bd177bca6b09f24687 --- /dev/null +++ b/account/appaccount/actsappaccountplugintest/entry/src/main/ets/TestAbility/TestAbility.ts @@ -0,0 +1,50 @@ +/* + * Copyright (c) 2022 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +import Ability from '@ohos.app.ability.UIAbility' + +export default class TestAbility extends Ability { + onCreate(want, launchParam) { + console.log('TestAbility onCreate') + } + + onDestroy() { + console.log('TestAbility onDestroy') + } + + onWindowStageCreate(windowStage) { + console.log('TestAbility onWindowStageCreate') + windowStage.loadContent("TestAbility/pages/index", (err, data) => { + if (err.code) { + console.error('Failed to load the content. Cause:' + JSON.stringify(err)); + return; + } + console.info('Succeeded in loading the content. Data: ' + JSON.stringify(data)) + }); + + globalThis.abilityContext = this.context; + } + + onWindowStageDestroy() { + console.log('TestAbility onWindowStageDestroy') + } + + onForeground() { + console.log('TestAbility onForeground') + } + + onBackground() { + console.log('TestAbility onBackground') + } +}; \ No newline at end of file diff --git a/account/appaccount/actsappaccountplugintest/entry/src/main/ets/TestAbility/pages/index.ets b/account/appaccount/actsappaccountplugintest/entry/src/main/ets/TestAbility/pages/index.ets new file mode 100644 index 0000000000000000000000000000000000000000..e661f98bb674202d218c991529cb678ca6069ca4 --- /dev/null +++ b/account/appaccount/actsappaccountplugintest/entry/src/main/ets/TestAbility/pages/index.ets @@ -0,0 +1,48 @@ +/* + * Copyright (c) 2022-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 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/account/appaccount/actsappaccountplugintest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts b/account/appaccount/actsappaccountplugintest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts new file mode 100644 index 0000000000000000000000000000000000000000..c8946214fba8ce78113066d471da633872ac204e --- /dev/null +++ b/account/appaccount/actsappaccountplugintest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts @@ -0,0 +1,78 @@ +/* + * Copyright (c) 2022-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 TestRunner from '@ohos.application.testRunner' +import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry' + +var abilityDelegator = undefined +var abilityDelegatorArguments = undefined + +function translateParamsToString(parameters) { + const keySet = new Set([ + '-s class', '-s notClass', '-s suite', '-s it', + '-s level', '-s testType', '-s size', '-s timeout', + '-s dryRun' + ]) + let targetParams = ''; + for (const key in parameters) { + if (keySet.has(key)) { + targetParams = `${targetParams} ${key} ${parameters[key]}` + } + } + return targetParams.trim() +} + +async function onAbilityCreateCallback() { + console.log("onAbilityCreateCallback"); +} + +async function addAbilityMonitorCallback(err: any) { + console.info("addAbilityMonitorCallback : " + JSON.stringify(err)) +} + +export default class OpenHarmonyTestRunner implements TestRunner { + constructor() { + } + + onPrepare() { + console.info("OpenHarmonyTestRunner OnPrepare ") + } + + async onRun() { + console.log('OpenHarmonyTestRunner onRun run') + abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments() + abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator() + var testAbilityName = abilityDelegatorArguments.bundleName + '.MainAbility' + let lMonitor = { + abilityName: testAbilityName, + onAbilityCreate: onAbilityCreateCallback, + }; + abilityDelegator.addAbilityMonitor(lMonitor, addAbilityMonitorCallback) + var cmd = 'aa start -d 0 -a com.example.accountplugintest.MainAbility' + ' -b ' + abilityDelegatorArguments.bundleName + cmd += ' '+translateParamsToString(abilityDelegatorArguments.parameters) + var debug = abilityDelegatorArguments.parameters["-D"] + if (debug == 'true') + { + cmd += ' -D' + } + console.info('cmd : '+cmd) + abilityDelegator.executeShellCommand(cmd, + (err: any, d: any) => { + console.info('executeShellCommand : err : ' + JSON.stringify(err)); + console.info('executeShellCommand : data : ' + d.stdResult); + console.info('executeShellCommand : data : ' + d.exitCode); + }) + console.info('OpenHarmonyTestRunner onRun end') + } +}; \ No newline at end of file diff --git a/account/appaccount/actsappaccountplugintest/entry/src/main/ets/test/List.test.ets b/account/appaccount/actsappaccountplugintest/entry/src/main/ets/test/List.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..5624c4b08cf3d670882b751cf7ea8dacd099e3db --- /dev/null +++ b/account/appaccount/actsappaccountplugintest/entry/src/main/ets/test/List.test.ets @@ -0,0 +1,19 @@ +/* + * Copyright (c) 2021-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 ActsAALoginPlugin from './actsAALoginPluginTest.test' + +export default function testsuite() { + ActsAALoginPlugin() +} diff --git a/account/appaccount/actsappaccountplugintest/entry/src/main/ets/test/actsAALoginPluginTest.test.ets b/account/appaccount/actsappaccountplugintest/entry/src/main/ets/test/actsAALoginPluginTest.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..5dbe9c91ee4f974747fe20bd261b0c276be9402e --- /dev/null +++ b/account/appaccount/actsappaccountplugintest/entry/src/main/ets/test/actsAALoginPluginTest.test.ets @@ -0,0 +1,456 @@ +/* + * 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 appAccount from '@ohos.account.appAccount'; +import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from '@ohos/hypium' + +export default function ActsAALoginPlugin() { + describe('ActsAALoginPlugin', function () { + + async function sleep(delay) { + let timeoutId = null; + var promise = new Promise((resolve, reject) => { + timeoutId = setTimeout(() => resolve("done!"), delay); + }) + await promise + clearTimeout(timeoutId) + } + + class TestErrorAuthProvider extends appAccount.AuthorizationProvider { + constructor() { + super({ + bundleName: "", abilityName: "" + }) + } + } + + class TestAuthRequest extends appAccount.AccountCapabilityRequest { + readonly testKey: string + testKey1: string + constructor(provider) { + super(provider) + this.testKey = "test_testkey"; + } + } + + /* + * @tc.number : SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_0900 + * @tc.name : executeRequest callback test_0100 + * @tc.desc : err.code = 401 + */ + it('SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_0900', 0, async function (done) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_0900 start===="); + try { + let request = null; + let scheduler = new appAccount.AccountCapabilityScheduler(); + scheduler.executeRequest(request, (err, data) => { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_0900 err===="); + expect().assertFail(); + done(); + }); + } catch (err) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_0900 exception: " + JSON.stringify(err)); + expect(err.code).assertEqual(401); + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_0900 end===="); + await sleep(200) + done() + } + }); + + /* + * @tc.number : SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1000 + * @tc.name : executeRequest promise test_0100 + * @tc.desc : err.code = 401 + */ + it('SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1000', 0, async function (done) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1000 start===="); + try { + let request = null; + let scheduler = new appAccount.AccountCapabilityScheduler(); + scheduler.executeRequest(request).then(async (data) => { + expect().assertFail(); + await sleep(200) + done(); + }).catch(async (err) => { + expect().assertFail(); + await sleep(200) + done(); + }); + } catch (err) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1000 exception: " + JSON.stringify(err)); + expect(err.code).assertEqual(401); + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1000 end===="); + await sleep(200) + done() + } + }); + + /* + * @tc.number : SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1100 + * @tc.name : executeRequest callback test_0200 + * @tc.desc : err.code = 401 + */ + it('SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1100', 0, async function (done) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1100 start===="); + try { + let request = undefined; + let scheduler = new appAccount.AccountCapabilityScheduler(); + scheduler.executeRequest(request, async (err, data) => { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1100 err===="); + expect().assertFail(); + await sleep(200) + done(); + }); + } catch (err) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1100 exception: " + JSON.stringify(err)); + expect(err.code).assertEqual(401); + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1100 end===="); + await sleep(200) + done() + } + }); + + /* + * @tc.number : SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1200 + * @tc.name : executeRequest promise test_0200 + * @tc.desc : err.code = 401 + */ + it('SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1200', 0, async function (done) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1200 start===="); + try { + let request = undefined; + let scheduler = new appAccount.AccountCapabilityScheduler(); + await scheduler.executeRequest(request).then(async (data) => { + expect().assertFail(); + await sleep(200) + done(); + }).catch(async (err) => { + expect().assertFail(); + await sleep(200) + done(); + }); + } catch (err) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1200 exception: " + JSON.stringify(err)); + expect(err.code).assertEqual(401); + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1200 end===="); + await sleep(200) + done() + } + }) + + /* + * @tc.number : SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1300 + * @tc.name : executeRequest callback test_0300 + * @tc.desc : err.code = 401 + */ + it('SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1300', 0, async function (done) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1300 start===="); + try { + let testProvider = new appAccount.AccountCapabilityProvider(1) + let request = new appAccount.AccountCapabilityRequest(testProvider); + let scheduler = new appAccount.AccountCapabilityScheduler(); + scheduler.executeRequest(request, async (err, data) => { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1300 err===="); + expect().assertFail(); + await sleep(200) + done(); + }); + } catch (err) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1300 exception: " + JSON.stringify(err)); + expect(err.code).assertEqual(401); + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1300 end===="); + await sleep(200) + done() + } + }); + + /* + * @tc.number : SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1400 + * @tc.name : executeRequest promise test_0300 + * @tc.desc : err.code = 401 + */ + it('SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1400', 0, async function (done) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1400 start===="); + try { + let testProvider = new appAccount.AccountCapabilityProvider(1) + let request = new appAccount.AccountCapabilityRequest(testProvider); + let scheduler = new appAccount.AccountCapabilityScheduler(); + await scheduler.executeRequest(request).then(async (data) => { + expect().assertFail(); + await sleep(200) + done(); + }).catch(async (err) => { + expect().assertFail(); + await sleep(200) + done(); + }); + } catch (err) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1400 exception: " + JSON.stringify(err)); + expect(err.code).assertEqual(401); + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1400 end===="); + await sleep(200) + done() + } + }) + + /* + * @tc.number : SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1500 + * @tc.name : executeRequest callback test_0400 + * @tc.desc : err.code = 401 + */ + it('SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1500', 0, async function (done) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1500 start===="); + try { + let testProvider = new appAccount.AccountCapabilityProvider(1) + let request = new TestAuthRequest(testProvider) + let scheduler = new appAccount.AccountCapabilityScheduler(); + scheduler.executeRequest(request, async (err, data) => { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1500 err===="); + expect().assertFail(); + done(); + }); + } catch (err) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1500 exception: " + JSON.stringify(err)); + expect(err.code).assertEqual(401); + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1500 end===="); + await sleep(200) + done() + } + }); + + /* + * @tc.number : SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1600 + * @tc.name : executeRequest promise test_0400 + * @tc.desc : err.code = 401 + */ + it('SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1600', 0, async function (done) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1600 start===="); + try { + let testProvider = new appAccount.AccountCapabilityProvider(1) + let request = new TestAuthRequest(testProvider) + let scheduler = new appAccount.AccountCapabilityScheduler(); + await scheduler.executeRequest(request).then(async (data) => { + expect().assertFail(); + done(); + }).catch(async (err) => { + expect().assertFail(); + await sleep(200) + done(); + }); + } catch (err) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1600 exception: " + JSON.stringify(err)); + expect(err.code).assertEqual(401); + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1600 end===="); + await sleep(200) + done() + } + }) + + /* + * @tc.number : SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1700 + * @tc.name : executeRequest callback test_0100 + * @tc.desc : err = 12300002, 2 provider 1 request + */ + it('SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1700', 0, async function (done) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1500 start===="); + try { + let testProvider = new appAccount.AuthorizationProvider({ + bundleName: "com", abilityName: "Auth" + }) + let request = new appAccount.AccountCapabilityRequest(testProvider) + let scheduler = new appAccount.AccountCapabilityScheduler(); + scheduler.executeRequest(request, async (err, data) => { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1700 err: " + JSON.stringify(err)); + expect(err).assertEqual(12300002); + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1700 end===="); + await sleep(200) + done(); + }); + } catch (err) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1700 err===="); + expect().assertFail(); + done() + } + }); + + /* + * @tc.number : SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1600 + * @tc.name : executeRequest promise test_0100 + * @tc.desc : err = 12300002, 2 provider 1 request + */ + it('SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1800', 0, async function (done) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1800 start===="); + try { + let testProvider = new appAccount.AuthorizationProvider({ + bundleName: "com", abilityName: "Auth" + }) + let request = new appAccount.AccountCapabilityRequest(testProvider) + let scheduler = new appAccount.AccountCapabilityScheduler(); + await scheduler.executeRequest(request).then(async (data) => { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1800 run err===="); + expect().assertFail(); + done(); + }).catch(async (err) => { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1800 err: " + JSON.stringify(err)); + expect(err).assertEqual(12300002); + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1800 end===="); + await sleep(200) + done(); + }); + } catch (err) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1800 exception: " + JSON.stringify(err)); + expect().assertFail(); + await sleep(200) + done() + } + }) + + /* + * @tc.number : SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1900 + * @tc.name : executeRequest callback test_0200 + * @tc.desc : err = 12300002, errData 2 provider 2 request + */ + it('SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1900', 0, async function (done) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1900 start===="); + try { + let testProvider = new appAccount.AuthorizationProvider({ + bundleName: "com", abilityName: "Auth" + }) + let request = new TestAuthRequest(testProvider) + let scheduler = new appAccount.AccountCapabilityScheduler(); + scheduler.executeRequest(request, async (err, data) => { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1900 err: " + JSON.stringify(err)); + expect(err).assertEqual(12300002); + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1900 end===="); + await sleep(200) + done(); + }); + } catch (err) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1900 exception: " + JSON.stringify(err)); + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_1900 err===="); + expect().assertFail(); + await sleep(200) + done() + } + }); + + /* + * @tc.number : SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2000 + * @tc.name : executeRequest promise test_0200 + * @tc.desc : err = 12300002, errData 2 provider 2 request + */ + it('SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2000', 0, async function (done) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2000 start===="); + try { + let testProvider = new TestErrorAuthProvider() + let request = new TestAuthRequest(testProvider) + let scheduler = new appAccount.AccountCapabilityScheduler(); + await scheduler.executeRequest(request).then(async (data) => { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2000 run err===="); + expect().assertFail(); + done(); + }).catch(async (err) => { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2000 err: " + JSON.stringify(err)); + expect(err).assertEqual(12300002); + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2000 end===="); + await sleep(200) + done(); + }); + } catch (err) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2000 exception: " + JSON.stringify(err)); + expect().assertFail(); + await sleep(200) + done() + } + }) + + /* + * @tc.number : SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2100 + * @tc.name : executeRequest callback test_0300 + * @tc.desc : err = 12300002, errData 3 provider 2 request + */ + it('SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2100', 0, async function (done) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2100 start===="); + try { + let testProvider = new TestErrorAuthProvider() + let request = new TestAuthRequest(testProvider) + let scheduler = new appAccount.AccountCapabilityScheduler(); + scheduler.executeRequest(request, async (err, data) => { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2100 err: " + JSON.stringify(err)); + expect(err).assertEqual(12300002); + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2100 end===="); + await sleep(200) + done(); + }); + } catch (err) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2100 exception: " + JSON.stringify(err)); + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2100 err===="); + expect().assertFail(); + await sleep(200) + done() + } + }); + + /* + * @tc.number : SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2200 + * @tc.name : executeRequest promise test_0300 + * @tc.desc : err = 12300002, errData 3 provider 2 request + */ + it('SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2200', 0, async function (done) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2200 start===="); + try { + let testProvider = new TestErrorAuthProvider() + let request = new TestAuthRequest(testProvider) + let scheduler = new appAccount.AccountCapabilityScheduler(); + await scheduler.executeRequest(request).then(async (data) => { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2000 run err===="); + expect().assertFail(); + done(); + }).catch(async (err) => { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2200 err: " + JSON.stringify(err)); + expect(err).assertEqual(12300002); + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2200 end===="); + await sleep(200) + done(); + }); + } catch (err) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_ExecuteRequest_2200 exception: " + JSON.stringify(err)); + expect().assertFail(); + await sleep(200) + done() + } + }) + + /* + * @tc.number : SUB_ACCOUNT_APPACCOUNT_Enum_AccountCapabilityType_0100 + * @tc.name : AccountCapabilityType test_0100 + * @tc.desc : Enum + */ + it('SUB_ACCOUNT_APPACCOUNT_Enum_AccountCapabilityType_0100', 0, async function (done) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_Enum_AccountCapabilityType_0100 start===="); + try { + console.debug("====>Enum AccountCapabilityType.AUTHORIZATION : " + JSON.stringify(appAccount.AccountCapabilityType.AUTHORIZATION)); + expect(1).assertEqual(appAccount.AccountCapabilityType.AUTHORIZATION) + console.debug("====>SUB_ACCOUNT_APPACCOUNT_Enum_AccountCapabilityType_0100 end===="); + await sleep(200) + done(); + } catch (err) { + console.debug("====>SUB_ACCOUNT_APPACCOUNT_Enum_AccountCapabilityType_0100 exception: " + JSON.stringify(err)); + console.debug("====>SUB_ACCOUNT_APPACCOUNT_Enum_AccountCapabilityType_0100 err===="); + await sleep(200) + done() + } + }) + }) +} \ No newline at end of file diff --git a/account/appaccount/actsappaccountplugintest/entry/src/main/module.json b/account/appaccount/actsappaccountplugintest/entry/src/main/module.json new file mode 100644 index 0000000000000000000000000000000000000000..10d853c091df9215ac57f21c2e484e9a2a81ae54 --- /dev/null +++ b/account/appaccount/actsappaccountplugintest/entry/src/main/module.json @@ -0,0 +1,43 @@ +{ + "module": { + "name": "phone", + "type": "entry", + "srcEntrance": "./ets/Application/AbilityStage.ts", + "description": "$string:phone_entry_dsc", + "mainElement": "MainAbility", + "deviceTypes": [ + "tablet", + "default", + "phone" + ], + "deliveryWithInstall": true, + "installationFree": false, + "uiSyntax": "ets", + "pages": "$profile:main_pages", + "abilities": [{ + "name": "com.example.accountplugintest.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" + ] + }] + }], + "requestPermissions": [ + { + "name": "ohos.permission.MANAGE_LOCAL_ACCOUNTS" + }, + { + "name": "ohos.permission.ACCESS_USER_AUTH_INTERNAL" + } + ] + } +} \ No newline at end of file diff --git a/account/appaccount/actsappaccountplugintest/entry/src/main/resources/base/element/string.json b/account/appaccount/actsappaccountplugintest/entry/src/main/resources/base/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..3e59ab0f6c0352f93fabd189eedbcec8bcfed361 --- /dev/null +++ b/account/appaccount/actsappaccountplugintest/entry/src/main/resources/base/element/string.json @@ -0,0 +1,32 @@ +{ + "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": "AccountPluginTest" + }, + { + "name": "form_description", + "value": "my form" + }, + { + "name": "serviceability_description", + "value": "my whether" + }, + { + "name": "description_application", + "value": "demo for test" + }, + { + "name": "app_name", + "value": "Demo" + } + ] +} diff --git a/account/appaccount/actsappaccountplugintest/entry/src/main/resources/base/media/icon.png b/account/appaccount/actsappaccountplugintest/entry/src/main/resources/base/media/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..ce307a8827bd75456441ceb57d530e4c8d45d36c Binary files /dev/null and b/account/appaccount/actsappaccountplugintest/entry/src/main/resources/base/media/icon.png differ diff --git a/account/appaccount/actsappaccountplugintest/entry/src/main/resources/base/profile/main_pages.json b/account/appaccount/actsappaccountplugintest/entry/src/main/resources/base/profile/main_pages.json new file mode 100644 index 0000000000000000000000000000000000000000..ceb075cd80946aade673d707aac904fb8998bce9 --- /dev/null +++ b/account/appaccount/actsappaccountplugintest/entry/src/main/resources/base/profile/main_pages.json @@ -0,0 +1,5 @@ +{ + "src": [ + "MainAbility/pages/index/index" + ] +} \ No newline at end of file diff --git a/account/appaccount/actsappaccountplugintest/signature/openharmony_sx.p7b b/account/appaccount/actsappaccountplugintest/signature/openharmony_sx.p7b new file mode 100644 index 0000000000000000000000000000000000000000..0705f2384381d78b8c6db9d38d22be238f0d4ed0 Binary files /dev/null and b/account/appaccount/actsappaccountplugintest/signature/openharmony_sx.p7b differ