diff --git a/arkui/ace_ets_components_ux/BUILD.gn b/arkui/ace_ets_components_ux/BUILD.gn index d5a1e1ae5835a66f8ac2f01a693137b322c070f1..99e780d6a7e76f83d61b6c750376c80db7374c92 100644 --- a/arkui/ace_ets_components_ux/BUILD.gn +++ b/arkui/ace_ets_components_ux/BUILD.gn @@ -22,6 +22,7 @@ group("componentUxTest") { "ace_ets_component_sidebar:ActsAceSideBarTest", "ace_ets_component_tabs:ActsAceTabsTest", "ace_ets_component_text:ActsAceTextTest", + "ace_ets_component_textpicker:ActsAceTextPickerTest", ] } } diff --git a/arkui/ace_ets_components_ux/ace_ets_component_textpicker/AppScope/app.json b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/AppScope/app.json new file mode 100644 index 0000000000000000000000000000000000000000..9b225e81a3d95cc698bb7966731d65d5132a79f9 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/AppScope/app.json @@ -0,0 +1,19 @@ +{ + "app": { + "bundleName": "com.example.acetextpickertest", + "vendor": "example", + "versionCode": 1000000, + "versionName": "1.0.0", + "icon": "$media:app_icon", + "label": "$string:app_name", + "distributedNotificationEnabled": true, + "keepAlive": true, + "singleUser": true, + "minAPIVersion": 10, + "targetAPIVersion": 10, + "car": { + "apiCompatibleVersion": 10, + "singleUser": false + } + } +} diff --git a/arkui/ace_ets_components_ux/ace_ets_component_textpicker/AppScope/resources/base/element/string.json b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/AppScope/resources/base/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..30af7cfee6766dda361b893d1565490dc145fdf0 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/AppScope/resources/base/element/string.json @@ -0,0 +1,8 @@ +{ + "string":[ + { + "name":"app_name", + "value":"MyApplication" + } + ] +} \ No newline at end of file diff --git a/arkui/ace_ets_components_ux/ace_ets_component_textpicker/AppScope/resources/base/media/app_icon.png b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/AppScope/resources/base/media/app_icon.png new file mode 100644 index 0000000000000000000000000000000000000000..ce307a8827bd75456441ceb57d530e4c8d45d36c Binary files /dev/null and b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/AppScope/resources/base/media/app_icon.png differ diff --git a/arkui/ace_ets_components_ux/ace_ets_component_textpicker/BUILD.gn b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/BUILD.gn new file mode 100644 index 0000000000000000000000000000000000000000..7afe2e20889181f93c5e8d108947ef72eea58f97 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/BUILD.gn @@ -0,0 +1,43 @@ +# Copyright (c) 2023 Huawei Device Co., Ltd. +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +import("//test/xts/tools/build/suite.gni") + +ohos_js_hap_suite("ActsAceTextPickerTest") { + hap_profile = "src/main/module.json" + js_build_mode = "debug" + deps = [ + ":ace_ets_component_textpicker_js_assets", + ":ace_ets_component_textpicker_resources", + ] + ets2abc = true + certificate_profile = "signature/openharmony_sx.p7b" + hap_name = "ActsAceTextPickerTest" + part_name = "ace_engine" + subsystem_name = "arkui" +} + +ohos_app_scope("ace_ets_component_textpicker_profile") { + app_profile = "AppScope/app.json" + sources = [ "AppScope/resources" ] +} + +ohos_js_assets("ace_ets_component_textpicker_js_assets") { + source_dir = "src/main/ets" +} + +ohos_resources("ace_ets_component_textpicker_resources") { + sources = [ "src/main/resources" ] + deps = [ ":ace_ets_component_textpicker_profile" ] + hap_profile = "src/main/module.json" +} diff --git a/arkui/ace_ets_components_ux/ace_ets_component_textpicker/Test.json b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/Test.json new file mode 100644 index 0000000000000000000000000000000000000000..264b4aed77f2680a1d35a191a65fc0dfe0a632d3 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/Test.json @@ -0,0 +1,26 @@ +{ + "description": "Configuration for hjunit demo Tests", + "driver": { + "type": "OHJSUnitTest", + "test-timeout": "600000", + "bundle-name": "com.example.acetextpickertest", + "module-name": "phone", + "shell-timeout": "600000", + "testcase-timeout": 70000 + }, + "kits": [{ + "test-file-name": [ + "ActsAceTextPickerTest.hap" + ], + "type": "AppInstallKit", + "cleanup-apps": true + }, + { + "type": "ShellKit", + "run-command": [ + "power-shell wakeup", + "power-shell setmode 602" + ] + } + ] +} \ No newline at end of file diff --git a/arkui/ace_ets_components_ux/ace_ets_component_textpicker/signature/openharmony_sx.p7b b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/signature/openharmony_sx.p7b new file mode 100644 index 0000000000000000000000000000000000000000..fb7bf259a4ed090ce0b1541592c5bee473c7fe0d Binary files /dev/null and b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/signature/openharmony_sx.p7b differ diff --git a/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/TestAbility/TestAbility.ets b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/TestAbility/TestAbility.ets new file mode 100644 index 0000000000000000000000000000000000000000..fc4e92b3ab3bfcf55c6562ba538d672cfa9458f0 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/TestAbility/TestAbility.ets @@ -0,0 +1,64 @@ +/* + * Copyright (c) 2023 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +import hilog from '@ohos.hilog'; +import Ability from '@ohos.app.ability.UIAbility' +import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry' +import testsuite from '../test/List.test' +import Window from '@ohos.window' + +export default class TestAbility extends Ability { + onCreate(want, launchParam) { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onCreate'); + hilog.info(0x0000, 'testTag', '%{public}s', 'want param:' + JSON.stringify(want) ?? ''); + hilog.info(0x0000, 'testTag', '%{public}s', 'launchParam:'+ JSON.stringify(launchParam) ?? ''); + } + + onDestroy() { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onDestroy'); + } + + onWindowStageCreate(windowStage: Window.WindowStage) { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onWindowStageCreate'); + windowStage.loadContent('TestAbility/pages/Index', (err, data) => { + if (err.code) { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.ERROR); + hilog.error(0x0000, 'testTag', 'Failed to load the content. Cause: %{public}s', JSON.stringify(err) ?? ''); + return; + } + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', 'Succeeded in loading the content. Data: %{public}s', + JSON.stringify(data) ?? ''); + }); + } + + onWindowStageDestroy() { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onWindowStageDestroy'); + } + + onForeground() { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onForeground'); + } + + onBackground() { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'TestAbility onBackground'); + } +} diff --git a/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/TestAbility/pages/Index.ets b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/TestAbility/pages/Index.ets new file mode 100644 index 0000000000000000000000000000000000000000..7da329e19bd60e5948fd381b6eb9082423ec3b40 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/TestAbility/pages/Index.ets @@ -0,0 +1,76 @@ +/* + * Copyright (c) 2023 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +import events_emitter from '@ohos.events.emitter'; +import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry'; +import { Hypium } from '@ohos/hypium'; +import hilog from '@ohos.hilog'; +import testsuite from '../../test/List.test' +@Entry +@Component +struct TextPickerExample { + + @State select: number = 1 + private multipleColumns: TextPickerRangeContent[] = [{icon: $r('app.media.icon'), text:'apple1'}, {icon:$r('app.media.icon'), text:'orange2'}, {icon:$r('app.media.icon'), text:'peach3'}, + {icon:$r('app.media.icon'), text:'grape4'}, {icon:$r('app.media.icon'), text:'grape5'}] + + @State disappearTextStyle: PickerTextStyle = {color:Color.Black,font:{size:8,weight:FontWeight.Lighter}} + @State textStyle: PickerTextStyle = {color:Color.Red,font:{size:'10px',weight:FontWeight.Normal}} + @State selectedTextStyle: PickerTextStyle = {color:Color.Blue,font:{size:'20px',weight:FontWeight.Bold}} + + + private stateChangCallBack = (eventData) => { + console.info("select page state change called:" + JSON.stringify(eventData)); + if (eventData != null) { + if (eventData.data.disappearTextStyle != null) { + this.disappearTextStyle = JSON.parse(eventData.data.disappearTextStyle); + } + if (eventData.data.textStyle != null) { + this.textStyle = JSON.parse(eventData.data.textStyle); + } + if (eventData.data.selectedTextStyle != null) { + this.selectedTextStyle = JSON.parse(eventData.data.selectedTextStyle); + } + } + } + + aboutToAppear(){ + var stateChangeEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + events_emitter.on(stateChangeEvent, this.stateChangCallBack); + + var abilityDelegator: any + abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator() + var abilityDelegatorArguments: any + abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments() + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'start run testcase!!!'); + Hypium.hypiumTest(abilityDelegator, abilityDelegatorArguments, testsuite) + } + + build() { + Column() { + TextPicker({range: this.multipleColumns,selected: this.select}) + .disappearTextStyle(this.disappearTextStyle) + .textStyle(this.textStyle) + .selectedTextStyle(this.selectedTextStyle) + .key('textPicker') + .onChange((value: string, index: number) => { + console.info('Picker item changed, value: ' + value + ', index: ' + index) + }) + } + } +} diff --git a/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts new file mode 100644 index 0000000000000000000000000000000000000000..d6c662824093f9339085214d247c6247faa86ae9 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts @@ -0,0 +1,85 @@ +/* + * Copyright (c) 2023 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +import hilog from '@ohos.hilog'; +import TestRunner from '@ohos.application.testRunner' +import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry' + +var abilityDelegator = undefined +var abilityDelegatorArguments = undefined + +function translateParamsToString(parameters) { + const keySet = new Set([ + '-s class', '-s notClass', '-s suite', '-s it', + '-s level', '-s testType', '-s size', '-s timeout', + '-s dryRun' + ]) + let targetParams = ''; + for (const key in parameters) { + if (keySet.has(key)) { + targetParams = `${targetParams} ${key} ${parameters[key]}` + } + } + return targetParams.trim() +} + +async function onAbilityCreateCallback() { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'onAbilityCreateCallback'); +} + +async function addAbilityMonitorCallback(err: any) { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', 'addAbilityMonitorCallback : %{public}s', JSON.stringify(err) ?? ''); +} + +export default class OpenHarmonyTestRunner implements TestRunner { + constructor() { + } + + onPrepare() { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner OnPrepare '); + } + + async onRun() { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner onRun run'); + abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments() + abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator() + var testAbilityName = abilityDelegatorArguments.bundleName + '.TestAbility' + let lMonitor = { + abilityName: testAbilityName, + onAbilityCreate: onAbilityCreateCallback, + }; + abilityDelegator.addAbilityMonitor(lMonitor, addAbilityMonitorCallback) + var cmd = 'aa start -d 0 -a TestAbility' + ' -b ' + abilityDelegatorArguments.bundleName + cmd += ' '+translateParamsToString(abilityDelegatorArguments.parameters) + var debug = abilityDelegatorArguments.parameters['-D'] + if (debug == 'true') + { + cmd += ' -D' + } + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', 'cmd : %{public}s', cmd); + abilityDelegator.executeShellCommand(cmd, + (err: any, d: any) => { + hilog.isLoggable(0x0000, 'testTag', hilog.LogLevel.INFO); + hilog.info(0x0000, 'testTag', 'executeShellCommand : err : %{public}s', JSON.stringify(err) ?? ''); + hilog.info(0x0000, 'testTag', 'executeShellCommand : data : %{public}s', d.stdResult ?? ''); + hilog.info(0x0000, 'testTag', 'executeShellCommand : data : %{public}s', d.exitCode ?? ''); + }) + hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner onRun end'); + } +} \ No newline at end of file diff --git a/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/test/List.test.ets b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/test/List.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..4ad13128ddb492654ba723f3f5cd0895f3a4ae71 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/test/List.test.ets @@ -0,0 +1,20 @@ +/* + * Copyright (c) 2023 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +import textpicker from './TextPicker' + +export default function testsuite() { + textpicker() + +} \ No newline at end of file diff --git a/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/test/TextPicker.ets b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/test/TextPicker.ets new file mode 100644 index 0000000000000000000000000000000000000000..59ac1ddd8bb72228540aaf9cfb442bd88775e7d1 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/test/TextPicker.ets @@ -0,0 +1,856 @@ +/* + * Copyright (c) 2023 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +// @ts-nocheck +import { describe, beforeEach, afterEach, it, expect } from '@ohos/hypium' +import events_emitter from '@ohos.events.emitter'; +import Utils from './Utils.ets'; +export default function textpicker() { + describe('ActsAceTextPickerTest', function () { + beforeEach(async function (done) { + await Utils.sleep(2000); + console.info("textPicker beforeEach start"); + done(); + }) + + afterEach(async function (done) { + console.info("textPicker afterEach start"); + try { + var eventData = { + data: { + "disappearTextStyle": {color:Color.Black,font:{size:8,weight:FontWeight.Lighter}}, + "textStyle": {color:Color.Red,font:{size:'10px',weight:FontWeight.Normal}}, + "selectedTextStyle": {color:Color.Blue,font:{size:'20px',weight:FontWeight.Bold}} + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[textPicker_afterEach] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[selectTest_afterEach] change component data error: " + err.message); + } + done(); + }) + + /* + * @tc.number ArkUI_Stage_textpicker_disappearTextStyle_0001 + * @tc.name Tests the disappearTextStyle property of the picker component + * @tc.desc get the default value + */ + it('ArkUI_Stage_textpicker_disappearTextStyle_0001', 0, async function (done) { + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_disappearTextStyle_0001] disappearColor:" + obj.$attrs.disappearTextStyle.color); + expect(obj.$attrs.disappearTextStyle.color).assertEqual('#FF000000'); + expect(obj.$attrs.disappearTextStyle.font.size).assertEqual('8.00fp'); + expect(obj.$attrs.disappearTextStyle.font.weight).assertEqual('FontWeight.Lighter'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_disappearTextStyle_0002 + * @tc.name Tests the disappearTextStyle property of the picker component + * @tc.desc set disappearTextStyle then get the value + */ + it('ArkUI_Stage_textpicker_disappearTextStyle_0002', 0, async function (done) { + let value = {color:Color.Black,font:{size:8,weight:FontWeight.Bolder}} + try { + var eventData = { + data: { + "disappearTextStyle":JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_disappearTextStyle_0002] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_disappearTextStyle_0002] change component data error: " + err.message); + } + await Utils.sleep(3000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.error("[ArkUI_Stage_textpicker_disappearTextStyle_0002] disappearColor:" + obj.$attrs.disappearTextStyle.color); + expect(obj.$attrs.disappearTextStyle.color).assertEqual('#FF000000'); + expect(obj.$attrs.disappearTextStyle.font.size).assertEqual('8.00fp'); + expect(obj.$attrs.disappearTextStyle.font.weight).assertEqual('FontWeight.Bolder'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_disappearTextStyle_0003 + * @tc.name Tests the disappearTextStyle property of the picker component + * @tc.desc set disappearTextStyle then get the value + */ + it('ArkUI_Stage_textpicker_disappearTextStyle_0003', 0, async function (done) { + let value = {color:0x808080,font:{size:8,weight:100}} + try { + var eventData = { + data: { + "disappearTextStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_disappearTextStyle_0003] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_disappearTextStyle_0003] change component data error: " + err.message); + } + await Utils.sleep(2000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_disappearTextStyle_0003] disappearColor:" + obj.$attrs.disappearTextStyle.color); + expect(obj.$attrs.disappearTextStyle.color).assertEqual('#FF808080'); + expect(obj.$attrs.disappearTextStyle.font.size).assertEqual('8.00fp'); + expect(obj.$attrs.disappearTextStyle.font.weight).assertEqual('100'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_disappearTextStyle_0004 + * @tc.name Tests the disappearTextStyle property of the picker component + * @tc.desc set disappearTextStyle then get the value + */ + it('ArkUI_Stage_textpicker_disappearTextStyle_0004', 0, async function (done) { + let value = {color:'#ff0000',font:{size:'1px',weight:'700'}} + try { + var eventData = { + data: { + "disappearTextStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_disappearTextStyle_0004] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_disappearTextStyle_0004] change component data error: " + err.message); + } + await Utils.sleep(2000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_disappearTextStyle_0004] disappearColor:" + obj.$attrs.disappearTextStyle.color); + expect(obj.$attrs.disappearTextStyle.color).assertEqual('#FFFF0000'); + expect(obj.$attrs.disappearTextStyle.font.size).assertEqual('1.00px'); + expect(obj.$attrs.disappearTextStyle.font.weight).assertEqual('700'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_disappearTextStyle_0005 + * @tc.name Tests the disappearTextStyle property of the picker component + * @tc.desc set disappearTextStyle then get the value + */ + it('ArkUI_Stage_textpicker_disappearTextStyle_0005', 0, async function (done) { + let value = {color:Color.Green,font:{size:30,weight:450}} + try { + var eventData = { + data: { + "disappearTextStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_disappearTextStyle_0005] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_disappearTextStyle_0005] change component data error: " + err.message); + } + await Utils.sleep(2000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_disappearTextStyle_0005] disappearColor:" + obj.$attrs.disappearTextStyle.color); + expect(obj.$attrs.disappearTextStyle.color).assertEqual('#FF008000'); + expect(obj.$attrs.disappearTextStyle.font.size).assertEqual('30.00fp'); + expect(obj.$attrs.disappearTextStyle.font.weight).assertEqual('FontWeight.Normal'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_disappearTextStyle_0006 + * @tc.name Tests the disappearTextStyle property of the picker component + * @tc.desc set disappearTextStyle then get the value + */ + it('ArkUI_Stage_textpicker_disappearTextStyle_0006', 0, async function (done) { + let value = {color:'#80808g',font:{size:-1,weight:1000}} + try { + var eventData = { + data: { + "disappearTextStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_disappearTextStyle_0006] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_disappearTextStyle_0006] change component data error: " + err.message); + } + await Utils.sleep(2000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_disappearTextStyle_0006] disappearColor:" + obj.$attrs.disappearTextStyle.color); + expect(obj.$attrs.disappearTextStyle.color).assertEqual('#FF182431'); + expect(obj.$attrs.disappearTextStyle.font.size).assertEqual('14.00vp'); + expect(obj.$attrs.disappearTextStyle.font.weight).assertEqual('FontWeight.Normal'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_disappearTextStyle_0007 + * @tc.name Tests the disappearTextStyle property of the picker component + * @tc.desc set disappearTextStyle then get the value + */ + it('ArkUI_Stage_textpicker_disappearTextStyle_0007', 0, async function (done) { + let value = {color:'xxx',font:{size:'xxx',weight:FontWeight.Bold}} + try { + var eventData = { + data: { + "disappearTextStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_disappearTextStyle_0007] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_disappearTextStyle_0007] change component data error: " + err.message); + } + await Utils.sleep(2000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_disappearTextStyle_0007] disappearColor:" + obj.$attrs.disappearTextStyle.color); + expect(obj.$attrs.disappearTextStyle.color).assertEqual('#FF182431'); + expect(obj.$attrs.disappearTextStyle.font.size).assertEqual('14.00vp'); + expect(obj.$attrs.disappearTextStyle.font.weight).assertEqual('FontWeight.Bold'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_disappearTextStyle_0008 + * @tc.name Tests the disappearTextStyle property of the picker component + * @tc.desc set disappearTextStyle then get the value + */ + it('ArkUI_Stage_textpicker_disappearTextStyle_0008', 0, async function (done) { + let value = {color:'rgb(138,43,226)',font:{size:'20vp',weight:900}} + try { + var eventData = { + data: { + "disappearTextStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_disappearTextStyle_0008] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_disappearTextStyle_0008] change component data error: " + err.message); + } + await Utils.sleep(3000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + expect(obj.$attrs.disappearTextStyle.color).assertEqual('#FF8A2BE2'); + expect(obj.$attrs.disappearTextStyle.font.size).assertEqual('20.00vp'); + expect(obj.$attrs.disappearTextStyle.font.weight).assertEqual('900'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_disappearTextStyle_0009 + * @tc.name Tests the disappearTextStyle property of the picker component + * @tc.desc set disappearTextStyle then get the value + */ + it('ArkUI_Stage_textpicker_disappearTextStyle_0009', 0, async function (done) { + let value = {color:'rgb(138,43,226)',font:{size:'15lpx',weight:90}} + try { + var eventData = { + data: { + "disappearTextStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_disappearTextStyle_0009] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_disappearTextStyle_0009] change component data error: " + err.message); + } + await Utils.sleep(3000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + expect(obj.$attrs.disappearTextStyle.color).assertEqual('#FF8A2BE2'); + expect(obj.$attrs.disappearTextStyle.font.size).assertEqual('15.00lpx'); + expect(obj.$attrs.disappearTextStyle.font.weight).assertEqual('FontWeight.Normal'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_textStyle_0001 + * @tc.name Tests the textStyle property of the picker component + * @tc.desc get the default value + */ + it('ArkUI_Stage_textpicker_textStyle_0001', 0, async function (done) { + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_textStyle_0001] disappearColor:" + obj.$attrs.textStyle.color); + expect(obj.$attrs.textStyle.color).assertEqual('#FFFF0000'); + expect(obj.$attrs.textStyle.font.size).assertEqual('10.00px'); + expect(obj.$attrs.textStyle.font.weight).assertEqual('FontWeight.Normal'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_textStyle_0002 + * @tc.name Tests the textStyle property of the picker component + * @tc.desc set textStyle then get the value + */ + it('ArkUI_Stage_textpicker_textStyle_0002', 0, async function (done) { + let value = {color:Color.Red,font:{size:'10px',weight:FontWeight.Bolder}} + try { + var eventData = { + data: { + "textStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_textStyle_0002] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_textStyle_0002] change component data error: " + err.message); + } + await Utils.sleep(3000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.error("[ArkUI_Stage_textpicker_textStyle_0002] disappearColor:" + obj.$attrs.textStyle.color); + expect(obj.$attrs.textStyle.color).assertEqual('#FFFF0000'); + expect(obj.$attrs.textStyle.font.size).assertEqual('10.00px'); + expect(obj.$attrs.textStyle.font.weight).assertEqual('FontWeight.Bolder'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_textStyle_0003 + * @tc.name Tests the textStyle property of the picker component + * @tc.desc set textStyle then get the value + */ + it('ArkUI_Stage_textpicker_textStyle_0003', 0, async function (done) { + let value = {color:0xFF808080,font:{size:'10px',weight:100}} + try { + var eventData = { + data: { + "textStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_textStyle_0003] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_textStyle_0003] change component data error: " + err.message); + } + await Utils.sleep(2000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_textStyle_0003] disappearColor:" + obj.$attrs.textStyle.color); + expect(obj.$attrs.textStyle.color).assertEqual('#FF808080'); + expect(obj.$attrs.textStyle.font.size).assertEqual('10.00px'); + expect(obj.$attrs.textStyle.font.weight).assertEqual('100'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_textStyle_0004 + * @tc.name Tests the textStyle property of the picker component + * @tc.desc set textStyle then get the value + */ + it('ArkUI_Stage_textpicker_textStyle_0004', 0, async function (done) { + let value = {color:'#00ff00',font:{size:'1px',weight:'700'}} + try { + var eventData = { + data: { + "textStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_textStyle_0004] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_textStyle_0004] change component data error: " + err.message); + } + await Utils.sleep(2000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_textStyle_0004] disappearColor:" + obj.$attrs.textStyle.color); + expect(obj.$attrs.textStyle.color).assertEqual('#FF00FF00'); + expect(obj.$attrs.textStyle.font.size).assertEqual('1.00px'); + expect(obj.$attrs.textStyle.font.weight).assertEqual('700'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_textStyle_0005 + * @tc.name Tests the textStyle property of the picker component + * @tc.desc set textStyle then get the value + */ + it('ArkUI_Stage_textpicker_textStyle_0005', 0, async function (done) { + let value = {color:Color.Green,font:{size:30,weight:450}} + try { + var eventData = { + data: { + "textStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_textStyle_0005] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_textStyle_0005] change component data error: " + err.message); + } + await Utils.sleep(2000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_textStyle_0005] disappearColor:" + obj.$attrs.textStyle.color); + expect(obj.$attrs.textStyle.color).assertEqual('#FF008000'); + expect(obj.$attrs.textStyle.font.size).assertEqual('30.00fp'); + expect(obj.$attrs.textStyle.font.weight).assertEqual('FontWeight.Normal'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_textStyle_0006 + * @tc.name Tests the textStyle property of the picker component + * @tc.desc set textStyle then get the value + */ + it('ArkUI_Stage_textpicker_textStyle_0006', 0, async function (done) { + let value = {color:'#80808g',font:{size:-1,weight:1000}} + try { + var eventData = { + data: { + "textStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_textStyle_0006] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_textStyle_0006] change component data error: " + err.message); + } + await Utils.sleep(2000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_textStyle_0006] disappearColor:" + obj.$attrs.textStyle.color); + expect(obj.$attrs.textStyle.color).assertEqual('#FF182431'); + expect(obj.$attrs.textStyle.font.size).assertEqual('16.00vp'); + expect(obj.$attrs.textStyle.font.weight).assertEqual('FontWeight.Normal'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_textStyle_0007 + * @tc.name Tests the textStyle property of the picker component + * @tc.desc set textStyle then get the value + */ + it('ArkUI_Stage_textpicker_textStyle_0007', 0, async function (done) { + let value = {color:'xxx',font:{size:'xxx',weight:FontWeight.Lighter}} + try { + var eventData = { + data: { + "textStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_textStyle_0007] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_textStyle_0007] change component data error: " + err.message); + } + await Utils.sleep(2000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_textStyle_0007] disappearColor:" + obj.$attrs.textStyle.color); + expect(obj.$attrs.textStyle.color).assertEqual('#FF182431'); + expect(obj.$attrs.textStyle.font.size).assertEqual('16.00vp'); + expect(obj.$attrs.textStyle.font.weight).assertEqual('FontWeight.Lighter'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_textStyle_0008 + * @tc.name Tests the textStyle property of the picker component + * @tc.desc set textStyle then get the value + */ + it('ArkUI_Stage_textpicker_textStyle_0008', 0, async function (done) { + let value = {color:'rgb(138,43,226)',font:{size:'20vp',weight:900}} + try { + var eventData = { + data: { + "textStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_textStyle_0008] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_textStyle_0008] change component data error: " + err.message); + } + await Utils.sleep(3000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + expect(obj.$attrs.textStyle.color).assertEqual('#FF8A2BE2'); + expect(obj.$attrs.textStyle.font.size).assertEqual('20.00vp'); + expect(obj.$attrs.textStyle.font.weight).assertEqual('900'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_textStyle_0009 + * @tc.name Tests the textStyle property of the picker component + * @tc.desc set textStyle then get the value + */ + it('ArkUI_Stage_textpicker_textStyle_0009', 0, async function (done) { + let value = {color:'rgb(138,43,226)',font:{size:'15lpx',weight:90}} + try { + var eventData = { + data: { + "textStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_textStyle_0009] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_textStyle_0009] change component data error: " + err.message); + } + await Utils.sleep(3000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + expect(obj.$attrs.textStyle.color).assertEqual('#FF8A2BE2'); + expect(obj.$attrs.textStyle.font.size).assertEqual('15.00lpx'); + expect(obj.$attrs.textStyle.font.weight).assertEqual('FontWeight.Normal'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_selectedTextStyle_0001 + * @tc.name Tests the selectedTextStyle property of the picker component + * @tc.desc get the default value + */ + it('ArkUI_Stage_textpicker_selectedTextStyle_0001', 0, async function (done) { + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_selectedTextStyle_0001] disappearColor:" + obj.$attrs.selectedTextStyle.color); + expect(obj.$attrs.selectedTextStyle.color).assertEqual('#FF0000FF'); + expect(obj.$attrs.selectedTextStyle.font.size).assertEqual('20.00px'); + expect(obj.$attrs.selectedTextStyle.font.weight).assertEqual('FontWeight.Bold'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_selectedTextStyle_0002 + * @tc.name Tests the selectedTextStyle property of the picker component + * @tc.desc set selectedTextStyle then get the value + */ + it('ArkUI_Stage_textpicker_selectedTextStyle_0002', 0, async function (done) { + let value = {color:Color.Blue,font:{size:'20px',weight:FontWeight.Bolder}} + try { + var eventData = { + data: { + "selectedTextStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_selectedTextStyle_0002] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_selectedTextStyle_0002] change component data error: " + err.message); + } + await Utils.sleep(3000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.error("[ArkUI_Stage_textpicker_selectedTextStyle_0002] disappearColor:" + obj.$attrs.selectedTextStyle.color); + expect(obj.$attrs.selectedTextStyle.color).assertEqual('#FF0000FF'); + expect(obj.$attrs.selectedTextStyle.font.size).assertEqual('20.00px'); + expect(obj.$attrs.selectedTextStyle.font.weight).assertEqual('FontWeight.Bolder'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_selectedTextStyle_0003 + * @tc.name Tests the selectedTextStyle property of the picker component + * @tc.desc set selectedTextStyle then get the value + */ + it('ArkUI_Stage_textpicker_selectedTextStyle_0003', 0, async function (done) { + let value = {color:0xFF808080,font:{size:'20px',weight:100}} + try { + var eventData = { + data: { + "selectedTextStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_selectedTextStyle_0003] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_selectedTextStyle_0003] change component data error: " + err.message); + } + await Utils.sleep(2000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_selectedTextStyle_0003] disappearColor:" + obj.$attrs.selectedTextStyle.color); + expect(obj.$attrs.selectedTextStyle.color).assertEqual('#FF808080'); + expect(obj.$attrs.selectedTextStyle.font.size).assertEqual('20.00px'); + expect(obj.$attrs.selectedTextStyle.font.weight).assertEqual('100'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_selectedTextStyle_0004 + * @tc.name Tests the selectedTextStyle property of the picker component + * @tc.desc set selectedTextStyle then get the value + */ + it('ArkUI_Stage_textpicker_selectedTextStyle_0004', 0, async function (done) { + let value = {color:'#00ff00',font:{size:'1px',weight:'700'}} + try { + var eventData = { + data: { + "selectedTextStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_selectedTextStyle_0004] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_selectedTextStyle_0004] change component data error: " + err.message); + } + await Utils.sleep(2000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_selectedTextStyle_0004] disappearColor:" + obj.$attrs.selectedTextStyle.color); + expect(obj.$attrs.selectedTextStyle.color).assertEqual('#FF00FF00'); + expect(obj.$attrs.selectedTextStyle.font.size).assertEqual('1.00px'); + expect(obj.$attrs.selectedTextStyle.font.weight).assertEqual('700'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_selectedTextStyle_0005 + * @tc.name Tests the selectedTextStyle property of the picker component + * @tc.desc set selectedTextStyle then get the value + */ + it('ArkUI_Stage_textpicker_selectedTextStyle_0005', 0, async function (done) { + let value = {color:Color.Green,font:{size:30,weight:450}} + try { + var eventData = { + data: { + "selectedTextStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_selectedTextStyle_0005] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_selectedTextStyle_0005] change component data error: " + err.message); + } + await Utils.sleep(2000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_selectedTextStyle_0005] disappearColor:" + obj.$attrs.selectedTextStyle.color); + expect(obj.$attrs.selectedTextStyle.color).assertEqual('#FF008000'); + expect(obj.$attrs.selectedTextStyle.font.size).assertEqual('30.00fp'); + expect(obj.$attrs.selectedTextStyle.font.weight).assertEqual('FontWeight.Normal'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_selectedTextStyle_0006 + * @tc.name Tests the selectedTextStyle property of the picker component + * @tc.desc set selectedTextStyle then get the value + */ + it('ArkUI_Stage_textpicker_selectedTextStyle_0006', 0, async function (done) { + let value = {color:'#80808g',font:{size:-1,weight:1000}} + try { + var eventData = { + data: { + "selectedTextStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_selectedTextStyle_0006] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_selectedTextStyle_0006] change component data error: " + err.message); + } + await Utils.sleep(2000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_selectedTextStyle_0006] disappearColor:" + obj.$attrs.selectedTextStyle.color); + expect(obj.$attrs.selectedTextStyle.color).assertEqual('#FF007DFF'); + expect(obj.$attrs.selectedTextStyle.font.size).assertEqual('20.00vp'); + expect(obj.$attrs.selectedTextStyle.font.weight).assertEqual('FontWeight.Normal'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_selectedTextStyle_0007 + * @tc.name Tests the selectedTextStyle property of the picker component + * @tc.desc set selectedTextStyle then get the value + */ + it('ArkUI_Stage_textpicker_selectedTextStyle_0007', 0, async function (done) { + let value = {color:'xxx',font:{size:'xxx',weight:FontWeight.Lighter}} + try { + var eventData = { + data: { + "selectedTextStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_selectedTextStyle_0007] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_selectedTextStyle_0007] change component data error: " + err.message); + } + await Utils.sleep(2000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + console.info("[ArkUI_Stage_textpicker_selectedTextStyle_0007] disappearColor:" + obj.$attrs.selectedTextStyle.color); + expect(obj.$attrs.selectedTextStyle.color).assertEqual('#FF007DFF'); + expect(obj.$attrs.selectedTextStyle.font.size).assertEqual('20.00vp'); + expect(obj.$attrs.selectedTextStyle.font.weight).assertEqual('FontWeight.Lighter'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_selectedTextStyle_0008 + * @tc.name Tests the selectedTextStyle property of the picker component + * @tc.desc set selectedTextStyle then get the value + */ + it('ArkUI_Stage_textpicker_selectedTextStyle_0008', 0, async function (done) { + let value = {color:'rgb(138,43,226)',font:{size:'20vp',weight:900}} + try { + var eventData = { + data: { + "selectedTextStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_selectedTextStyle_0008] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_selectedTextStyle_0008] change component data error: " + err.message); + } + await Utils.sleep(3000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + expect(obj.$attrs.selectedTextStyle.color).assertEqual('#FF8A2BE2'); + expect(obj.$attrs.selectedTextStyle.font.size).assertEqual('20.00vp'); + expect(obj.$attrs.selectedTextStyle.font.weight).assertEqual('900'); + done(); + }); + + /* + * @tc.number ArkUI_Stage_textpicker_selectedTextStyle_0009 + * @tc.name Tests the selectedTextStyle property of the picker component + * @tc.desc set selectedTextStyle then get the value + */ + it('ArkUI_Stage_textpicker_selectedTextStyle_0009', 0, async function (done) { + let value = {color:'rgb(138,43,226)',font:{size:'15lpx',weight:90}} + try { + var eventData = { + data: { + "selectedTextStyle": JSON.stringify(value) + } + } + var innerEvent = { + eventId: 183, + priority: events_emitter.EventPriority.LOW + } + console.info("[ArkUI_Stage_textpicker_selectedTextStyle_0009] start to publish emit"); + events_emitter.emit(innerEvent, eventData); + } catch (err) { + console.log("[ArkUI_Stage_textpicker_selectedTextStyle_0009] change component data error: " + err.message); + } + await Utils.sleep(3000); + let strJson = getInspectorByKey('textPicker'); + let obj = JSON.parse(strJson); + expect(obj.$attrs.selectedTextStyle.color).assertEqual('#FF8A2BE2'); + expect(obj.$attrs.selectedTextStyle.font.size).assertEqual('15.00lpx'); + expect(obj.$attrs.selectedTextStyle.font.weight).assertEqual('FontWeight.Normal'); + done(); + }); + }) + } diff --git a/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/test/Utils.ets b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/test/Utils.ets new file mode 100644 index 0000000000000000000000000000000000000000..6fecbfe80e6e5a3882dac77004efbc26a7faefea --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/ets/test/Utils.ets @@ -0,0 +1,26 @@ +/* + * Copyright (c) 2023 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +export default class Utils { + static sleep(time){ + return new Promise((resolve,reject)=>{ + setTimeout(()=>{ + resolve("ok") + },time) + }).then(()=>{ + console.info(`sleep ${time} over...`) + }) + } +} diff --git a/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/module.json b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/module.json new file mode 100644 index 0000000000000000000000000000000000000000..2b03fde2a1898cf911b3b3f2f94a553bca8ebb86 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/module.json @@ -0,0 +1,41 @@ +{ + "module": { + "name": "phone", + "type": "feature", + "description": "$string:module_test_desc", + "mainElement": "TestAbility", + "deviceTypes": [ + "default", + "tablet" + ], + "deliveryWithInstall": true, + "installationFree": false, + "pages": "$profile:test_pages", + "metadata": [{ + "name": "ArkTSPartialUpdate", + "value": "true" + }], + "abilities": [ + { + "name": "TestAbility", + "srcEntrance": "./ets/TestAbility/TestAbility.ets", + "description": "$string:TestAbility_desc", + "icon": "$media:icon", + "label": "$string:TestAbility_label", + "visible": true, + "startWindowIcon": "$media:icon", + "startWindowBackground": "$color:start_window_background", + "skills": [ + { + "actions": [ + "action.system.home" + ], + "entities": [ + "entity.system.home" + ] + } + ] + } + ] + } +} diff --git a/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/resources/base/element/color.json b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/resources/base/element/color.json new file mode 100644 index 0000000000000000000000000000000000000000..3c712962da3c2751c2b9ddb53559afcbd2b54a02 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/resources/base/element/color.json @@ -0,0 +1,8 @@ +{ + "color": [ + { + "name": "start_window_background", + "value": "#FFFFFF" + } + ] +} \ No newline at end of file diff --git a/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/resources/base/element/string.json b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/resources/base/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..65d8fa5a7cf54aa3943dcd0214f58d1771bc1f6c --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/resources/base/element/string.json @@ -0,0 +1,16 @@ +{ + "string": [ + { + "name": "module_test_desc", + "value": "test ability description" + }, + { + "name": "TestAbility_desc", + "value": "the test ability" + }, + { + "name": "TestAbility_label", + "value": "test label" + } + ] +} \ No newline at end of file diff --git a/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/resources/base/media/icon.png b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/resources/base/media/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..ce307a8827bd75456441ceb57d530e4c8d45d36c Binary files /dev/null and b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/resources/base/media/icon.png differ diff --git a/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/resources/base/profile/test_pages.json b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/resources/base/profile/test_pages.json new file mode 100644 index 0000000000000000000000000000000000000000..77e90731b5a38d861663029b483df3d3ac9ec74b --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_textpicker/src/main/resources/base/profile/test_pages.json @@ -0,0 +1,5 @@ +{ + "src": [ + "TestAbility/pages/Index" + ] +}