From e3cb6f9d12e5e565276c0e174d7b25e27d5c1d59 Mon Sep 17 00:00:00 2001 From: Mupceet Date: Wed, 24 Aug 2022 15:06:03 +0800 Subject: [PATCH] =?UTF-8?q?=E6=B7=BB=E5=8A=A0API=E5=B1=9E=E6=80=A7?= =?UTF-8?q?=E8=A6=86=E7=9B=96?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Mupceet --- barrierfree/BUILD.gn | 1 + barrierfree/accessibletest/BUILD.gn | 29 + .../actsabilitylisttest/AppScope/app.json | 19 + .../resources/base/element/string.json | 8 + .../resources/base/media/app_icon.png | Bin 0 -> 6790 bytes .../actsabilitylisttest/BUILD.gn | 43 + .../actsabilitylisttest/Test.json | 36 + .../src/main/ets/Application/AbilityStage.ts | 24 + .../src/main/ets/MainAbility/MainAbility.ts | 58 ++ .../src/main/ets/MainAbility/pages/index.ets | 121 +++ .../src/main/ets/TestAbility/TestAbility.ts | 45 ++ .../src/main/ets/TestAbility/pages/index.ets | 34 + .../ets/TestRunner/OpenHarmonyTestRunner.ts | 64 ++ .../entry/src/main/ets/test/Ability.test.ets | 625 +++++++++++++++ .../entry/src/main/ets/test/List.test.ets | 19 + .../entry/src/main/module.json | 47 ++ .../main/resources/base/element/string.json | 16 + .../src/main/resources/base/media/icon.png | Bin 0 -> 6790 bytes .../resources/base/profile/main_pages.json | 5 + .../signature/openharmony_sx.p7b | Bin 0 -> 3842 bytes .../AppScope/app.json | 20 + .../resources/base/element/string.json | 12 + .../resources/base/media/app_icon.png | Bin 0 -> 6790 bytes .../actscaptionconfigurationtest/BUILD.gn | 43 + .../actscaptionconfigurationtest/Test.json | 26 + .../src/main/ets/Application/AbilityStage.ts | 20 + .../src/main/ets/MainAbility/MainAbility.ts | 59 ++ .../src/main/ets/MainAbility/pages/index.ets | 661 ++++++++++++++++ .../ServiceExtAbility/ServiceExtAbility.ts | 61 ++ .../src/main/ets/TestAbility/TestAbility.ts | 45 ++ .../src/main/ets/TestAbility/pages/index.ets | 34 + .../ets/TestRunner/OpenHarmonyTestRunner.ts | 64 ++ .../ets/test/CaptionConfiguration.test.ets | 747 ++++++++++++++++++ .../entry/src/main/ets/test/List.test.ets | 19 + .../entry/src/main/module.json | 62 ++ .../main/resources/base/element/string.json | 20 + .../src/main/resources/base/media/icon.png | Bin 0 -> 6790 bytes .../base/profile/accessibility_config.json | 10 + .../resources/base/profile/main_pages.json | 5 + .../signature/openharmony_sx.p7b | Bin 0 -> 3842 bytes .../AppScope/app.json | 19 + .../resources/base/element/string.json | 8 + .../resources/base/media/app_icon.png | Bin 0 -> 6790 bytes .../accessibilityAudibleAbility/BUILD.gn | 43 + .../accessibilityAudibleAbility/Test.json | 3 + .../src/main/ets/Application/AbilityStage.ts | 22 + .../src/main/ets/MainAbility/MainAbility.ts | 49 ++ .../src/main/ets/MainAbility/pages/index.ets | 32 + .../ServiceExtAbility/ServiceExtAbility.ts | 37 + .../entry/src/main/module.json | 63 ++ .../main/resources/base/element/string.json | 24 + .../src/main/resources/base/media/icon.png | Bin 0 -> 6790 bytes .../base/profile/accessibility_config.json | 11 + .../resources/base/profile/form_config.json | 24 + .../resources/base/profile/main_pages.json | 5 + .../signature/openharmony_sx.p7b | Bin 0 -> 3842 bytes .../AppScope/app.json | 19 + .../resources/base/element/string.json | 8 + .../resources/base/media/app_icon.png | Bin 0 -> 6790 bytes .../accessibilityGenericAbility/BUILD.gn | 43 + .../accessibilityGenericAbility/Test.json | 3 + .../src/main/ets/Application/AbilityStage.ts | 22 + .../src/main/ets/MainAbility/MainAbility.ts | 49 ++ .../src/main/ets/MainAbility/pages/index.ets | 32 + .../ServiceExtAbility/ServiceExtAbility.ts | 37 + .../entry/src/main/module.json | 63 ++ .../main/resources/base/element/string.json | 24 + .../src/main/resources/base/media/icon.png | Bin 0 -> 6790 bytes .../base/profile/accessibility_config.json | 11 + .../resources/base/profile/form_config.json | 24 + .../resources/base/profile/main_pages.json | 5 + .../signature/openharmony_sx.p7b | Bin 0 -> 3842 bytes .../AppScope/app.json | 19 + .../resources/base/element/string.json | 8 + .../resources/base/media/app_icon.png | Bin 0 -> 6790 bytes .../accessibilityHapticAbility/BUILD.gn | 43 + .../accessibilityHapticAbility/Test.json | 3 + .../src/main/ets/Application/AbilityStage.ts | 22 + .../src/main/ets/MainAbility/MainAbility.ts | 49 ++ .../src/main/ets/MainAbility/pages/index.ets | 32 + .../ServiceExtAbility/ServiceExtAbility.ts | 38 + .../entry/src/main/module.json | 63 ++ .../main/resources/base/element/string.json | 24 + .../src/main/resources/base/media/icon.png | Bin 0 -> 6790 bytes .../base/profile/accessibility_config.json | 11 + .../resources/base/profile/form_config.json | 24 + .../resources/base/profile/main_pages.json | 5 + .../signature/openharmony_sx.p7b | Bin 0 -> 3842 bytes .../AppScope/app.json | 19 + .../resources/base/element/string.json | 8 + .../resources/base/media/app_icon.png | Bin 0 -> 6790 bytes .../accessibilitySpokenAbility/BUILD.gn | 43 + .../accessibilitySpokenAbility/Test.json | 3 + .../src/main/ets/Application/AbilityStage.ts | 22 + .../src/main/ets/MainAbility/MainAbility.ts | 49 ++ .../src/main/ets/MainAbility/pages/index.ets | 32 + .../ServiceExtAbility/ServiceExtAbility.ts | 37 + .../entry/src/main/module.json | 63 ++ .../main/resources/base/element/string.json | 24 + .../src/main/resources/base/media/icon.png | Bin 0 -> 6790 bytes .../base/profile/accessibility_config.json | 11 + .../resources/base/profile/form_config.json | 24 + .../resources/base/profile/main_pages.json | 5 + .../signature/openharmony_sx.p7b | Bin 0 -> 3842 bytes .../AppScope/app.json | 19 + .../resources/base/element/string.json | 8 + .../resources/base/media/app_icon.png | Bin 0 -> 6790 bytes .../accessibilityVisualAbility/BUILD.gn | 43 + .../accessibilityVisualAbility/Test.json | 3 + .../src/main/ets/Application/AbilityStage.ts | 22 + .../src/main/ets/MainAbility/MainAbility.ts | 49 ++ .../src/main/ets/MainAbility/pages/index.ets | 32 + .../ServiceExtAbility/ServiceExtAbility.ts | 37 + .../entry/src/main/module.json | 63 ++ .../main/resources/base/element/string.json | 24 + .../src/main/resources/base/media/icon.png | Bin 0 -> 6790 bytes .../base/profile/accessibility_config.json | 11 + .../resources/base/profile/form_config.json | 24 + .../resources/base/profile/main_pages.json | 5 + .../signature/openharmony_sx.p7b | Bin 0 -> 3842 bytes 120 files changed, 4803 insertions(+) create mode 100644 barrierfree/accessibletest/BUILD.gn create mode 100644 barrierfree/accessibletest/actsabilitylisttest/AppScope/app.json create mode 100644 barrierfree/accessibletest/actsabilitylisttest/AppScope/resources/base/element/string.json create mode 100644 barrierfree/accessibletest/actsabilitylisttest/AppScope/resources/base/media/app_icon.png create mode 100644 barrierfree/accessibletest/actsabilitylisttest/BUILD.gn create mode 100644 barrierfree/accessibletest/actsabilitylisttest/Test.json create mode 100644 barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/Application/AbilityStage.ts create mode 100644 barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/MainAbility/MainAbility.ts create mode 100644 barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/MainAbility/pages/index.ets create mode 100644 barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/TestAbility/TestAbility.ts create mode 100644 barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/TestAbility/pages/index.ets create mode 100644 barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts create mode 100644 barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/test/Ability.test.ets create mode 100644 barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/test/List.test.ets create mode 100644 barrierfree/accessibletest/actsabilitylisttest/entry/src/main/module.json create mode 100644 barrierfree/accessibletest/actsabilitylisttest/entry/src/main/resources/base/element/string.json create mode 100644 barrierfree/accessibletest/actsabilitylisttest/entry/src/main/resources/base/media/icon.png create mode 100644 barrierfree/accessibletest/actsabilitylisttest/entry/src/main/resources/base/profile/main_pages.json create mode 100644 barrierfree/accessibletest/actsabilitylisttest/signature/openharmony_sx.p7b create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/AppScope/app.json create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/AppScope/resources/base/element/string.json create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/AppScope/resources/base/media/app_icon.png create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/BUILD.gn create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/Test.json create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/Application/AbilityStage.ts create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/MainAbility/MainAbility.ts create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/MainAbility/pages/index.ets create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/ServiceExtAbility/ServiceExtAbility.ts create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/TestAbility/TestAbility.ts create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/TestAbility/pages/index.ets create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/test/CaptionConfiguration.test.ets create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/test/List.test.ets create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/module.json create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/resources/base/element/string.json create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/resources/base/media/icon.png create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/resources/base/profile/accessibility_config.json create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/resources/base/profile/main_pages.json create mode 100644 barrierfree/accessibletest/actscaptionconfigurationtest/signature/openharmony_sx.p7b create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityAudibleAbility/AppScope/app.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityAudibleAbility/AppScope/resources/base/element/string.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityAudibleAbility/AppScope/resources/base/media/app_icon.png create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityAudibleAbility/BUILD.gn create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityAudibleAbility/Test.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityAudibleAbility/entry/src/main/ets/Application/AbilityStage.ts create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityAudibleAbility/entry/src/main/ets/MainAbility/MainAbility.ts create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityAudibleAbility/entry/src/main/ets/MainAbility/pages/index.ets create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityAudibleAbility/entry/src/main/ets/ServiceExtAbility/ServiceExtAbility.ts create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityAudibleAbility/entry/src/main/module.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityAudibleAbility/entry/src/main/resources/base/element/string.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityAudibleAbility/entry/src/main/resources/base/media/icon.png create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityAudibleAbility/entry/src/main/resources/base/profile/accessibility_config.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityAudibleAbility/entry/src/main/resources/base/profile/form_config.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityAudibleAbility/entry/src/main/resources/base/profile/main_pages.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityAudibleAbility/signature/openharmony_sx.p7b create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityGenericAbility/AppScope/app.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityGenericAbility/AppScope/resources/base/element/string.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityGenericAbility/AppScope/resources/base/media/app_icon.png create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityGenericAbility/BUILD.gn create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityGenericAbility/Test.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityGenericAbility/entry/src/main/ets/Application/AbilityStage.ts create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityGenericAbility/entry/src/main/ets/MainAbility/MainAbility.ts create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityGenericAbility/entry/src/main/ets/MainAbility/pages/index.ets create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityGenericAbility/entry/src/main/ets/ServiceExtAbility/ServiceExtAbility.ts create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityGenericAbility/entry/src/main/module.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityGenericAbility/entry/src/main/resources/base/element/string.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityGenericAbility/entry/src/main/resources/base/media/icon.png create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityGenericAbility/entry/src/main/resources/base/profile/accessibility_config.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityGenericAbility/entry/src/main/resources/base/profile/form_config.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityGenericAbility/entry/src/main/resources/base/profile/main_pages.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityGenericAbility/signature/openharmony_sx.p7b create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityHapticAbility/AppScope/app.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityHapticAbility/AppScope/resources/base/element/string.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityHapticAbility/AppScope/resources/base/media/app_icon.png create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityHapticAbility/BUILD.gn create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityHapticAbility/Test.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityHapticAbility/entry/src/main/ets/Application/AbilityStage.ts create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityHapticAbility/entry/src/main/ets/MainAbility/MainAbility.ts create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityHapticAbility/entry/src/main/ets/MainAbility/pages/index.ets create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityHapticAbility/entry/src/main/ets/ServiceExtAbility/ServiceExtAbility.ts create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityHapticAbility/entry/src/main/module.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityHapticAbility/entry/src/main/resources/base/element/string.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityHapticAbility/entry/src/main/resources/base/media/icon.png create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityHapticAbility/entry/src/main/resources/base/profile/accessibility_config.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityHapticAbility/entry/src/main/resources/base/profile/form_config.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityHapticAbility/entry/src/main/resources/base/profile/main_pages.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityHapticAbility/signature/openharmony_sx.p7b create mode 100644 barrierfree/accessibletest/sceneProject/accessibilitySpokenAbility/AppScope/app.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilitySpokenAbility/AppScope/resources/base/element/string.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilitySpokenAbility/AppScope/resources/base/media/app_icon.png create mode 100644 barrierfree/accessibletest/sceneProject/accessibilitySpokenAbility/BUILD.gn create mode 100644 barrierfree/accessibletest/sceneProject/accessibilitySpokenAbility/Test.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilitySpokenAbility/entry/src/main/ets/Application/AbilityStage.ts create mode 100644 barrierfree/accessibletest/sceneProject/accessibilitySpokenAbility/entry/src/main/ets/MainAbility/MainAbility.ts create mode 100644 barrierfree/accessibletest/sceneProject/accessibilitySpokenAbility/entry/src/main/ets/MainAbility/pages/index.ets create mode 100644 barrierfree/accessibletest/sceneProject/accessibilitySpokenAbility/entry/src/main/ets/ServiceExtAbility/ServiceExtAbility.ts create mode 100644 barrierfree/accessibletest/sceneProject/accessibilitySpokenAbility/entry/src/main/module.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilitySpokenAbility/entry/src/main/resources/base/element/string.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilitySpokenAbility/entry/src/main/resources/base/media/icon.png create mode 100644 barrierfree/accessibletest/sceneProject/accessibilitySpokenAbility/entry/src/main/resources/base/profile/accessibility_config.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilitySpokenAbility/entry/src/main/resources/base/profile/form_config.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilitySpokenAbility/entry/src/main/resources/base/profile/main_pages.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilitySpokenAbility/signature/openharmony_sx.p7b create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityVisualAbility/AppScope/app.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityVisualAbility/AppScope/resources/base/element/string.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityVisualAbility/AppScope/resources/base/media/app_icon.png create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityVisualAbility/BUILD.gn create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityVisualAbility/Test.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityVisualAbility/entry/src/main/ets/Application/AbilityStage.ts create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityVisualAbility/entry/src/main/ets/MainAbility/MainAbility.ts create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityVisualAbility/entry/src/main/ets/MainAbility/pages/index.ets create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityVisualAbility/entry/src/main/ets/ServiceExtAbility/ServiceExtAbility.ts create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityVisualAbility/entry/src/main/module.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityVisualAbility/entry/src/main/resources/base/element/string.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityVisualAbility/entry/src/main/resources/base/media/icon.png create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityVisualAbility/entry/src/main/resources/base/profile/accessibility_config.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityVisualAbility/entry/src/main/resources/base/profile/form_config.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityVisualAbility/entry/src/main/resources/base/profile/main_pages.json create mode 100644 barrierfree/accessibletest/sceneProject/accessibilityVisualAbility/signature/openharmony_sx.p7b diff --git a/barrierfree/BUILD.gn b/barrierfree/BUILD.gn index 03013055d..b40a83952 100644 --- a/barrierfree/BUILD.gn +++ b/barrierfree/BUILD.gn @@ -28,6 +28,7 @@ group("barrierfree") { "accessiblecheckability:ActsAccessibleCheckAbilityTest", "accessibleregisterstate:ActsAccessibleRegisterStateTest", "accessiblesendevent:ActsAccessibleSendEventTest", + "accessibletest:actsaccessibletest", "targetProject/aceTest:aceTest", ] } diff --git a/barrierfree/accessibletest/BUILD.gn b/barrierfree/accessibletest/BUILD.gn new file mode 100644 index 000000000..bacf236cb --- /dev/null +++ b/barrierfree/accessibletest/BUILD.gn @@ -0,0 +1,29 @@ +# Copyright (C) 2021 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("//build/ohos_var.gni") + +group("actsaccessibletest") { + testonly = true + if (is_standard_system) { + deps = [ + "actsabilitylisttest:ActsAbilityListTest", + "actscaptionconfigurationtest:ActsCaptionConfigurationTest", + "sceneProject/accessibilityAudibleAbility:accessibilityAudibleAbility", + "sceneProject/accessibilityGenericAbility:accessibilityGenericAbility", + "sceneProject/accessibilityHapticAbility:accessibilityHapticAbility", + "sceneProject/accessibilitySpokenAbility:accessibilitySpokenAbility", + "sceneProject/accessibilityVisualAbility:accessibilityVisualAbility", + ] + } +} diff --git a/barrierfree/accessibletest/actsabilitylisttest/AppScope/app.json b/barrierfree/accessibletest/actsabilitylisttest/AppScope/app.json new file mode 100644 index 000000000..e7e8606d8 --- /dev/null +++ b/barrierfree/accessibletest/actsabilitylisttest/AppScope/app.json @@ -0,0 +1,19 @@ +{ + "app": { + "bundleName": "com.example.abilitylisttest", + "vendor": "example", + "versionCode": 1000000, + "versionName": "1.0.0", + "icon": "$media:app_icon", + "label": "$string:app_name", + "distributedNotificationEnabled": true, + "keepAlive": true, + "singleUser": true, + "minAPIVersion": 9, + "targetAPIVersion": 9, + "car": { + "apiCompatibleVersion": 9, + "singleUser": false + } + } +} diff --git a/barrierfree/accessibletest/actsabilitylisttest/AppScope/resources/base/element/string.json b/barrierfree/accessibletest/actsabilitylisttest/AppScope/resources/base/element/string.json new file mode 100644 index 000000000..b9d556beb --- /dev/null +++ b/barrierfree/accessibletest/actsabilitylisttest/AppScope/resources/base/element/string.json @@ -0,0 +1,8 @@ +{ + "string": [ + { + "name": "app_name", + "value": "AbilityListTest" + } + ] +} diff --git a/barrierfree/accessibletest/actsabilitylisttest/AppScope/resources/base/media/app_icon.png b/barrierfree/accessibletest/actsabilitylisttest/AppScope/resources/base/media/app_icon.png new file mode 100644 index 0000000000000000000000000000000000000000..ce307a8827bd75456441ceb57d530e4c8d45d36c GIT binary patch literal 6790 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 { + this.enableAbility(LOG_PREFIX, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + }) + Button('AbilityList_0170-0180关闭辅助应用') + .fontSize(25) + .fontWeight(FontWeight.Bold) + .margin(5) + .onClick((e) => { + this.disableAbility(LOG_PREFIX, [AUDIBLE_BUNDLE_NAME]) + }) + Button('AbilityList_0170(callback)查询辅助应用') + .fontSize(25) + .fontWeight(FontWeight.Bold) + .margin(5) + .onClick((e) => { + accessibility.getAbilityLists('all', 'enable', (err, data) => { + if (err.code != 0) { + console.error(LOG_PREFIX + 'failed to getAbilityLists because ' + JSON.stringify(err)) + return + } + console.error(LOG_PREFIX + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.error(LOG_PREFIX + 'data.length : ' + JSON.stringify(data.length)) + this.abilityListsCallBack = JSON.stringify(data) + }) + }) + Text(this.abilityListsCallBack) + .fontSize(25) + Button('AbilityList_0180(promise)查询辅助应用') + .fontSize(25) + .fontWeight(FontWeight.Bold) + .margin(5) + .onClick((e) => { + accessibility.getAbilityLists('all', 'enable').then((data) => { + console.error(LOG_PREFIX + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.error(LOG_PREFIX + 'data.length : ' + JSON.stringify(data.length)) + this.abilityListsPromise = JSON.stringify(data) + }).catch((err) => { + console.error(LOG_PREFIX + 'failed to getAbilityLists because ' + JSON.stringify(err)) + }) + }) + Text(this.abilityListsPromise) + .fontSize(25) + } + .width('100%') + } + .height('100%') + } + + enableAbility(logTag, bundleNameArr) { + for (let bundleName of bundleNameArr) { + config.enableAbility(bundleName, ['retrieve']).then((data) => { + console.error(logTag + 'enableAbility ' + bundleName + ' success. data: ' + JSON.stringify(data)) + prompt.showToast({ message: '启动应用成功'}) + }).catch((error) => { + console.error(logTag + 'enableAbility ' + bundleName + ' failed. Cause: ' + JSON.stringify(error)) + prompt.showToast({ message: '启动应用异常'}) + return + }) + } + } + + disableAbility(logTag, bundleNameArr) { + for (let bundleName of bundleNameArr) { + config.disableAbility(bundleName).then((data) => { + console.error(logTag + 'disableAbility ' + bundleName + ' success. data: ' + JSON.stringify(data)) + prompt.showToast({ message: '关闭应用成功'}) + }).catch((error) => { + console.error(logTag + 'disableAbility ' + bundleName + ' failed. Cause: ' + JSON.stringify(error)) + prompt.showToast({ message: '关闭应用异常'}) + return + }) + } + } +} diff --git a/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/TestAbility/TestAbility.ts b/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/TestAbility/TestAbility.ts new file mode 100644 index 000000000..301aaf609 --- /dev/null +++ b/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/TestAbility/TestAbility.ts @@ -0,0 +1,45 @@ +import Ability from '@ohos.application.Ability' +import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry' +import { Hypium } from '@ohos/hypium' +import testsuite from '../test/List.test' + +export default class TestAbility extends Ability { + onCreate(want, launchParam) { + console.log('TestAbility onCreate') + var abilityDelegator: any + abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator() + var abilityDelegatorArguments: any + abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments() + console.info('start run testcase!!!') + Hypium.hypiumTest(abilityDelegator, abilityDelegatorArguments, testsuite) + } + + 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/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/TestAbility/pages/index.ets b/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/TestAbility/pages/index.ets new file mode 100644 index 000000000..733600abc --- /dev/null +++ b/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/TestAbility/pages/index.ets @@ -0,0 +1,34 @@ +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/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts b/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts new file mode 100644 index 000000000..b7a05f076 --- /dev/null +++ b/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts @@ -0,0 +1,64 @@ +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.abilitylisttest.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/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/test/Ability.test.ets b/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/test/Ability.test.ets new file mode 100644 index 000000000..4f29b3064 --- /dev/null +++ b/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/test/Ability.test.ets @@ -0,0 +1,625 @@ +/* + * Copyright (c) 2022 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +import { describe, beforeAll, beforeEach, afterEach, afterAll, it, expect } from '@ohos/hypium' +import config from '@ohos.accessibility.config' +import accessibility from '@ohos.accessibility' +import prompt from '@ohos.prompt' + +const AUDIBLE_BUNDLE_NAME = 'com.example.accessibleaudibleability.hmservice/ServiceExtAbility' +const GENERIC_BUNDLE_NAME = 'com.example.accessiblegenericability.hmservice/ServiceExtAbility' +const HAPTIC_BUNDLE_NAME = 'com.example.accessiblehapticability.hmservice/ServiceExtAbility' +const SPOKEN_BUNDLE_NAME = 'com.example.accessiblespokenability.hmservice/ServiceExtAbility' +const VISUAL_BUNDLE_NAME = 'com.example.accessiblevisualability.hmservice/ServiceExtAbility' +const LOG_PREFIX = '[CQH-ABILITY-LIST-TEST]' +const TIME_OUT = 3000 +const TIME_OUT_S = 1000 + +export default function abilityTest() { + describe('ActsAbilityListTest', function () { + afterEach(async function (done) { + disableAll(LOG_PREFIX + ' disableAll ') + setTimeout(() => { + done() + }, TIME_OUT) + }) + afterAll(async function (done) { + prompt.showToast({ + message: 'CASE All End' + }) + disableAll(LOG_PREFIX + ' disableAll ') + done() + }) + /** + * @tc.number: AbilityList_0010 + * @tc.name: getAbilityLists callback API. + * @tc.desc: getAbilityLists callback API abilityType is spoken, stateType is install. + */ + it('AbilityList_0010', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0010 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('spoken', 'install', (err, data) => { + if (err.code != 0) { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + return + } + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.info(logTag + 'data.length : ' + JSON.stringify(data.length)) + expect(data.length).assertLarger(0) + done() + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0020 + * @tc.name: getAbilityLists promise API. + * @tc.desc: getAbilityLists promise API abilityType is spoken, stateType is install. + */ + it('AbilityList_0020', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0020 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('spoken', 'install').then((data) => { + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.info(logTag + 'data.length : ' + JSON.stringify(data.length)) + expect(data.length).assertLarger(0) + done() + }).catch((err) => { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0030 + * @tc.name: getAbilityLists callback API. + * @tc.desc: getAbilityLists callback API abilityType is audible, stateType is install. + */ + it('AbilityList_0030', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0030 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('audible', 'install', (err, data) => { + if (err.code != 0) { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + return + } + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.info(logTag + 'data.length : ' + JSON.stringify(data.length)) + expect(data.length).assertLarger(0) + done() + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0040 + * @tc.name: getAbilityLists promise API. + * @tc.desc: getAbilityLists promise API abilityType is audible, stateType is install. + */ + it('AbilityList_0040', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0040 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('audible', 'install').then((data) => { + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.info(logTag + 'data.length : ' + JSON.stringify(data.length)) + expect(data.length).assertLarger(0) + done() + }).catch((err) => { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0050 + * @tc.name: getAbilityLists callback API. + * @tc.desc: getAbilityLists callback API abilityType is visual, stateType is install. + */ + it('AbilityList_0050', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0050 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('visual', 'install', (err, data) => { + if (err.code != 0) { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + return + } + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.info(logTag + 'data.length : ' + JSON.stringify(data.length)) + expect(data.length).assertLarger(0) + done() + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0060 + * @tc.name: getAbilityLists promise API. + * @tc.desc: getAbilityLists promise API abilityType is visual, stateType is install. + */ + it('AbilityList_0060', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0060 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('visual', 'install').then((data) => { + console.info(LOG_PREFIX + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.info(logTag + 'data.length : ' + JSON.stringify(data.length)) + expect(data.length).assertLarger(0) + done() + }).catch((err) => { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0070 + * @tc.name: getAbilityLists callback API. + * @tc.desc: getAbilityLists callback API abilityType is haptic, stateType is install. + */ + it('AbilityList_0070', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0070 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('haptic', 'install', (err, data) => { + if (err.code != 0) { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + return + } + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.info(logTag + 'data.length : ' + JSON.stringify(data.length)) + expect(data.length).assertLarger(0) + done() + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0080 + * @tc.name: getAbilityLists promise API. + * @tc.desc: getAbilityLists promise API abilityType is haptic, stateType is install. + */ + it('AbilityList_0080', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0080 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('haptic', 'install').then((data) => { + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.info(logTag + 'data.length : ' + JSON.stringify(data.length)) + expect(data.length).assertLarger(0) + done() + }).catch((err) => { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0090 + * @tc.name: getAbilityLists callback API. + * @tc.desc: getAbilityLists callback API abilityType is generic, stateType is install. + */ + it('AbilityList_0090', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0090 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('generic', 'install', (err, data) => { + if (err.code != 0) { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + return + } + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.info(logTag + 'data.length : ' + JSON.stringify(data.length)) + expect(data.length).assertLarger(0) + done() + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0100 + * @tc.name: getAbilityLists promise API. + * @tc.desc: getAbilityLists promise API abilityType is generic, stateType is install. + */ + it('AbilityList_0100', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0100 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('generic', 'install').then((data) => { + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.info(logTag + 'data.length : ' + JSON.stringify(data.length)) + expect(data.length).assertLarger(0) + done() + }).catch((err) => { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0110 + * @tc.name: getAbilityLists callback API. + * @tc.desc: getAbilityLists callback API abilityType is all, stateType is enable. + */ + it('AbilityList_0110', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0110 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('all', 'enable', (err, data) => { + if (err.code != 0) { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + return + } + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.info(logTag + 'data.length : ' + JSON.stringify(data.length)) + expect(data.length).assertLarger(0) + done() + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0111 + * @tc.name: getAbilityLists callback API. + * @tc.desc: getAbilityLists callback API abilityType is all, stateType is enable, get eventTypes. + */ + it('AbilityList_0111', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0111 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('all', 'enable', (err, data) => { + if (err.code != 0) { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + return + } + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + let eventTypes = [] + if (data.length > 0) { + eventTypes = data[0].eventTypes + } + expect(eventTypes.length).assertLarger(0) + done() + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0112 + * @tc.name: getAbilityLists callback API. + * @tc.desc: getAbilityLists callback API abilityType is all, stateType is enable, get targetBundleNames. + */ + it('AbilityList_0112', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0112 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('all', 'enable', (err, data) => { + if (err.code != 0) { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + return + } + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + let targetBundleNames = [] + if (data.length > 0) { + targetBundleNames = data[0].targetBundleNames + } + expect(targetBundleNames.length).assertLarger(0) + done() + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0113 + * @tc.name: getAbilityLists callback API. + * @tc.desc: getAbilityLists callback API abilityType is all, stateType is enable, get other attribute. + */ + it('AbilityList_0113', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0113 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('all', 'enable', (err, data) => { + if (err.code != 0) { + console.error(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + return + } + console.error(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + let id = '' + let name = '' + let bundleName = '' + let abilityTypes = [] + let capabilities = [] + let description = '' + if (data.length > 0) { + id = data[0].id + name = data[0].name + bundleName = data[0].bundleName + abilityTypes = data[0].abilityTypes + capabilities = data[0].capabilities + description = data[0].description + } + expect(id.length).assertLarger(0) + expect(name.length).assertLarger(0) + expect(bundleName.length).assertLarger(0) + expect(abilityTypes.length).assertLarger(0) + expect(capabilities.length).assertLarger(0) + expect(description.length).assertLarger(0) + done() + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0120 + * @tc.name: getAbilityLists promise API. + * @tc.desc: getAbilityLists promise API abilityType is all, stateType is enable. + */ + it('AbilityList_0120', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0120 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('all', 'enable').then((data) => { + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.info(logTag + 'data.length : ' + JSON.stringify(data.length)) + expect(data.length).assertLarger(0) + done() + }).catch((err) => { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0121 + * @tc.name: getAbilityLists promise API. + * @tc.desc: getAbilityLists promise API abilityType is all, stateType is enable, get eventTypes. + */ + it('AbilityList_0121', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0121 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('all', 'enable').then((data) => { + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + let eventTypes = [] + if (data.length > 0) { + eventTypes = data[0].eventTypes + } + expect(eventTypes.length).assertLarger(0) + done() + }).catch((err) => { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0122 + * @tc.name: getAbilityLists promise API. + * @tc.desc: getAbilityLists promise API abilityType is all, stateType is enable, get targetBundleNames. + */ + it('AbilityList_0122', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0122 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('all', 'enable').then((data) => { + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + let targetBundleNames = [] + if (data.length > 0) { + targetBundleNames = data[0].targetBundleNames + } + expect(targetBundleNames.length).assertLarger(0) + done() + }).catch((err) => { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0123 + * @tc.name: getAbilityLists promise API. + * @tc.desc: getAbilityLists promise API abilityType is all, stateType is enable, get other attribute. + */ + it('AbilityList_0123', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0123 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('all', 'enable').then((data) => { + console.error(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + let id = '' + let name = '' + let bundleName = '' + let abilityTypes = [] + let capabilities = [] + let description = '' + if (data.length > 0) { + id = data[0].id + name = data[0].name + bundleName = data[0].bundleName + abilityTypes = data[0].abilityTypes + capabilities = data[0].capabilities + description = data[0].description + } + expect(id.length).assertLarger(0) + expect(name.length).assertLarger(0) + expect(bundleName.length).assertLarger(0) + expect(abilityTypes.length).assertLarger(0) + expect(capabilities.length).assertLarger(0) + expect(description.length).assertLarger(0) + done() + }).catch((err) => { + console.error(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0130 + * @tc.name: getAbilityLists callback API. + * @tc.desc: getAbilityLists callback API abilityType is all, stateType is disable. + */ + it('AbilityList_0130', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0130 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('all', 'disable', (err, data) => { + if (err.code != 0) { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + return + } + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.info(logTag + 'data.length : ' + JSON.stringify(data.length)) + expect(data.length).assertLarger(0) + done() + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0140 + * @tc.name: getAbilityLists promise API. + * @tc.desc: getAbilityLists promise API abilityType is all, stateType is disable. + */ + it('AbilityList_0140', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0140 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('all', 'disable').then((data) => { + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.info(logTag + 'data.length : ' + JSON.stringify(data.length)) + expect(data.length).assertLarger(0) + done() + }).catch((err) => { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0150 + * @tc.name: getAbilityLists callback API. + * @tc.desc: getAbilityLists callback API abilityType is all, stateType is enable. + */ + it('AbilityList_0150', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0150 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('all', 'disable', (err, data) => { + if (err.code != 0) { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + return + } + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.info(logTag + 'data.length : ' + JSON.stringify(data.length)) + expect(data.length).assertLarger(0) + done() + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + /** + * @tc.number: AbilityList_0160 + * @tc.name: getAbilityLists promise API. + * @tc.desc: getAbilityLists promise API abilityType is all, stateType is enable. + */ + it('AbilityList_0160', 1, async function (done) { + let logTag = LOG_PREFIX + ' AbilityList_0160 ' + enableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME]) + setTimeout(() => { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME]) + setTimeout(() => { + accessibility.getAbilityLists('all', 'disable').then((data) => { + console.info(logTag + 'success data:getAbilityLists : ' + JSON.stringify(data)) + console.info(logTag + 'data.length : ' + JSON.stringify(data.length)) + expect(data.length).assertLarger(0) + done() + }).catch((err) => { + console.info(logTag + 'failed to getAbilityLists because ' + JSON.stringify(err)) + }) + }, TIME_OUT) + }, TIME_OUT_S) + }) + }) + + function enableAbility(logTag, bundleNameArr) { + for (let bundleName of bundleNameArr) { + config.enableAbility(bundleName, ['retrieve']).then(() => { + console.info(logTag + 'enableAbility ' + bundleName + ' success.') + }).catch((error) => { + console.info(logTag + 'enableAbility ' + bundleName + ' failed. Cause: ' + JSON.stringify(error)) + return + }) + } + } + + function disableAbility(logTag, bundleNameArr) { + for (let bundleName of bundleNameArr) { + config.disableAbility(bundleName).then(() => { + console.info(logTag + 'disableAbility ' + bundleName + ' success.') + }).catch((error) => { + console.info(logTag + 'disableAbility ' + bundleName + ' failed. Cause: ' + JSON.stringify(error)) + return + }) + } + } + + function disableAll(logTag) { + disableAbility(logTag, [AUDIBLE_BUNDLE_NAME, GENERIC_BUNDLE_NAME, HAPTIC_BUNDLE_NAME, SPOKEN_BUNDLE_NAME, VISUAL_BUNDLE_NAME]) + } +} diff --git a/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/test/List.test.ets b/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/test/List.test.ets new file mode 100644 index 000000000..cb35098ac --- /dev/null +++ b/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/ets/test/List.test.ets @@ -0,0 +1,19 @@ +/* + * Copyright (c) 2022 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +import abilityTest from './Ability.test' + +export default function testsuite() { + abilityTest() +} \ No newline at end of file diff --git a/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/module.json b/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/module.json new file mode 100644 index 000000000..b8b2f9ecc --- /dev/null +++ b/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/module.json @@ -0,0 +1,47 @@ +{ + "module": { + "name": "phone", + "type": "entry", + "srcEntrance": "./ets/Application/AbilityStage.ts", + "description": "$string:entry_desc", + "mainElement": "MainAbility", + "deviceTypes": [ + "phone", + "tablet" + ], + "deliveryWithInstall": true, + "installationFree": false, + "pages": "$profile:main_pages", + "uiSyntax": "ets", + "abilities": [ + { + "name": "com.example.abilitylisttest.MainAbility", + "srcEntrance": "./ets/MainAbility/MainAbility.ts", + "description": "$string:MainAbility_desc", + "icon": "$media:icon", + "label": "$string:MainAbility_label", + "visible": true, + "skills": [ + { + "entities": [ + "entity.system.home" + ], + "actions": [ + "action.system.home" + ] + } + ] + } + ], + "requestPermissions": [ + { + "name": "ohos.permission.SYSTEM_FLOAT_WINDOW", + "reason": "need use ohos.permission.SYSTEM_FLOAT_WINDOW" + }, + { + "name": "ohos.permission.CAPTURE_SCREEN", + "reason": "need use ohos.permission.SYSTEM_FLOAT_WINDOW" + } + ] + } +} \ No newline at end of file diff --git a/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/resources/base/element/string.json b/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/resources/base/element/string.json new file mode 100644 index 000000000..26c6350af --- /dev/null +++ b/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/resources/base/element/string.json @@ -0,0 +1,16 @@ +{ + "string": [ + { + "name": "entry_desc", + "value": "AbilityListTest entry" + }, + { + "name": "MainAbility_desc", + "value": "AbilityListTest MainAbility" + }, + { + "name": "MainAbility_label", + "value": "AbilityList" + } + ] +} \ No newline at end of file diff --git a/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/resources/base/media/icon.png b/barrierfree/accessibletest/actsabilitylisttest/entry/src/main/resources/base/media/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..ce307a8827bd75456441ceb57d530e4c8d45d36c GIT binary patch literal 6790 zcmX|G1ymHk)?T_}Vd;>R?p|tHQo6fg38|$UVM!6BLrPFWk?s;$LOP{GmJpBl$qoSA!PUg~PA65-S00{{S`XKG6NkG0RgjEntPrmV+?0|00mu7;+5 zrdpa{2QLqPJ4Y{j7=Mrl{BaxrkdY69+c~(w{Fv-v&aR%aEI&JYSeRTLWm!zbv;?)_ ziZB;fwGbbeL5Q}YLx`J$lp~A09KK8t_z}PZ=4ZzgdeKtgoc+o5EvN9A1K1_<>M?MBqb#!ASf&# zEX?<)!RH(7>1P+j=jqG(58}TVN-$psA6K}atCuI!KTJD&FMmH-78ZejBm)0qc{ESp z|LuG1{QnBUJRg_E=h1#XMWt2%fcoN@l7eAS!Es?Q+;XsRNPhiiE=@AqlLkJzF`O18 zbsbSmKN=aaq8k3NFYZfDWpKmM!coBU0(XnL8R{4=i|wi{!uWYM2je{U{B*K2PVdu&=E zTq*-XsEsJ$u5H4g6DIm2Y!DN`>^v|AqlwuCD;w45K0@eqauiqWf7l&o)+YLHm~|L~ z7$0v5mkobriU!H<@mVJHLlmQqzQ3d6Rh_-|%Yy2li*tHO>_vcnuZ7OR_xkAIuIU&x z-|8Y0wj|6|a6_I(v91y%k_kNw6pnkNdxjqG8!%Vz_d%c_!X+6-;1`GC9_FpjoHev5fEV7RhJ>r=mh-jp$fqbqRJ=obwdgLDVP5+s zy1=_DWG0Y-Jb3t^WXmkr(d9~08k-|#Ly zaNOmT(^9tIb&eb4%CzIT zAm3CUtWSr1t4?h1kk#NBi{U|pJslvME{q|_eS^3En>SOqSxyuN1x;Is@8~m?*>}** znrRFArP!K_52RpX*&JHMR<^lVdm8ypJ}0R(SD(51j;6@ni$6bQ+2XL+R^|NnSp5}(kzvMZ^(@4fD_{QVu$(&K6H|C37TG1Am9Re{<<3gd zh@`>;BqkXMW&p0T6rt|iB$)~CvFe(XC)F9WgAZn*0@t$oZo;!*}r@_`h?KKH&6A@3= zISXoQB+~`op>NP-buiA*^0n{@i{_?MRG)&k)c)k_F+-2Lud!S9pc+i`s74NpBCaGF zXN+pHkubw*msGBTY27BKHv)RRh3;nMg4&$fD_6X9Vt~;_4D+5XPH~#Kn-yjcy!$}1 zigv#FNY>TqMhtIBb@UoF!cE~Q8~;!Pek>SQQwHnHuWKoVBosAiOr}q>!>aE*Krc)V zBUMEcJ5NU0g8}-h6i1zpMY9>m4ne?=U2~`w7K7Q0gB_=p@$5K7p6}thw z-~3dMj?YNX2X$lZ+7ngQ$=s}3mizNN@kE%OtB)?c&i~2L55z8^=yz;xMHLmlY>&Q# zJj?!)M#q_SyfkQh)k?j8IfLtB)ZCp|*vf4_B zos?73yd^h-Ac+;?E4*bpf=o*^3x3-`TVjbY4n6!EN10K6o@fxdyps05Vo3PU)otB} z`3kR+2w7_C#8Z!q`J)p{Vh!+m9-UP!$STp+Hb}}#@#_u^SsUQg<}59< zTvH3%XS4G+6FF^(m6bVF&nSUIXcl;nw{=H$%fgeJ>CgDYiLdpDXr{;-AnG z8dvcrHYVMI&`R6;GWekI@Ir3!uo)oz4^{6q0m^}@f2tM9&=YHNi6-?rh0-{+k@cQm zdp`g#YdQn%MDVg2GR>wZ`n2<0l4)9nx1Wfr&!Dvz=bPwU!h2S?ez6MVc5APE4-xLB zi&W9Q8k2@0w!C53g?iAIQ}~p*3O(@zja6KQ=M3zfW*_6o5SwR-)6VBh~m7{^-=MC-owYH5-u40a}a0liho3QZZ5L{bS_xM1)4}19)zTU$$MY zq3eZML1WC{K%YFd`Be0M-rkO^l?h{kM{$2oK1*A@HVJ57*yhDkUF!2WZ&oA4Y-sK( zCY69%#`mBCi6>6uw(x4gbFaP0+FD*JKJ-q!F1E?vLJ+d35!I5d7@^eU?(CS|C^tmI5?lv@s{{*|1F zFg|OzNpZ0hxljdjaW%45O0MOttRrd(Z?h{HYbB-KFUx&9GfFL3b8NwZ$zNu)WbBD` zYkj$^UB5%3Pj1MDr>S2Ejr9pUcgA!;ZG!@{uAy12)vG=*^9-|dNQBc8&`oxBlU~#y zs!anJX&T?57Jdr^sb>e+V`MVfY>Y0ESg7MG<7W0g&bR-ZYzzZ%2H&Etcp zcd6QeXO1D!5A#zM0lx*GH}`M)2~ZFLE;sP^RSB5wVMNfiZXPd(cmO>j=OSA3`o5r& zna(|^jGXbdN7PK)U8b7^zYtYkkeb%<%F~=OqB~kXMQkq}ii|skh@WSRt>5za;cjP0 zZ~nD%6)wzedqE}BMLt~qKwlvTr33))#uP~xyw#*Eaa|DbMQ_%mG0U8numf8)0DX`r zRoG2bM;#g|p-8gWnwRV5SCW0tLjLO&9Z?K>FImeIxlGUgo0Zk`9Qzhj1eco~7XZy+hXc@YF&ZQ=? zn*^1O56yK^x{y}q`j7}blGCx%dydV!c7)g~tJzmHhV=W~jbWRRR{1<^oDK+1clprm zz$eCy7y9+?{E|YgkW~}}iB#I4XoJ*xr8R?i_Hv$=Cof5bo-Nj~f`-DLebH}&0% zfQj9@WGd4;N~Y?mzQsHJTJq6!Qzl^-vwol(+fMt#Pl=Wh#lI5Vmu@QM0=_r+1wHt` z+8WZ~c2}KQQ+q)~2Ki77QvV&`xb|xVcTms99&cD$Zz4+-^R4kvUBxG8gDk7Y`K*)JZ^2rL(+ZWV~%W(@6 z)0bPArG#BROa_PHs~&WplQ_UIrpd)1N1QGPfv!J(Z9jNT#i%H?CE6|pPZb9hJ1JW4 z^q;ft#!HRNV0YgPojzIYT`8LuET2rUe-J|c!9l4`^*;4WtY@Ew@pL>wkjmMgGfN7 ze}}GtmU0@<_#08~I-Suk=^*9GLW=H4xhsml;vAV{%hy5Eegl@!6qKqbG024%n2HHw zCc@ivW_$@5ZoHP70(7D+(`PvgjW1Pd`wsiuv-aCukMrafwDm)B!xXVy*j2opohhoU zcJz%ADmj>i3`-3-$7nQKBQQuGY;2Qt&+(L~C>vSGFj5{Mlv?T_^dql;{zkpe4R1}R z%XfZyQ}wr*sr>jrKgm*PWLjuVc%6&&`Kbf1SuFpHPN&>W)$GmqC;pIoBC`=4-hPY8 zT*>%I2fP}vGW;R=^!1be?ta2UQd2>alOFFbVl;(SQJ4Jk#)4Z0^wpWEVvY4=vyDk@ zqlModi@iVPMC+{?rm=4(n+<;|lmUO@UKYA>EPTS~AndtK^Wy^%#3<;(dQdk3WaUkRtzSMC9}7x2||CNpF#(3T4C)@ z$~RWs`BNABKX|{cmBt>Q=&gkXl&x!!NK_%5hW0LS)Z4PB>%sV?F-{Wyj#s7W%$F{D zXdK^Fp3wvy+48+GP6F_|^PCRx=ddcTO3sG;B23A49~Qaw31SZ0Rc~`r4qqt%#OGW{ zCA_(LG5^N>yzUn&kAgVmxb=EA8s&tBXC}S1CZ(KoW)(%^JjLTPo^fs`Va;`=YlVPgmB$!yB}<(4ym6OeZ3xAJJ#;)2+B%p3P1Wt+d$eo`vz`T zXfUP2))kBDPoscH;Jc7I3NU<({|@wM$&GaDt`n7WLgIY3IA7A6-_R?z8N3mz|}*i z(zl5ot--Oq@f2-nv{X(ujT2T(k1vY_qh93pK@>H-qc%2Xta)IP0Q%zt%bqYgI`o!wv!0QerB`nCN^1n|@$sVOQ!V0teVG!I z_fD%JvfDeT1cK#-{o6Gv7}& zY0#NWin~kVaf$aufV&;63Hbs|`QVZWpDX6IMk1Hj2G}fiH9e-^6u2zf^FIr^BwD<6zjw63+{yUe8PUFvk8v{sJ=R{d#`O!sz`Q13~< zPT$JS(w=yQfU2`zPCNfSw=&zup@DXc(98afjhv@1w_f!m2Z>rMJ19AB&dB%P#Ls3b z=lK7OILM+SQ&VEd=1GN6o&>YVVtIzoZ%=Z_SdqJN2}E43{bE`>w+A;=y->@^k{oCC z$F*WTY&?34;kfyFV?b*Xb1Pq`Z=%OgwEg)Rz)tx=`f%5#w_INP=x&z5!jI;#;N$ma zhO)+MDm;SxOEVL15; zGq(v2pL3&P1Sl)8P*;G-fd{l1QJsv@e@d8)1PK4w2m*M%V3j-V~L^$i|&C@b?D?9tfwE{B^}Z$k8e5FmQ>v7Xz)sG32g9t}YBt zyR$+*_00RmPx+0mW+vVG4mxd(n$(eQf3-w>JPl2UJpafrPaL5@2j}%{VE-) zBI%6Qpj*dsdH<;g!S!avA~bv^0E+ zfyJbSjPb+j;J52U)<|cIcntQBI2T#>2;tOxu{%D?kML476AErF(qN9hPva5Nkc@BF zC-tLF@3ZFb%Kpj)M<{)x*l|*Ia@ECeXo2E4h2f!aV=cHAhi_E_mfUth(sM4^hJq7B zQsGWqdZUm9S%F`$nQ*_#NcuD`&)Ek%_s{&^78{9Hm ztri&rYLOxgFdG>O@+XHy z9#;|&vBCPXH5Mon^I`jSuR$&~ZWtyB67ujzFSj!51>#C}C17~TffQ{c-!QFQkTQ%! zIR^b1`zHx|*1GU?tbBx23weFLz5H?y_Q%N&t$}k?w+``2A=aotj0;2v$~AL z{scF-cL{wsdrmPvf#a9OHyYLcwQD4Kcm)`LLwMh4WT~p29f7M!iafJSU`IV}QY5Wa z(n44-9oA}?J{a+ah*@31WTs#&J#o1`H98#6IQf;Wv0N_!);f&9g7o-k(lW5rWnDUR zQBFIRG+X=6NnsI@mxnwm;tf5;_Uxg?jZ8m-m0}&6+DA!qam(p$mN5R})yA_7m$q@| zFEd|dpS595rxQr-n#GjI5i-AhnUE>Cr;jpCqSrD~EwK_DqI^7%3#p5)%T_od!t3SOmH9MyXeeGO2(UQL;ax|x?Ncixmeo1=$ z{-);Au{*tfzOG?KQ~K|ak8-HQ?`Pekhe2WM(8s{xv-p>Zmu_6{G!-oE$7$mY`MOJorI=+mMx?H;`pr!;fVYz?5~yXBACruWB`Ph zZM}90_<^OBxIhyZ9BW$`>6JvO;%VFpqVr8|7t3~AmxYak6?`Pp#c;**_SYmi`&z23 z`p6_~ePvH)C6x-G9$hgL=eVALq`-AiamN>!3~Lxw&{H(b{B(7xSRm6<3<{%{yXiH# zos5Rv1L+8fUKJLo%P>4I&$}y~SeBvh{(i_&{al!0t?2p{?bQJ)T4U z$ei!Hzx&!%?4AoQExQO>+>@aflW*9 zYLnSeQzf|<&(j98TsXn%;#`E6r-#`#Ho>RZw62f3E5&j)CY|KDc4?g&&?ut*?ql)xAlIzMlLNhBI=jkPqp z>L|(ri(Z(-$sC%8?MT#FkH9_}ZgIM#2yRNmqCQJKMJ>QYp)Q2iXFa&JJ=kE*vNYC2 zA|V`xycn7zDY^|J@*8p-0EO4?PL(+cE28N+9 zs~Ey_DWBd77%3No)t(4S`wi*6Vgn7+NHjE%T>_Ca?dSS)O(KZsL}8c?`dlbQr5cQp zaEs68G#J}JV-;*;a*)2c4hdrxK4WzgO%U6d%(;Ad5ANseA{oipVqUKqV5S5C=tf@? z=S)UPD8sj9gDlkw(>z3oUJD$NncF-hhFjo)F^ZTE8l7S)BA6(c5N)0;tZ!fw_3`<q&CJ`&=S zm28elrV?yrvR!Hi3Ax<*Yo19Zq_WGjX9PAG2+8H%-!LL9BV^^`*T$qiF)%Jo)k?L_ zgc2FK$eBcf7um3`-@Z%BOVCQG=9BS^+}A1zr-z0ejsW6yS{#`6ZfWY3(Y^?2R&Gln zK?*Wtg0#B%s*BahR{qc$vHm7gi=`{+ z-=IVJ8_=P6xl^T7D3$7(oynKL7|nIk{r2{4YL%+60ED2?ph%dKoAywIw!9(yBIhLa^m^!Ig4*@;ULwf0JY?@ST zFhlw(Xut%iUq}Lg%6<|RS0hoE<|FY0Tkh_^K!FdGX-4&>L8%zXhe|O@g%qe8-cf#W zaL4|S;ntTXy!OcK^?R)~%Zk@cQ+&2}&R-uoas1>|a#ziFs`tJ=%qi#6cT9WvZ=KZI zqKSWb)bO^7TXlHy`Yt!91JfirH_uQ{1{0T#|Htxf?Zgj8Z&}dYbIYQGUl%Uks>4Bv z3>d3W{8z13DMu{@H_LX3dZK##8_ee~?#w%nzVn9zzdciU@%uor!aelNRPh23Q9=cK z9^O~f5p3UQn>h|S^LzGSOtb%nO{Jps_KRn>uIv67Sra}U`R?S-b0=48suy1R(RwW%#z-JjXfag z$0F(HwE_K%J!x7slnaRc!lRoFX7wN4w5uJRo9BgLB7zK%X^@Ee%xlP`4U}FHPvPAA z)dgBrus}^#_q4BVDPFemY_a|DrP=(KAvn2U(LvqljcqTU_W9nuYs1z%JAQobeV-a% zMdIsHk0IOlbe=mHxIph1Q_>T9aLwQGaa|7-pLl-z)(e3N7iLXcmF_A3_03eqM=Yrs zg@4tBfIGohStw<)a0-D+`V3W)LNiE7lWI%1JbB~2y#=m4@2;!ZzphCvd28tDsiFlS ztOR0{SOLBDgShMV$2T2od}htQiXGRlerL?{wFjp@uyl?w@87=VCf(+vhj{gjxUWLk zpae6YocTNc?maU`xyNr?eXjE%V85f?@}Df$o7&d4Y2!KYc&lq|`>~yqj?UfjHa>ZI zp`;^5(oye#j;6A&+%}ZSH9WmR%?L79=?CjbHm^-byo!XTZ~pSgrl%$u_pW?>Tj0~r z;ae)yr=~pd?fb$qbl)z`_j}J)OnKwjqs1>gU$bpVs&U1UCBI7TZ`<+Qn{LqX%!iN9 zuC9Bw`>9tqOxd{o+Z8KHzkPSz^cCmtTlmb}Y3EPBcJkpLb>6NJV1_iO5jFCEXl%sh zHspp;#R>qc1j*y~n3nxfID6mI=WAnu-AAf7pL(hE$g#3hizB73UYqx$6-#f7bratl zJ>5Owz0=3WNzLl;b-cK{Hoe8&Jxh1t*~UGG9(%0x)x@nm6FY9Y_}~fW>U8hJ%&C-5 zSRH-c@WibjRze*LL=xHU(qj#@T$5uQxKRhc3p?Xr^5u77kqVN=etJzRz)hEpqC#k_ zbSdhAL2m{%kilqf0`sqosv)hq{QZ@*vGt}a8baqiY#BBT6bK9(= z8^(j{FW=-!wGCL6(+kdjQ*tk&x-NZj!;0!p$4&V0={K7%%<1YB9AAAhq mCl*fp;NAt}BL{ZRsww--|AHBRR?p|tHQo6fg38|$UVM!6BLrPFWk?s;$LOP{GmJpBl$qoSA!PUg~PA65-S00{{S`XKG6NkG0RgjEntPrmV+?0|00mu7;+5 zrdpa{2QLqPJ4Y{j7=Mrl{BaxrkdY69+c~(w{Fv-v&aR%aEI&JYSeRTLWm!zbv;?)_ ziZB;fwGbbeL5Q}YLx`J$lp~A09KK8t_z}PZ=4ZzgdeKtgoc+o5EvN9A1K1_<>M?MBqb#!ASf&# zEX?<)!RH(7>1P+j=jqG(58}TVN-$psA6K}atCuI!KTJD&FMmH-78ZejBm)0qc{ESp z|LuG1{QnBUJRg_E=h1#XMWt2%fcoN@l7eAS!Es?Q+;XsRNPhiiE=@AqlLkJzF`O18 zbsbSmKN=aaq8k3NFYZfDWpKmM!coBU0(XnL8R{4=i|wi{!uWYM2je{U{B*K2PVdu&=E zTq*-XsEsJ$u5H4g6DIm2Y!DN`>^v|AqlwuCD;w45K0@eqauiqWf7l&o)+YLHm~|L~ z7$0v5mkobriU!H<@mVJHLlmQqzQ3d6Rh_-|%Yy2li*tHO>_vcnuZ7OR_xkAIuIU&x z-|8Y0wj|6|a6_I(v91y%k_kNw6pnkNdxjqG8!%Vz_d%c_!X+6-;1`GC9_FpjoHev5fEV7RhJ>r=mh-jp$fqbqRJ=obwdgLDVP5+s zy1=_DWG0Y-Jb3t^WXmkr(d9~08k-|#Ly zaNOmT(^9tIb&eb4%CzIT zAm3CUtWSr1t4?h1kk#NBi{U|pJslvME{q|_eS^3En>SOqSxyuN1x;Is@8~m?*>}** znrRFArP!K_52RpX*&JHMR<^lVdm8ypJ}0R(SD(51j;6@ni$6bQ+2XL+R^|NnSp5}(kzvMZ^(@4fD_{QVu$(&K6H|C37TG1Am9Re{<<3gd zh@`>;BqkXMW&p0T6rt|iB$)~CvFe(XC)F9WgAZn*0@t$oZo;!*}r@_`h?KKH&6A@3= zISXoQB+~`op>NP-buiA*^0n{@i{_?MRG)&k)c)k_F+-2Lud!S9pc+i`s74NpBCaGF zXN+pHkubw*msGBTY27BKHv)RRh3;nMg4&$fD_6X9Vt~;_4D+5XPH~#Kn-yjcy!$}1 zigv#FNY>TqMhtIBb@UoF!cE~Q8~;!Pek>SQQwHnHuWKoVBosAiOr}q>!>aE*Krc)V zBUMEcJ5NU0g8}-h6i1zpMY9>m4ne?=U2~`w7K7Q0gB_=p@$5K7p6}thw z-~3dMj?YNX2X$lZ+7ngQ$=s}3mizNN@kE%OtB)?c&i~2L55z8^=yz;xMHLmlY>&Q# zJj?!)M#q_SyfkQh)k?j8IfLtB)ZCp|*vf4_B zos?73yd^h-Ac+;?E4*bpf=o*^3x3-`TVjbY4n6!EN10K6o@fxdyps05Vo3PU)otB} z`3kR+2w7_C#8Z!q`J)p{Vh!+m9-UP!$STp+Hb}}#@#_u^SsUQg<}59< zTvH3%XS4G+6FF^(m6bVF&nSUIXcl;nw{=H$%fgeJ>CgDYiLdpDXr{;-AnG z8dvcrHYVMI&`R6;GWekI@Ir3!uo)oz4^{6q0m^}@f2tM9&=YHNi6-?rh0-{+k@cQm zdp`g#YdQn%MDVg2GR>wZ`n2<0l4)9nx1Wfr&!Dvz=bPwU!h2S?ez6MVc5APE4-xLB zi&W9Q8k2@0w!C53g?iAIQ}~p*3O(@zja6KQ=M3zfW*_6o5SwR-)6VBh~m7{^-=MC-owYH5-u40a}a0liho3QZZ5L{bS_xM1)4}19)zTU$$MY zq3eZML1WC{K%YFd`Be0M-rkO^l?h{kM{$2oK1*A@HVJ57*yhDkUF!2WZ&oA4Y-sK( zCY69%#`mBCi6>6uw(x4gbFaP0+FD*JKJ-q!F1E?vLJ+d35!I5d7@^eU?(CS|C^tmI5?lv@s{{*|1F zFg|OzNpZ0hxljdjaW%45O0MOttRrd(Z?h{HYbB-KFUx&9GfFL3b8NwZ$zNu)WbBD` zYkj$^UB5%3Pj1MDr>S2Ejr9pUcgA!;ZG!@{uAy12)vG=*^9-|dNQBc8&`oxBlU~#y zs!anJX&T?57Jdr^sb>e+V`MVfY>Y0ESg7MG<7W0g&bR-ZYzzZ%2H&Etcp zcd6QeXO1D!5A#zM0lx*GH}`M)2~ZFLE;sP^RSB5wVMNfiZXPd(cmO>j=OSA3`o5r& zna(|^jGXbdN7PK)U8b7^zYtYkkeb%<%F~=OqB~kXMQkq}ii|skh@WSRt>5za;cjP0 zZ~nD%6)wzedqE}BMLt~qKwlvTr33))#uP~xyw#*Eaa|DbMQ_%mG0U8numf8)0DX`r zRoG2bM;#g|p-8gWnwRV5SCW0tLjLO&9Z?K>FImeIxlGUgo0Zk`9Qzhj1eco~7XZy+hXc@YF&ZQ=? zn*^1O56yK^x{y}q`j7}blGCx%dydV!c7)g~tJzmHhV=W~jbWRRR{1<^oDK+1clprm zz$eCy7y9+?{E|YgkW~}}iB#I4XoJ*xr8R?i_Hv$=Cof5bo-Nj~f`-DLebH}&0% zfQj9@WGd4;N~Y?mzQsHJTJq6!Qzl^-vwol(+fMt#Pl=Wh#lI5Vmu@QM0=_r+1wHt` z+8WZ~c2}KQQ+q)~2Ki77QvV&`xb|xVcTms99&cD$Zz4+-^R4kvUBxG8gDk7Y`K*)JZ^2rL(+ZWV~%W(@6 z)0bPArG#BROa_PHs~&WplQ_UIrpd)1N1QGPfv!J(Z9jNT#i%H?CE6|pPZb9hJ1JW4 z^q;ft#!HRNV0YgPojzIYT`8LuET2rUe-J|c!9l4`^*;4WtY@Ew@pL>wkjmMgGfN7 ze}}GtmU0@<_#08~I-Suk=^*9GLW=H4xhsml;vAV{%hy5Eegl@!6qKqbG024%n2HHw zCc@ivW_$@5ZoHP70(7D+(`PvgjW1Pd`wsiuv-aCukMrafwDm)B!xXVy*j2opohhoU zcJz%ADmj>i3`-3-$7nQKBQQuGY;2Qt&+(L~C>vSGFj5{Mlv?T_^dql;{zkpe4R1}R z%XfZyQ}wr*sr>jrKgm*PWLjuVc%6&&`Kbf1SuFpHPN&>W)$GmqC;pIoBC`=4-hPY8 zT*>%I2fP}vGW;R=^!1be?ta2UQd2>alOFFbVl;(SQJ4Jk#)4Z0^wpWEVvY4=vyDk@ zqlModi@iVPMC+{?rm=4(n+<;|lmUO@UKYA>EPTS~AndtK^Wy^%#3<;(dQdk3WaUkRtzSMC9}7x2||CNpF#(3T4C)@ z$~RWs`BNABKX|{cmBt>Q=&gkXl&x!!NK_%5hW0LS)Z4PB>%sV?F-{Wyj#s7W%$F{D zXdK^Fp3wvy+48+GP6F_|^PCRx=ddcTO3sG;B23A49~Qaw31SZ0Rc~`r4qqt%#OGW{ zCA_(LG5^N>yzUn&kAgVmxb=EA8s&tBXC}S1CZ(KoW)(%^JjLTPo^fs`Va;`=YlVPgmB$!yB}<(4ym6OeZ3xAJJ#;)2+B%p3P1Wt+d$eo`vz`T zXfUP2))kBDPoscH;Jc7I3NU<({|@wM$&GaDt`n7WLgIY3IA7A6-_R?z8N3mz|}*i z(zl5ot--Oq@f2-nv{X(ujT2T(k1vY_qh93pK@>H-qc%2Xta)IP0Q%zt%bqYgI`o!wv!0QerB`nCN^1n|@$sVOQ!V0teVG!I z_fD%JvfDeT1cK#-{o6Gv7}& zY0#NWin~kVaf$aufV&;63Hbs|`QVZWpDX6IMk1Hj2G}fiH9e-^6u2zf^FIr^BwD<6zjw63+{yUe8PUFvk8v{sJ=R{d#`O!sz`Q13~< zPT$JS(w=yQfU2`zPCNfSw=&zup@DXc(98afjhv@1w_f!m2Z>rMJ19AB&dB%P#Ls3b z=lK7OILM+SQ&VEd=1GN6o&>YVVtIzoZ%=Z_SdqJN2}E43{bE`>w+A;=y->@^k{oCC z$F*WTY&?34;kfyFV?b*Xb1Pq`Z=%OgwEg)Rz)tx=`f%5#w_INP=x&z5!jI;#;N$ma zhO)+MDm;SxOEVL15; zGq(v2pL3&P1Sl)8P*;G-fd{l1QJsv@e@d8)1PK4w2m*M%V3j-V~L^$i|&C@b?D?9tfwE{B^}Z$k8e5FmQ>v7Xz)sG32g9t}YBt zyR$+*_00RmPx+0mW+vVG4mxd(n$(eQf3-w>JPl2UJpafrPaL5@2j}%{VE-) zBI%6Qpj*dsdH<;g!S!avA~bv^0E+ zfyJbSjPb+j;J52U)<|cIcntQBI2T#>2;tOxu{%D?kML476AErF(qN9hPva5Nkc@BF zC-tLF@3ZFb%Kpj)M<{)x*l|*Ia@ECeXo2E4h2f!aV=cHAhi_E_mfUth(sM4^hJq7B zQsGWqdZUm9S%F`$nQ*_#NcuD`&)Ek%_s{&^78{9Hm ztri&rYLOxgFdG>O@+XHy z9#;|&vBCPXH5Mon^I`jSuR$&~ZWtyB67ujzFSj!51>#C}C17~TffQ{c-!QFQkTQ%! zIR^b1`zHx|*1GU?tbBx23weFLz5H?y_Q%N&t$}k?w+``2A=aotj0;2v$~AL z{scF-cL{wsdrmPvf#a9OHyYLcwQD4Kcm)`LLwMh4WT~p29f7M!iafJSU`IV}QY5Wa z(n44-9oA}?J{a+ah*@31WTs#&J#o1`H98#6IQf;Wv0N_!);f&9g7o-k(lW5rWnDUR zQBFIRG+X=6NnsI@mxnwm;tf5;_Uxg?jZ8m-m0}&6+DA!qam(p$mN5R})yA_7m$q@| zFEd|dpS595rxQr-n#GjI5i-AhnUE>Cr;jpCqSrD~EwK_DqI^7%3#p5)%T_od!t3SOmH9MyXeeGO2(UQL;ax|x?Ncixmeo1=$ z{-);Au{*tfzOG?KQ~K|ak8-HQ?`Pekhe2WM(8s{xv-p>Zmu_6{G!-oE$7$mY`MOJorI=+mMx?H;`pr!;fVYz?5~yXBACruWB`Ph zZM}90_<^OBxIhyZ9BW$`>6JvO;%VFpqVr8|7t3~AmxYak6?`Pp#c;**_SYmi`&z23 z`p6_~ePvH)C6x-G9$hgL=eVALq`-AiamN>!3~Lxw&{H(b{B(7xSRm6<3<{%{yXiH# zos5Rv1L+8fUKJLo%P>4I&$}y { + const caseName = "CaptionConfiguration_0010" + const logTag = LOG + caseName; + let captionsManager = accessibility.getCaptionsManager(); + if (!captionsManager) { + console.info(logTag + "captionsManager is undefined"); + return; + } + let before = captionsManager.enabled; + console.info(logTag + "captionsManager before modification. enabled=" + before); + captionsManager.enabled = !captionsManager.enabled; + let after = captionsManager.enabled; + console.info(logTag + "captionsManager after modification. enabled=" + after); + if (before != after) { + commonEventPublishOnTargetChangeExtra(caseName); + } +} + +const printCaptionsManagerStyle = (logTag, captionsManager) => { + const back = "{\"fontFamily\":\"" + captionsManager.style.fontFamily + + "\",\"fontScale\":" + captionsManager.style.fontScale + + ",\"fontColor\":\"" + captionsManager.style.fontColor + + "\",\"fontEdgeType\":\"" + captionsManager.style.fontEdgeType + + "\",\"backgroundColor\":\"" + captionsManager.style.backgroundColor + + "\",\"windowColor\":\"" + captionsManager.style.windowColor + "\"}"; + console.info(logTag + back); + return back; +}; + +const printCaptionStyle = (logTag, CaptionStyle) => { + const back = "{\"fontFamily\":\"" + CaptionStyle.fontFamily + + "\",\"fontScale\":" + CaptionStyle.fontScale + + ",\"fontColor\":\"" + CaptionStyle.fontColor + + "\",\"fontEdgeType\":\"" + CaptionStyle.fontEdgeType + + "\",\"backgroundColor\":\"" + CaptionStyle.backgroundColor + + "\",\"windowColor\":\"" + CaptionStyle.windowColor + "\"}"; + console.info(logTag + back); + return back; +}; + +const foreachList = (currValue, array) => { + if (!currValue || currValue.length < 1) { + return array[0]; + } + let result = array[0]; + array.forEach((value, index) => { + if (currValue === value) { + if (array.length > index + 1) { + result = array[index + 1]; + } + } + }); + return result; +} + +const CaptionConfiguration_0020 = () => { + const caseName = "CaptionConfiguration_0020" + const logTag = LOG + caseName; + let captionsManager = accessibility.getCaptionsManager(); + if (!captionsManager) { + console.info(logTag + "captionsManager is undefined"); + return; + } + const before = printCaptionsManagerStyle(logTag + "captionsManager before modification. style=", captionsManager); + captionsManager.style.fontFamily = foreachList(captionsManager.style.fontFamily, ['default', 'monospacedSerif', 'serif', + 'monospacedSansSerif', 'sansSerif', 'casual', 'cursive', 'smallCapitals']); + const after = printCaptionsManagerStyle(logTag + "captionsManager after modification. style=", captionsManager); + if (before != after) { + commonEventPublishOnTargetChangeExtra(caseName); + } + +}; + +const CaptionConfiguration_0030 = () => { + const caseName = "CaptionConfiguration_0030" + const logTag = LOG + caseName; + let captionsManager = accessibility.getCaptionsManager(); + if (!captionsManager) { + console.info(logTag + "captionsManager is undefined"); + return; + } + let before = (captionsManager.enabled); + console.info(logTag + "captionsManager before modification. enabled=" + before); + captionsManager.enabled = !captionsManager.enabled; + let after = captionsManager.enabled; + console.info(logTag + "captionsManager after modification. enabled=" + after); + if (before != after) { + commonEventPublishOnTargetChangeExtra(caseName); + } +} + +const CaptionConfiguration_0040 = () => { + const caseName = "CaptionConfiguration_0040" + const logTag = LOG + caseName; + let captionsManager = accessibility.getCaptionsManager(); + if (!captionsManager) { + console.info(logTag + "captionsManager is undefined"); + return; + } + const before = printCaptionsManagerStyle(logTag + "captionsManager before modification. style=", captionsManager); + captionsManager.style.fontFamily = foreachList(captionsManager.style.fontFamily, ['default', 'monospacedSerif', 'serif', + 'monospacedSansSerif', 'sansSerif', 'casual', 'cursive', 'smallCapitals']); + const after = printCaptionsManagerStyle(logTag + "captionsManager after modification. style=", captionsManager); + if (before != after) { + commonEventPublishOnTargetChangeExtra(caseName); + } +}; + +const CaptionConfiguration_0050 = () => { + const caseName = "CaptionConfiguration_0050" + const logTag = LOG + caseName; + let captionsManager = accessibility.getCaptionsManager(); + if (!captionsManager) { + console.info(logTag + "captionsManager is undefined"); + return; + } + const before = printCaptionsManagerStyle(logTag + "captionsManager before modification. style=", captionsManager); + captionsManager.style.fontFamily = foreachList(captionsManager.style.fontFamily, ['default', 'monospacedSerif', 'serif', + 'monospacedSansSerif', 'sansSerif', 'casual', 'cursive', 'smallCapitals']); + const after = printCaptionsManagerStyle(logTag + "captionsManager after modification. style=", captionsManager); + if (before != after) { + commonEventPublishOnTargetChangeExtra(caseName); + } +}; + +const CaptionConfiguration_0060 = () => { + const caseName = "CaptionConfiguration_0060" + const logTag = LOG + caseName; + let captionsManager = accessibility.getCaptionsManager(); + if (!captionsManager) { + console.info(logTag + "captionsManager is undefined"); + return; + } + const before = printCaptionsManagerStyle(logTag + "captionsManager before modification. style=", captionsManager); + captionsManager.style.fontScale = (captionsManager.style.fontScale ?? 0) + 1; + const after = printCaptionsManagerStyle(logTag + "captionsManager after modification. style=", captionsManager); + if (before != after) { + commonEventPublishOnTargetChangeExtra(caseName); + } +}; + +const CaptionConfiguration_0070 = () => { + const caseName = "CaptionConfiguration_0070" + const logTag = LOG + caseName; + let captionsManager = accessibility.getCaptionsManager(); + if (!captionsManager) { + console.info(logTag + "captionsManager is undefined"); + return; + } + const before = printCaptionsManagerStyle(logTag + "captionsManager before modification. style=", captionsManager); + captionsManager.style.fontColor = foreachList(captionsManager.style.fontColor, ['red', 'yellow', 'blue', '#ff0000ff', '##ff000000', 'black', 'white']); + const after = printCaptionsManagerStyle(logTag + "captionsManager after modification. style=", captionsManager); + if (before != after) { + commonEventPublishOnTargetChangeExtra(caseName); + } +}; + +const CaptionConfiguration_0080 = () => { + const caseName = "CaptionConfiguration_0080" + const logTag = LOG + caseName; + let captionsManager = accessibility.getCaptionsManager(); + if (!captionsManager) { + console.info(logTag + "captionsManager is undefined"); + return; + } + const before = printCaptionsManagerStyle(logTag + "captionsManager before modification. style=", captionsManager); + captionsManager.style.fontEdgeType = foreachList(captionsManager.style.fontEdgeType, ['none', 'raised', 'depressed', 'uniform', 'dropShadow']); + const after = printCaptionsManagerStyle(logTag + "captionsManager after modification. style=", captionsManager); + if (before != after) { + commonEventPublishOnTargetChangeExtra(caseName); + } +}; + +const CaptionConfiguration_0090 = () => { + const caseName = "CaptionConfiguration_0090" + const logTag = LOG + caseName; + let captionsManager = accessibility.getCaptionsManager(); + if (!captionsManager) { + console.info(logTag + "captionsManager is undefined"); + return; + } + const before = printCaptionsManagerStyle(logTag + "captionsManager before modification. style=", captionsManager); + captionsManager.style.backgroundColor = foreachList(captionsManager.style.backgroundColor, ['red', 'yellow', 'blue', '#ff0000ff', '##ff000000', 'black', 'white']); + const after = printCaptionsManagerStyle(logTag + "captionsManager after modification. style=", captionsManager); + if (before != after) { + commonEventPublishOnTargetChangeExtra(caseName); + } +}; + +const CaptionConfiguration_0100 = () => { + const caseName = "CaptionConfiguration_0100" + const logTag = LOG + caseName; + let captionsManager = accessibility.getCaptionsManager(); + if (!captionsManager) { + console.info(logTag + "captionsManager is undefined"); + return; + } + const before = printCaptionsManagerStyle(logTag + "captionsManager before modification. style=", captionsManager); + captionsManager.style.windowColor = foreachList(captionsManager.style.windowColor, ['red', 'yellow', 'blue', '#ff0000ff', '#ff000000', 'black', 'white']); + const after = printCaptionsManagerStyle(logTag + "captionsManager after modification. style=", captionsManager); + if (before != after) { + commonEventPublishOnTargetChangeExtra(caseName); + } +}; + +const CaptionConfiguration_0110 = () => { + const caseName = "CaptionConfiguration_0110" + const logTag = LOG + caseName; + let captionsManager = accessibility.getCaptionsManager(); + if (!captionsManager) { + console.info(logTag + "captionsManager is undefined"); + return; + } + const before = printCaptionsManagerStyle(logTag + "captionsManager before modification. style=", captionsManager); + for (let index = 0; index < 3; index++) { + printCaptionsManagerStyle(logTag + "captionsManager before modification. times=" + index + ". style=", captionsManager); + captionsManager.style.windowColor = foreachList(captionsManager.style.windowColor, ['red', 'yellow', 'blue', '#ff0000ff', '#ff000000', '#00000000', '#f0000000', 'black', 'white']); + printCaptionsManagerStyle(logTag + "captionsManager after modification. times=" + index + ". style=", captionsManager); + } + setTimeout(() => { + const after = printCaptionsManagerStyle(logTag + "captionsManager after modification. style=", captionsManager); + if (before != after) { + commonEventPublishOnTargetChangeExtra(caseName); + } + }, 2000) + +}; + +const CaptionConfiguration_0120 = () => { + const caseName = "CaptionConfiguration_0120" + const logTag = LOG + caseName; + let captionsManager = accessibility.getCaptionsManager(); + if (!captionsManager) { + console.info(logTag + "captionsManager is undefined"); + return; + } + const before = console.info(logTag + "captionsManager before modification. enabled=" + captionsManager.enabled); + captionsManager.enabled = undefined; + const after = console.info(logTag + "captionsManager after modification. enabled=" + captionsManager.enabled); + if (before != after) { + commonEventPublishOnTargetChangeExtra(caseName); + } +}; + +const CaptionConfiguration_0130 = () => { + const caseName = "CaptionConfiguration_0130" + const logTag = LOG + caseName; + let captionsManager = accessibility.getCaptionsManager(); + if (!captionsManager) { + console.info(logTag + "captionsManager is undefined"); + return; + } + const before = printCaptionsManagerStyle(logTag + "captionsManager before modification. style=", captionsManager); + captionsManager.style.fontEdgeType = undefined; + const after = printCaptionsManagerStyle(logTag + "captionsManager after modification. style=", captionsManager); + if (before != after) { + commonEventPublishOnTargetChangeExtra(caseName); + } +}; + +const CaptionConfiguration_0140 = () => { + const caseName = "CaptionConfiguration_0140" + const logTag = LOG + caseName; + config.captions.get().then((res) => { + console.info(logTag + "Config before modification. enabled=" + res); + config.captions.set(!res).then(() => { + console.info(logTag + "Config after modification. enabled=" + !res); + commonEventPublishOnTargetChangeExtra(caseName); + }).catch((err) => { + console.info(logTag + "caption set err=" + JSON.stringify(err)); + }); + }); +}; + +const CaptionConfiguration_0150 = () => { + const caseName = "CaptionConfiguration_0150" + const logTag = LOG + caseName; + config.captionsStyle.get().then((res) => { + if (!res) { + console.info(logTag + "captionsStyle is undefined"); + return; + } + var captionsStyle = res; + printCaptionStyle(logTag + "captionsStyle before modification. style=", JSON.stringify(res)); + captionsStyle.fontFamily = foreachList(res.fontFamily, ['default', 'monospacedSerif', 'serif', + 'monospacedSansSerif', 'sansSerif', 'casual', 'cursive', 'smallCapitals']); + printCaptionStyle(logTag + "captionsStyle after modification. style=", JSON.stringify(captionsStyle)); + config.captionsStyle.set(captionsStyle).then(() => { + commonEventPublishOnTargetChangeExtra(caseName); + }).catch((err) => { + console.info(logTag + "captionsStyle fontFamily set err=" + JSON.stringify(err)); + }); + }) +}; + +const CaptionConfiguration_0160 = () => { + const caseName = "CaptionConfiguration_0160" + const logTag = LOG + caseName; + config.captions.get().then((res) => { + console.info(logTag + "Config before modification. enabled=" + res); + config.captions.set(!res).then(() => { + console.info(logTag + "Config after modification. enabled=" + !res); + commonEventPublishOnTargetChangeExtra(caseName); + }).catch((err) => { + console.info(logTag + "caption set err=" + JSON.stringify(err)); + }); + }); +}; + +const CaptionConfiguration_0170 = () => { + const caseName = "CaptionConfiguration_0170" + const logTag = LOG + caseName; + config.captionsStyle.get().then((res) => { + if (!res) { + console.info(logTag + "captionsStyle is undefined"); + return; + } + var captionsStyle = res; + printCaptionStyle(logTag + "captionsStyle before modification. style=", JSON.stringify(res)); + captionsStyle.fontFamily = foreachList(res.fontFamily, ['default', 'monospacedSerif', 'serif', + 'monospacedSansSerif', 'sansSerif', 'casual', 'cursive', 'smallCapitals']); + printCaptionStyle(logTag + "captionsStyle after modification. style=", JSON.stringify(captionsStyle)); + config.captionsStyle.set(captionsStyle).then(() => { + commonEventPublishOnTargetChangeExtra(caseName); + }).catch((err) => { + console.info(logTag + "captionsStyle fontFamily set err=" + JSON.stringify(err)); + }); + }) +}; + +const CaptionConfiguration_0180 = () => { + const caseName = "CaptionConfiguration_0180" + const logTag = LOG + caseName; + config.captionsStyle.get().then((res) => { + if (!res) { + console.info(logTag + "captionsStyle is undefined"); + return; + } + var captionsStyle = res; + printCaptionStyle(logTag + "captionsStyle before modification. style=", JSON.stringify(res)); + captionsStyle.fontFamily = foreachList(res.fontFamily, ['default', 'monospacedSerif', 'serif', + 'monospacedSansSerif', 'sansSerif', 'casual', 'cursive', 'smallCapitals']); + printCaptionStyle(logTag + "captionsStyle after modification. style=", JSON.stringify(captionsStyle)); + config.captionsStyle.set(captionsStyle).then(() => { + commonEventPublishOnTargetChangeExtra(caseName); + }).catch((err) => { + console.info(logTag + "captionsStyle fontFamily set err=" + JSON.stringify(err)); + }); + }) +}; + +const CaptionConfiguration_0190 = () => { + const caseName = "CaptionConfiguration_0190" + const logTag = LOG + caseName; + config.captionsStyle.get().then((res) => { + if (!res) { + console.info(logTag + "captionsStyle is undefined"); + return; + } + var captionsStyle = res; + printCaptionStyle(logTag + "captionsStyle before modification. style=", JSON.stringify(res)); + captionsStyle.fontScale = (res.fontScale ?? 0) + 1; + printCaptionStyle(logTag + "captionsStyle after modification. style=", JSON.stringify(captionsStyle)); + config.captionsStyle.set(captionsStyle).then(() => { + commonEventPublishOnTargetChangeExtra(caseName); + }).catch((err) => { + console.info(logTag + "captionsStyle fontFamily set err=" + JSON.stringify(err)); + }); + }) +}; + +const CaptionConfiguration_0200 = () => { + const caseName = "CaptionConfiguration_0200" + const logTag = LOG + caseName; + config.captionsStyle.get().then((res) => { + if (!res) { + console.info(logTag + "captionsStyle is undefined"); + return; + } + var captionsStyle = res; + printCaptionStyle(logTag + "captionsStyle before modification. style=", JSON.stringify(res)); + captionsStyle.fontColor = foreachList(res.fontColor, ['red', 'yellow', 'blue', '#FFFFFF', '#000000', 'black', 'white']); + printCaptionStyle(logTag + "captionsStyle after modification. style=", JSON.stringify(captionsStyle)); + config.captionsStyle.set(captionsStyle).then(() => { + commonEventPublishOnTargetChangeExtra(caseName); + }).catch((err) => { + console.info(logTag + "captionsStyle fontFamily set err=" + JSON.stringify(err)); + }); + }) +}; + +const CaptionConfiguration_0210 = () => { + const caseName = "CaptionConfiguration_0210" + const logTag = LOG + caseName; + config.captionsStyle.get().then((res) => { + if (!res) { + console.info(logTag + "captionsStyle is undefined"); + return; + } + var captionsStyle = res; + printCaptionStyle(logTag + "captionsStyle before modification. style=", JSON.stringify(res)); + captionsStyle.fontEdgeType = foreachList(res.fontEdgeType, ['none', 'raised', 'depressed', 'uniform', 'dropShadow']); + printCaptionStyle(logTag + "captionsStyle after modification. style=", JSON.stringify(captionsStyle)); + config.captionsStyle.set(captionsStyle).then(() => { + commonEventPublishOnTargetChangeExtra(caseName); + }).catch((err) => { + console.info(logTag + "captionsStyle fontFamily set err=" + JSON.stringify(err)); + }); + }) +}; + +const CaptionConfiguration_0220 = () => { + const caseName = "CaptionConfiguration_0220" + const logTag = LOG + caseName; + config.captionsStyle.get().then((res) => { + if (!res) { + console.info(logTag + "captionsStyle is undefined"); + return; + } + var captionsStyle = res; + printCaptionStyle(logTag + "captionsStyle before modification. style=", JSON.stringify(res)); + captionsStyle.backgroundColor = foreachList(res.backgroundColor, ['red', 'yellow', 'blue', '#ff0000ff', '#ff000000', '#00000000', '#f0000000', 'black', 'white']); + printCaptionStyle(logTag + "captionsStyle after modification. style=", JSON.stringify(captionsStyle)); + config.captionsStyle.set(captionsStyle).then(() => { + commonEventPublishOnTargetChangeExtra(caseName); + }).catch((err) => { + console.info(logTag + "captionsStyle fontFamily set err=" + JSON.stringify(err)); + }); + }) +}; + +const CaptionConfiguration_0230 = () => { + const caseName = "CaptionConfiguration_0230" + const logTag = LOG + caseName; + config.captionsStyle.get().then((res) => { + if (!res) { + console.info(logTag + "captionsStyle is undefined"); + return; + } + var captionsStyle = res; + printCaptionStyle(logTag + "captionsStyle before modification. style=", JSON.stringify(res)); + captionsStyle.windowColor = foreachList(res.windowColor, ['red', 'yellow', 'blue', '#ff0000ff', '#ff000000', '#00000000', '#f0000000', 'black', 'white']); + printCaptionStyle(logTag + "captionsStyle after modification. style=", JSON.stringify(captionsStyle)); + config.captionsStyle.set(captionsStyle).then(() => { + commonEventPublishOnTargetChangeExtra(caseName); + }).catch((err) => { + console.info(logTag + "captionsStyle fontFamily set err=" + JSON.stringify(err)); + }); + }) +}; + +const CaptionConfiguration_0240 = () => { + const caseName = "CaptionConfiguration_0240" + const logTag = LOG + caseName; + config.captionsStyle.get().then((res) => { + if (!res) { + console.info(logTag + "captionsStyle is undefined"); + return; + } + var captionsStyle = res; + for (let index = 0; index < 3; index++) { + printCaptionStyle(logTag + "captionsStyle before modification. style=", JSON.stringify(res)); + captionsStyle.windowColor = foreachList(res.windowColor, ['red', 'yellow', 'blue', '#ff0000ff', '#ff000000', '#00000000', '#f0000000', 'black', 'white']); + printCaptionStyle(logTag + "captionsStyle after modification. style=", JSON.stringify(captionsStyle)); + config.captionsStyle.set(captionsStyle).then(() => { + commonEventPublishOnTargetChangeExtra(caseName); + }).catch((err) => { + console.info(logTag + "captionsStyle fontFamily set err=" + JSON.stringify(err)); + }); + } + + + }) +}; + +const CaptionConfiguration_0260 = () => { + const caseName = "CaptionConfiguration_0260" + const logTag = LOG + caseName; + config.captionsStyle.get().then((res) => { + if (!res) { + console.info(logTag + "captionsStyle is undefined"); + return; + } + var captionsStyle = res; + printCaptionStyle(logTag + "captionsStyle before modification. style=", JSON.stringify(res)); + captionsStyle.fontEdgeType = undefined; + printCaptionStyle(logTag + "captionsStyle after modification. style=", JSON.stringify(captionsStyle)); + config.captionsStyle.set(captionsStyle).then(() => { + commonEventPublishOnTargetChangeExtra(caseName); + }).catch((err) => { + console.info(logTag + "captionsStyle fontFamily set err=" + JSON.stringify(err)); + }); + }) +}; + +const commonEventPublishOnTargetChangeExtra = (caseName) => { + function publishCallback(err) { + console.info(LOG + caseName + " on_target_change_extra publish call back result:" + JSON.stringify(err)); + } + var commonEventPublishData = { + data: caseName + "_on_target_change_extra_success", + } + commonEvent.publish("on_target_change_extra", commonEventPublishData, publishCallback); +} + +const excuteAbility = (data) => { + switch (data) { + case "CaptionConfiguration_0010" + "_AccessibilityApp_start": + CaptionConfiguration_0010() + break; + case "CaptionConfiguration_0020" + "_AccessibilityApp_start": + CaptionConfiguration_0020() + break; + case "CaptionConfiguration_0030" + "_AccessibilityApp_start": + CaptionConfiguration_0030() + break; + case "CaptionConfiguration_0040" + "_AccessibilityApp_start": + CaptionConfiguration_0040() + break; + case "CaptionConfiguration_0050" + "_AccessibilityApp_start": + CaptionConfiguration_0050() + break; + case "CaptionConfiguration_0060" + "_AccessibilityApp_start": + CaptionConfiguration_0060() + break; + case "CaptionConfiguration_0070" + "_AccessibilityApp_start": + CaptionConfiguration_0070() + break; + case "CaptionConfiguration_0080" + "_AccessibilityApp_start": + CaptionConfiguration_0080() + break; + case "CaptionConfiguration_0090" + "_AccessibilityApp_start": + CaptionConfiguration_0090() + break; + case "CaptionConfiguration_0100" + "_AccessibilityApp_start": + CaptionConfiguration_0100() + break; + case "CaptionConfiguration_0110" + "_AccessibilityApp_start": + CaptionConfiguration_0110() + break; + case "CaptionConfiguration_0120" + "_AccessibilityApp_start": + CaptionConfiguration_0120() + break; + case "CaptionConfiguration_0130" + "_AccessibilityApp_start": + CaptionConfiguration_0130() + break; + case "CaptionConfiguration_0140" + "_AccessibilityApp_start": + CaptionConfiguration_0140() + break; + case "CaptionConfiguration_0150" + "_AccessibilityApp_start": + CaptionConfiguration_0150() + break; + case "CaptionConfiguration_0160" + "_AccessibilityApp_start": + CaptionConfiguration_0160() + break; + case "CaptionConfiguration_0170" + "_AccessibilityApp_start": + CaptionConfiguration_0170() + break; + case "CaptionConfiguration_0180" + "_AccessibilityApp_start": + CaptionConfiguration_0180() + break; + case "CaptionConfiguration_0190" + "_AccessibilityApp_start": + CaptionConfiguration_0190() + break; + case "CaptionConfiguration_0200" + "_AccessibilityApp_start": + CaptionConfiguration_0200() + break; + case "CaptionConfiguration_0210" + "_AccessibilityApp_start": + CaptionConfiguration_0210() + break; + case "CaptionConfiguration_0210" + "_AccessibilityApp_start": + CaptionConfiguration_0210() + break; + case "CaptionConfiguration_0220" + "_AccessibilityApp_start": + CaptionConfiguration_0220() + break; + case "CaptionConfiguration_0220" + "_AccessibilityApp_start": + CaptionConfiguration_0220() + break; + case "CaptionConfiguration_0230" + "_AccessibilityApp_start": + CaptionConfiguration_0230() + break; + case "CaptionConfiguration_0240" + "_AccessibilityApp_start": + CaptionConfiguration_0240() + break; + case "CaptionConfiguration_0260" + "_AccessibilityApp_start": + CaptionConfiguration_0260() + break; + default: + break; + } +} + +@Entry +@Component +struct Index { + private subScriber = undefined; + aboutToAppear() { + var commonEventSubscribeInfo = { + events: ["on_target_change"] + } + function subscriberCallback(err, data) { + console.info(LOG + "====>Target subscriberCallback start"); + console.info(LOG + "====>Target receive event err:" + JSON.stringify(err)); + console.info(LOG + "====>Target receive event data:" + JSON.stringify(data)); + excuteAbility(data.data); + console.info(LOG + "====>Target subscriberCallback end"); + } + commonEvent.createSubscriber(commonEventSubscribeInfo).then((subscriber) => { + console.info(LOG + "====> Target createSubscriber Start====") + this.subScriber = subscriber; + commonEvent.subscribe(subscriber, subscriberCallback); + console.info(LOG + "====> Target createSubscriber End====") + }) + console.info("start run testcase!!!!"); + } + + aboutToDisappear() { + console.info('TargetApp aboutToDisappear'); + commonEvent.unsubscribe(this.subScriber); + this.subScriber = undefined; + } + + build() { + Row() { + Column() { + Button('CaptionConfiguration') + .fontSize(15) + .fontWeight(FontWeight.Bold) + .margin(5) + .onClick((e) => { + console.info("CaptionConfiguration onClick") + }) + } + .width('100%') + } + .height('100%') + } +} diff --git a/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/ServiceExtAbility/ServiceExtAbility.ts b/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/ServiceExtAbility/ServiceExtAbility.ts new file mode 100644 index 000000000..0ab1a5fed --- /dev/null +++ b/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/ServiceExtAbility/ServiceExtAbility.ts @@ -0,0 +1,61 @@ +/* + * 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 commonEvent from '@ohos.commonEvent' +import AccessibilityExtensionAbility from '@ohos.application.AccessibilityExtensionAbility' +const logTag = "[xtsLog]" +class ServiceExtAbility extends AccessibilityExtensionAbility { + onConnect() { + const context = this.context; + console.info(logTag + "AccessibilityAll onAbilityConnected"); + var commonEventSubscribeInfo = { + events: ["on_assist_change", "execute_accessibility_event"] + } + + function subscriberCallback(err, data) { + console.info(logTag + "AccessibilityALLD subscriberCallback start"); + console.info(logTag + "AccessibilityALLD receive event err:" + JSON.stringify(err)); + console.info(logTag + "AccessibilityALLD receive event data:" + JSON.stringify(data)); + console.info(logTag + "AccessibilityALLD subscriberCallback end"); + } + + var subscriber + commonEvent.createSubscriber(commonEventSubscribeInfo).then(function (data) { + console.info(logTag + " AccessibilityALLD createSubscriber Start====") + subscriber = data; + commonEvent.subscribe(subscriber, subscriberCallback); + console.info(logTag + " AccessibilityALLD createSubscriber End====") + }) + console.info(logTag + " AccessibilityALLD onShow End====") + } + + onAccessibilityEvent(accessibilityEvent) { + printAccessibilityEvent(accessibilityEvent); + return true; + } + + onKeyEvent(keyEvent) { + console.info(" onKeyEvent"); + console.info(logTag + "onKeyEvent KeyInterception AccessibilityAllD: " + JSON.stringify(keyEvent)); + return true; + } +} + +const printAccessibilityEvent = (accessibilityEvent) => { + console.info(logTag + "AccessibilityAllD onAccessibilityEvent Start"); + console.info(logTag + "AccessibilityAllD onAccessibilityEvent accessibilityEvent=" + JSON.stringify(accessibilityEvent)); + console.info(logTag + "AccessibilityAllD onAccessibilityEvent End"); +} + +export default ServiceExtAbility diff --git a/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/TestAbility/TestAbility.ts b/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/TestAbility/TestAbility.ts new file mode 100644 index 000000000..301aaf609 --- /dev/null +++ b/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/TestAbility/TestAbility.ts @@ -0,0 +1,45 @@ +import Ability from '@ohos.application.Ability' +import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry' +import { Hypium } from '@ohos/hypium' +import testsuite from '../test/List.test' + +export default class TestAbility extends Ability { + onCreate(want, launchParam) { + console.log('TestAbility onCreate') + var abilityDelegator: any + abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator() + var abilityDelegatorArguments: any + abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments() + console.info('start run testcase!!!') + Hypium.hypiumTest(abilityDelegator, abilityDelegatorArguments, testsuite) + } + + 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/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/TestAbility/pages/index.ets b/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/TestAbility/pages/index.ets new file mode 100644 index 000000000..733600abc --- /dev/null +++ b/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/TestAbility/pages/index.ets @@ -0,0 +1,34 @@ +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/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts b/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts new file mode 100644 index 000000000..aa8066518 --- /dev/null +++ b/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts @@ -0,0 +1,64 @@ +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.myapplicationxtsd.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/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/test/CaptionConfiguration.test.ets b/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/test/CaptionConfiguration.test.ets new file mode 100644 index 000000000..2c179bbf9 --- /dev/null +++ b/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/test/CaptionConfiguration.test.ets @@ -0,0 +1,747 @@ +/* + * Copyright (c) 2022 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +import { describe, beforeAll, beforeEach, afterAll, it, expect } from '@ohos/hypium' +import commonEvent from '@ohos.commonEvent' +import accessibility from '@ohos.accessibility'; +import config from '@ohos.accessibility.config'; +const LOG = "[xtsLog]" +const START_TIMEOUT = 5000; + +const CaptionConfigurationOn = (logTag, captionType) => { + let captionsManager = accessibility.getCaptionsManager(); + if (!captionsManager) { + console.info(logTag + " captionsManager is undefined"); + return; + } + captionsManager.on(captionType, (res) => { + console.info(logTag + " captionsManager on " + captionType + " res: " + JSON.stringify(res)); + onbackList.push(logTag + "_on_success") + console.info(logTag + "_on_success"); + }); +} + +const CaptionConfigurationOff = (logTag, captionType) => { + let captionsManager = accessibility.getCaptionsManager(); + if (!captionsManager) { + console.info(logTag + " captionsManager is undefined"); + return; + } + captionsManager.off(captionType, (res) => { + console.info(logTag + " captionsManager off " + captionType + " res: " + JSON.stringify(res)); + }); +} + +const captionOn = (logTag, caseName) => { + config.captions.on((res) => { + console.info(logTag + " captionOn res = " + JSON.stringify(res)); + console.info(logTag + "_on_success"); + onbackList.push(caseName + "_on_success") + }); +} + +const captionOff = (logTag, captionType) => { + config.captions.off((res) => { + console.info(logTag + " caption off " + captionType + " res: " + JSON.stringify(res)); + }); +} + +const captionStyleOn = (logTag, caseName) => { + config.captionsStyle.on((res) => { + console.info(logTag + " captionsStyle On res = " + JSON.stringify(res)); + console.info(logTag + "_on_success"); + onbackList.push(caseName + "_on_success") + }); +} + +const captionStyleOff = (logTag, captionType) => { + config.captionsStyle.off((res) => { + console.info(logTag + " captionsStyle off " + captionType + " res: " + JSON.stringify(res)); + }); +} + +const excuteCase = (caseNamePara) => { + console.info(LOG + 'AccessibleEventTest excuteCase: ' + caseNamePara); + + function publishCallback(err) { + console.info(LOG + caseNamePara + "on_target_change publish call back result:" + JSON.stringify(err)); + } + + var commonEventPublishData = { + data: caseNamePara + "_AccessibilityApp_start" + } + commonEvent.publish("on_target_change", commonEventPublishData, publishCallback); +} +var backList = [] +let subScriber = undefined; +var onbackList = [] +export default function CaptionConfigurationTest() { + describe('ActsCaptionConfigurationTest', function () { + beforeEach(async function (done) { + console.info(LOG + 'ActsCaptionConfigurationTest: beforeEach'); + setTimeout(() => { + done(); + }, 3000); + }); + beforeAll(async function (done) { + console.info(LOG + 'ActsCaptionConfigurationTest: beforeAll'); + + subScriber = await commonEvent.createSubscriber({ + events: ['on_target_change_extra'] + }); + console.info(LOG + 'ActsCaptionConfigurationTest beforeAll subscribe send:' + JSON.stringify(subScriber)); + + commonEvent.subscribe(subScriber, (err, data) => { + console.info(LOG + ' ActsCaptionConfigurationTest beforeAll subscribe data:' + JSON.stringify(data)); + if (data.data) { + console.info(LOG + " ActsCaptionConfigurationTest CallBack: " + data.data); + backList.push(data.data) + } + }); + setTimeout(done(), START_TIMEOUT); + }); + + afterAll(async function (done) { + console.info(LOG + 'ActsCaptionConfigurationTest: afterAll'); + setTimeout(function () { + commonEvent.unsubscribe(subScriber); + config.captions.set(false); + let captionsStyle: accessibility.CaptionsStyle = {"fontFamily":"default","fontScale":0,"fontColor":"#000000ff","fontEdgeType":"none","backgroundColor":"#000000ff","windowColor":"#000000ff"}; + config.captionsStyle.set(captionsStyle); + done(); + }, 10000); + }); + + /** + * @tc.number: CaptionConfiguration_0010 + * @tc.name: Call api:getcaptionsmanager() to set the caption parameter. + * @tc.desc: Call api:getcaptionsmanager() to set the caption parameter. + */ + it('CaptionConfiguration_0010', 1, async function (done) { + const caseName = "CaptionConfiguration_0010"; + const logF = LOG + caseName; + setTimeout(() => { + CaptionConfigurationOn(caseName, 'enableChange') + }, 1000); + setTimeout(() => { + excuteCase(caseName); + }, 3000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + var isSucceedOnBack: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + if (onbackList.indexOf(caseName + '_on_success') !== -1) { + isSucceedOnBack = true; + } + expect(isSucceedTarget && isSucceedOnBack).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget && isSucceedOnBack)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0020 + * @tc.name: Call api:getcaptionsmanager() to set the caption parameter. + * @tc.desc: Call api:getcaptionsmanager() to set the caption parameter. + */ + it('CaptionConfiguration_0020', 1, async function (done) { + const caseName = "CaptionConfiguration_0020"; + const logF = LOG + caseName; + CaptionConfigurationOn(caseName, 'styleChange') + setTimeout(() => { + excuteCase(caseName); + }, 3000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + var isSucceedOnBack: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + if (onbackList.indexOf(caseName + '_on_success') !== -1) { + isSucceedOnBack = true; + } + expect(isSucceedTarget && isSucceedOnBack).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget && isSucceedOnBack)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0030 + * @tc.name: Call api:getcaptionsmanager() to set the caption parameter. + * @tc.desc: Call api:getcaptionsmanager() to set the caption parameter. + */ + it('CaptionConfiguration_0030', 1, async function (done) { + const caseName = "CaptionConfiguration_0030"; + const logF = LOG + caseName; + setTimeout(() => { + CaptionConfigurationOn(caseName, 'enableChange'); + }, 1000); + setTimeout(() => { + CaptionConfigurationOff(caseName, 'enableChange') + }, 2000); + setTimeout(() => { + excuteCase(caseName); + }, 3000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + var isSucceedOnBack: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + if (onbackList.indexOf(caseName + '_on_success') == -1) { + isSucceedOnBack = true; + } + expect(isSucceedTarget && isSucceedOnBack).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget && isSucceedOnBack)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0040 + * @tc.name: Call api:getcaptionsmanager() to set the caption parameter. + * @tc.desc: Call api:getcaptionsmanager() to set the caption parameter. + */ + it('CaptionConfiguration_0040', 1, async function (done) { + const caseName = "CaptionConfiguration_0040"; + const logF = LOG + caseName; + setTimeout(() => { + CaptionConfigurationOn(caseName, 'styleChange'); + }, 1000); + setTimeout(() => { + CaptionConfigurationOff(caseName, 'styleChange') + }, 2000); + setTimeout(() => { + excuteCase(caseName); + }, 3000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + var isSucceedOnBack: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + if (onbackList.indexOf(caseName + '_on_success') == -1) { + isSucceedOnBack = true; + } + expect(isSucceedTarget && isSucceedOnBack).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget && isSucceedOnBack)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0050 + * @tc.name: Call api:getcaptionsmanager() to set the caption parameter. + * @tc.desc: Call api:getcaptionsmanager() to set the caption parameter. + */ + it('CaptionConfiguration_0050', 1, async function (done) { + const caseName = "CaptionConfiguration_0050"; + const logF = LOG + caseName; + setTimeout(() => { + excuteCase(caseName); + }, 2000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + expect(isSucceedTarget).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0060 + * @tc.name: Call api:getcaptionsmanager() to set the caption parameter. + * @tc.desc: Call api:getcaptionsmanager() to set the caption parameter. + */ + it('CaptionConfiguration_0060', 1, async function (done) { + const caseName = "CaptionConfiguration_0060"; + const logF = LOG + caseName; + setTimeout(() => { + excuteCase(caseName); + }, 2000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + expect(isSucceedTarget).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0070 + * @tc.name: Call api:getcaptionsmanager() to set the caption parameter. + * @tc.desc: Call api:getcaptionsmanager() to set the caption parameter. + */ + it('CaptionConfiguration_0070', 1, async function (done) { + const caseName = "CaptionConfiguration_0070"; + const logF = LOG + caseName; + setTimeout(() => { + excuteCase(caseName); + }, 2000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + expect(isSucceedTarget).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0080 + * @tc.name: Call api:getcaptionsmanager() to set the caption parameter. + * @tc.desc: Call api:getcaptionsmanager() to set the caption parameter. + */ + it('CaptionConfiguration_0080', 1, async function (done) { + const caseName = "CaptionConfiguration_0080"; + const logF = LOG + caseName; + setTimeout(() => { + excuteCase(caseName); + }, 2000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + expect(isSucceedTarget).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0090 + * @tc.name: Call api:getcaptionsmanager() to set the caption parameter. + * @tc.desc: Call api:getcaptionsmanager() to set the caption parameter. + */ + it('CaptionConfiguration_0090', 1, async function (done) { + const caseName = "CaptionConfiguration_0090"; + const logF = LOG + caseName; + setTimeout(() => { + excuteCase(caseName); + }, 2000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + expect(isSucceedTarget).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0100 + * @tc.name: Call api:getcaptionsmanager() to set the caption parameter. + * @tc.desc: Call api:getcaptionsmanager() to set the caption parameter. + */ + it('CaptionConfiguration_0100', 1, async function (done) { + const caseName = "CaptionConfiguration_0100"; + const logF = LOG + caseName; + setTimeout(() => { + excuteCase(caseName); + }, 2000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + expect(isSucceedTarget).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0110 + * @tc.name: Call api:getcaptionsmanager() to set the caption parameter. + * @tc.desc: Call api:getcaptionsmanager() to set the caption parameter. + */ + it('CaptionConfiguration_0110', 1, async function (done) { + const caseName = "CaptionConfiguration_0110"; + const logF = LOG + caseName; + setTimeout(() => { + excuteCase(caseName); + }, 2000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + expect(isSucceedTarget).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0120 + * @tc.name: Call api:getcaptionsmanager() to set the caption parameter. + * @tc.desc: Call api:getcaptionsmanager() to set the caption parameter. + */ + it('CaptionConfiguration_0120', 1, async function (done) { + const caseName = "CaptionConfiguration_0120"; + const logF = LOG + caseName; + setTimeout(() => { + CaptionConfigurationOn(caseName, undefined); + }, 1000); + setTimeout(() => { + excuteCase(caseName); + }, 2000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + var isSucceedOnBack: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') == -1) { + isSucceedTarget = true; + } + if (onbackList.indexOf(caseName + '_on_success') == -1) { + isSucceedOnBack = true; + } + expect(isSucceedTarget && isSucceedOnBack).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget && isSucceedOnBack)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0130 + * @tc.name: Call api:getcaptionsmanager() to set the caption parameter. + * @tc.desc: Call api:getcaptionsmanager() to set the caption parameter. + */ + it('CaptionConfiguration_0130', 1, async function (done) { + const caseName = "CaptionConfiguration_0130"; + const logF = LOG + caseName; + setTimeout(() => { + excuteCase(caseName); + }, 2000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + expect(isSucceedTarget).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0140 + * @tc.name: Call api:config to set the captions parameter. + * @tc.desc: Call api:config to set the captions parameter. + */ + it('CaptionConfiguration_0140', 1, async function (done) { + const caseName = "CaptionConfiguration_0140"; + const logF = LOG + caseName; + setTimeout(() => { + captionOn(logF, caseName) + }, 1000); + setTimeout(() => { + excuteCase(caseName); + }, 3000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + var isSucceedOnBack: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + if (onbackList.indexOf(caseName + '_on_success') !== -1) { + isSucceedOnBack = true; + } + expect(isSucceedTarget && isSucceedOnBack).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget && isSucceedOnBack)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0150 + * @tc.name: Call api:config to set the captionsStyle parameter. + * @tc.desc: Call api:config to set the captionsStyle parameter. + */ + it('CaptionConfiguration_0150', 1, async function (done) { + const caseName = "CaptionConfiguration_0150"; + const logF = LOG + caseName; + captionStyleOn(logF, caseName) + setTimeout(() => { + excuteCase(caseName); + }, 3000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + var isSucceedOnBack: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + if (onbackList.indexOf(caseName + '_on_success') !== -1) { + isSucceedOnBack = true; + } + expect(isSucceedTarget && isSucceedOnBack).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget && isSucceedOnBack)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0160 + * @tc.name: Call api:config to set the captions parameter. + * @tc.desc: Call api:config to set the captions parameter. + */ + it('CaptionConfiguration_0160', 1, async function (done) { + const caseName = "CaptionConfiguration_0160"; + const logF = LOG + caseName; + setTimeout(() => { + captionOn(logF, caseName) + }, 1000); + setTimeout(() => { + captionOff(logF, caseName) + }, 2000); + setTimeout(() => { + excuteCase(caseName); + }, 3000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + var isSucceedOnBack: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + if (onbackList.indexOf(caseName + '_on_success') == -1) { + isSucceedOnBack = true; + } + expect(isSucceedTarget && isSucceedOnBack).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget && isSucceedOnBack)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0170 + * @tc.name: Call api:config to set the captionsStyle parameter. + * @tc.desc: Call api:config to set the captionsStyle parameter. + */ + it('CaptionConfiguration_0170', 1, async function (done) { + const caseName = "CaptionConfiguration_0170"; + const logF = LOG + caseName; + setTimeout(() => { + captionStyleOn(logF, caseName); + }, 1000); + setTimeout(() => { + captionStyleOff(logF, caseName) + }, 2000); + setTimeout(() => { + excuteCase(caseName); + }, 3000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + var isSucceedOnBack: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + if (onbackList.indexOf(caseName + '_on_success') == -1) { + isSucceedOnBack = true; + } + expect(isSucceedTarget && isSucceedOnBack).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget && isSucceedOnBack)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0180 + * @tc.name: Call api:config to set the captionsStyle parameter. + * @tc.desc: Call api:config to set the captionsStyle parameter. + */ + it('CaptionConfiguration_0180', 1, async function (done) { + const caseName = "CaptionConfiguration_0180"; + const logF = LOG + caseName; + setTimeout(() => { + excuteCase(caseName); + }, 2000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + expect(isSucceedTarget).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0190 + * @tc.name: Call api:config to set the captionsStyle parameter. + * @tc.desc: Call api:config to set the captionsStyle parameter. + */ + it('CaptionConfiguration_0190', 1, async function (done) { + const caseName = "CaptionConfiguration_0190"; + const logF = LOG + caseName; + setTimeout(() => { + excuteCase(caseName); + }, 2000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + expect(isSucceedTarget).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0200 + * @tc.name: Call api:config to set the captionsStyle parameter. + * @tc.desc: Call api:config to set the captionsStyle parameter. + */ + it('CaptionConfiguration_0200', 1, async function (done) { + const caseName = "CaptionConfiguration_0200"; + const logF = LOG + caseName; + setTimeout(() => { + excuteCase(caseName); + }, 2000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + expect(isSucceedTarget).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0210 + * @tc.name: Call api:config to set the captionsStyle parameter. + * @tc.desc: Call api:config to set the captionsStyle parameter. + */ + it('CaptionConfiguration_0210', 1, async function (done) { + const caseName = "CaptionConfiguration_0210"; + const logF = LOG + caseName; + setTimeout(() => { + excuteCase(caseName); + }, 2000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + expect(isSucceedTarget).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0220 + * @tc.name: Call api:config to set the captionsStyle parameter. + * @tc.desc: Call api:config to set the captionsStyle parameter. + */ + it('CaptionConfiguration_0220', 1, async function (done) { + const caseName = "CaptionConfiguration_0220"; + const logF = LOG + caseName; + setTimeout(() => { + excuteCase(caseName); + }, 2000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + expect(isSucceedTarget).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0230 + * @tc.name: Call api:config to set the captionsStyle parameter. + * @tc.desc: Call api:config to set the captionsStyle parameter. + */ + it('CaptionConfiguration_0230', 1, async function (done) { + const caseName = "CaptionConfiguration_0230"; + const logF = LOG + caseName; + setTimeout(() => { + excuteCase(caseName); + }, 2000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + expect(isSucceedTarget).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0240 + * @tc.name: Call api:config to set the captionsStyle parameter. + * @tc.desc: Call api:config to set the captionsStyle parameter. + */ + it('CaptionConfiguration_0240', 1, async function (done) { + const caseName = "CaptionConfiguration_0240"; + const logF = LOG + caseName; + setTimeout(() => { + excuteCase(caseName); + }, 2000); + setTimeout(() => { + var isSucceedTarget: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + expect(isSucceedTarget).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget)); + done(); + }, 8000); + }); + + /** + * @tc.number: CaptionConfiguration_0260 + * @tc.name: Call api:config to set the captionsStyle parameter. + * @tc.desc: Call api:config to set the captionsStyle parameter. + */ + it('CaptionConfiguration_0260', 1, async function (done) { + const caseName = "CaptionConfiguration_0260"; + const logF = LOG + caseName; + excuteCase(caseName); + setTimeout(() => { + var isSucceedTarget: boolean = false; + if (backList.indexOf(caseName + '_on_target_change_extra_success') !== -1) { + isSucceedTarget = true; + } + expect(isSucceedTarget).assertEqual(true); + console.info(logF + ' isSucceed : ' + (isSucceedTarget)); + done(); + }, 8000); + }); + + + }) +} diff --git a/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/test/List.test.ets b/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/test/List.test.ets new file mode 100644 index 000000000..736fd1521 --- /dev/null +++ b/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/ets/test/List.test.ets @@ -0,0 +1,19 @@ +/* + * 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 CaptionConfigurationTest from './CaptionConfiguration.test' + +export default function testsuite() { + CaptionConfigurationTest() +} \ No newline at end of file diff --git a/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/module.json b/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/module.json new file mode 100644 index 000000000..f136cb907 --- /dev/null +++ b/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/module.json @@ -0,0 +1,62 @@ +{ + "module": { + "name": "phone", + "type": "entry", + "srcEntrance": "./ets/Application/AbilityStage.ts", + "description": "$string:entry_desc", + "mainElement": "MainAbility", + "deviceTypes": [ + "phone", + "tablet" + ], + "deliveryWithInstall": true, + "installationFree": false, + "pages": "$profile:main_pages", + "uiSyntax": "ets", + "abilities": [ + { + "name": "com.example.myapplicationxtsd.MainAbility", + "srcEntrance": "./ets/MainAbility/MainAbility.ts", + "description": "$string:entry_desc", + "icon": "$media:icon", + "label": "$string:entry_desc", + "visible": true, + "skills": [ + { + "entities": [ + "entity.system.home" + ], + "actions": [ + "action.system.home" + ] + } + ] + } + ], + "extensionAbilities": [ + { + "name": "ServiceExtAbility", + "srcEntrance": "./ets/ServiceExtAbility/ServiceExtAbility.ts", + "label": "$string:entry_desc", + "description": "$string:entry_desc", + "type": "accessibility", + "metadata": [ + { + "name": "ohos.accessibleability", + "resource": "$profile:accessibility_config" + } + ], + "permissions": ["ohos.permission.GET_BUNDLE_INFO"] + }], + "requestPermissions": [ + { + "name": "ohos.permission.SYSTEM_FLOAT_WINDOW", + "reason": "need use ohos.permission.SYSTEM_FLOAT_WINDOW" + }, + { + "name": "ohos.permission.CAPTURE_SCREEN", + "reason": "need use ohos.permission.SYSTEM_FLOAT_WINDOW" + } + ] + } +} \ No newline at end of file diff --git a/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/resources/base/element/string.json b/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/resources/base/element/string.json new file mode 100644 index 000000000..e533d8e9d --- /dev/null +++ b/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/resources/base/element/string.json @@ -0,0 +1,20 @@ +{ + "string": [ + { + "name": "entry_desc", + "value": "9xts" + }, + { + "name": "MainAbility_desc", + "value": "9xts" + }, + { + "name": "MainAbility_label", + "value": "9xts" + }, + { + "name": "description_serviceability", + "value": "Accessiable" + } + ] +} \ No newline at end of file diff --git a/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/resources/base/media/icon.png b/barrierfree/accessibletest/actscaptionconfigurationtest/entry/src/main/resources/base/media/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..ce307a8827bd75456441ceb57d530e4c8d45d36c GIT binary patch literal 6790 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 mCl*fp;NAt}BL{ZRsww--|AHBR