diff --git a/arkui/BUILD.gn b/arkui/BUILD.gn index f3c31887369c9bb52c3934592478b61249d869f0..2bf908a662ca26087ef969742e3df129e5359fe2 100644 --- a/arkui/BUILD.gn +++ b/arkui/BUILD.gn @@ -22,6 +22,7 @@ group("arkui") { "ace_ets_component_three:ActsAceEtsComponentThreeTest", "ace_ets_component_two:ActsAceEtsComponentTwoTest", "ace_ets_component_ui:ActsAceEtsComponentUITest", + "ace_ets_components_ux:componnetUxTest", "ace_ets_dev:ActsAceDevTest", "ace_ets_layout_test:ActsAceEtsLayoutTest", "ace_ets_standard:ActsAceEtsStTest", diff --git a/arkui/ace_ets_components_ux/BUILD.gn b/arkui/ace_ets_components_ux/BUILD.gn new file mode 100644 index 0000000000000000000000000000000000000000..d2514467aaf24e79a15f6f082456641faa448de6 --- /dev/null +++ b/arkui/ace_ets_components_ux/BUILD.gn @@ -0,0 +1,19 @@ +# Copyright (C) 2023 Huawei Device Co., Ltd. +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +group("componnetUxTest") { + testonly = true + if (is_standard_system) { + deps = [ "ace_ets_component_swiper:ActsAceSwiperTest" ] + } +} diff --git a/arkui/ace_ets_components_ux/ace_ets_component_swiper/AppScope/app.json b/arkui/ace_ets_components_ux/ace_ets_component_swiper/AppScope/app.json new file mode 100644 index 0000000000000000000000000000000000000000..17a999ff4e3653d03a40c0e8641dd2af8d138332 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_swiper/AppScope/app.json @@ -0,0 +1,19 @@ +{ + "app": { + "bundleName": "com.example.swipertest", + "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 + } + } +} \ No newline at end of file diff --git a/arkui/ace_ets_components_ux/ace_ets_component_swiper/AppScope/resources/base/element/string.json b/arkui/ace_ets_components_ux/ace_ets_component_swiper/AppScope/resources/base/element/string.json new file mode 100644 index 0000000000000000000000000000000000000000..3e8dda342484af625ea003b67a3db2d55bedcab9 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_swiper/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_swiper/AppScope/resources/base/media/app_icon.png b/arkui/ace_ets_components_ux/ace_ets_component_swiper/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_swiper/AppScope/resources/base/media/app_icon.png differ diff --git a/arkui/ace_ets_components_ux/ace_ets_component_swiper/BUILD.gn b/arkui/ace_ets_components_ux/ace_ets_component_swiper/BUILD.gn new file mode 100644 index 0000000000000000000000000000000000000000..d759697abfa0bd9b5b21ce39a755068c746c5896 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_swiper/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("ActsAceSwiperTest") { + hap_profile = "src/main/module.json" + js_build_mode = "debug" + deps = [ + ":ace_ets_component_swiper_js_assets", + ":ace_ets_component_swiper_resources", + ] + ets2abc = true + certificate_profile = "signature/openharmony_sx.p7b" + hap_name = "ActsAceSwiperTest" + part_name = "ace_engine" + subsystem_name = "arkui" +} + +ohos_app_scope("ace_ets_component_swiper_profile") { + app_profile = "AppScope/app.json" + sources = [ "AppScope/resources" ] +} + +ohos_js_assets("ace_ets_component_swiper_js_assets") { + source_dir = "src/main/ets" +} + +ohos_resources("ace_ets_component_swiper_resources") { + sources = [ "src/main/resources" ] + deps = [ ":ace_ets_component_swiper_profile" ] + hap_profile = "src/main/module.json" +} diff --git a/arkui/ace_ets_components_ux/ace_ets_component_swiper/Test.json b/arkui/ace_ets_components_ux/ace_ets_component_swiper/Test.json new file mode 100644 index 0000000000000000000000000000000000000000..fc890e93e349bc3f72b0b6a622364e2152c257ab --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_swiper/Test.json @@ -0,0 +1,27 @@ +{ + "description": "Configuration for hjunit demo Tests", + "driver": { + "type": "OHJSUnitTest", + "test-timeout": "600000", + "bundle-name": "com.example.swipertest", + "module-name": "phone", + "shell-timeout": "600000", + "testcase-timeout": 240000 + }, + "kits": [ + { + "test-file-name": [ + "ActsAceSwiperTest.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_swiper/signature/openharmony_sx.p7b b/arkui/ace_ets_components_ux/ace_ets_component_swiper/signature/openharmony_sx.p7b new file mode 100644 index 0000000000000000000000000000000000000000..931b0f0377aa2aab87bb2a89f4ff1d52d0c9ff7c Binary files /dev/null and b/arkui/ace_ets_components_ux/ace_ets_component_swiper/signature/openharmony_sx.p7b differ diff --git a/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/ets/TestAbility/TestAbility.ets b/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/ets/TestAbility/TestAbility.ets new file mode 100644 index 0000000000000000000000000000000000000000..8d65dd2ea8346a8b5d12ac7aff026197a95abaea --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/ets/TestAbility/TestAbility.ets @@ -0,0 +1,63 @@ +/* + * 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_swiper/src/main/ets/TestAbility/pages/Index.ets b/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/ets/TestAbility/pages/Index.ets new file mode 100644 index 0000000000000000000000000000000000000000..439791b605a4aff6fca05da258a9c98c01127386 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/ets/TestAbility/pages/Index.ets @@ -0,0 +1,543 @@ +/* + * 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 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' + +export class MyDataSource implements IDataSource { + private list: number[] = [] + private listener: DataChangeListener + + constructor(list: number[]) { this.list = list } + + totalCount(): number { + return this.list.length +} + + getData(index: number): any { + return this.list[index] + } + + registerDataChangeListener(listener: DataChangeListener): void { + this.listener = listener + } + + unregisterDataChangeListener() { + } +} + +@Entry +@Component +struct SwiperTest { + + aboutToAppear(){ + 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) + } + + @State flag: boolean = false; + @State selectedItemWidth: number = 12 + @State selectedItemHeight: number = 6 + @State itemWidth: number = 6 + @State itemHeight: number = 6 + @State selectedFontColor: Color = Color.Black + @State fontColor: Color = Color.Black + @State selectedSize: string | number = 14; + @State itemSize: string | number = 14; + @State selectedWeight: FontWeight | number | string = FontWeight.Normal; + @State itemWeight: FontWeight | number | string = FontWeight.Normal; + private swiperController: SwiperController = new SwiperController() + private data: MyDataSource = new MyDataSource([]) + + build() { + Row() { + Column() { + List({ space: 5, initialIndex: 0 }) { + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_ItemHeight_0100") + .curve(Curve.Linear) + .indicator(Indicator.dot() + .itemHeight(3)) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_ItemHeight_0200") + .curve(Curve.Linear) + .indicator(Indicator.dot() + .itemHeight("")) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_ItemHeight_0300") + .curve(Curve.Linear) + .indicator(Indicator.dot() + .itemHeight("9999vp")) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_ItemHeight_0400") + .curve(Curve.Linear) + .indicator(Indicator.dot() + .itemHeight(-1)) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_ItemHeight_0500") + .curve(Curve.Linear) + .indicator(Indicator.dot() + .itemHeight("abc")) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_ItemHeight_0600") + .curve(Curve.Linear) + .indicator(Indicator.dot() + .itemHeight("8fp")) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_ItemHeight_0700") + .curve(Curve.Linear) + .indicator(Indicator.dot() + .itemHeight("8lpx")) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_SelectedFontColor_0100") + .curve(Curve.Linear) + .indicator(Indicator.digit() + .selectedFontColor(0x00ff00)) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_SelectedFontColor_0200") + .curve(Curve.Linear) + .indicator(Indicator.digit() + .selectedFontColor("#FFFF0000")) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_SelectedFontColor_0300") + .curve(Curve.Linear) + .indicator(Indicator.digit() + .selectedFontColor("rgb(138,43,226)")) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_SelectedFontColor_0400") + .curve(Curve.Linear) + .indicator(Indicator.digit() + .selectedFontColor(Color.Pink)) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_SelectedFontColor_0500") + .curve(Curve.Linear) + .indicator(Indicator.digit() + .selectedFontColor("")) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_SelectedFontColor_0600") + .curve(Curve.Linear) + .indicator(Indicator.digit() + .selectedFontColor(null)) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_SelectedFontColor_0700") + .curve(Curve.Linear) + .indicator(Indicator.digit() + .selectedFontColor($r("app.color.selected_font_color_test"))) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_SelectedFontColor_0800") + .curve(Curve.Linear) + .indicator(Indicator.digit() + .selectedFontColor("bgr(138,43,226)")) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_SelectedFontColor_0900") + .curve(Curve.Linear) + .indicator(Indicator.digit() + .selectedFontColor(undefined)) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_SelectedFontColor_1000") + .curve(Curve.Linear) + .indicator(Indicator.digit() + .selectedFontColor("rgb(138,43,226)")) + .indicator(Indicator.digit() + .selectedFontColor(Color.Gray)) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_SelectedFontColor_1100") + .curve(Curve.Linear) + .indicator(Indicator.digit() + .selectedFontColor(0x00ff00)) + .backgroundColor(Color.Pink) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + ListItem() { + Swiper(this.swiperController) { + LazyForEach(this.data, (item: string) => { + Text(item) + .width('90%') + .height(160) + .backgroundColor(0xAFEEEE) + .textAlign(TextAlign.Center) + .fontSize(30) + }, item => item) + } + .autoPlay(true) + .interval(4000) + .loop(true) + .duration(1000) + .itemSpace(0) + .key("ArkUX_Stage_Swiper_SelectedFontColor_1200") + .curve(Curve.Linear) + .indicator(Indicator.digit() + .selectedFontColor("rgb(255,0,0)")) + .indicator(Indicator.digit() + .selectedFontColor(undefined)) + .onChange((index: number) => { + console.info(index.toString()) + }) + } + } + } + .width('100%') + } + .height('100%') + } +} diff --git a/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts b/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/ets/TestRunner/OpenHarmonyTestRunner.ts new file mode 100644 index 0000000000000000000000000000000000000000..d6c662824093f9339085214d247c6247faa86ae9 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_swiper/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_swiper/src/main/ets/test/List.test.ets b/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/ets/test/List.test.ets new file mode 100644 index 0000000000000000000000000000000000000000..1615575e03b1bfaa1dba29fc019e73e0f43499fa --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/ets/test/List.test.ets @@ -0,0 +1,19 @@ +/* + * Copyright (c) 2023 Huawei Device Co., Ltd. + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +import swiperTest from './swiper' + +export default function testsuite() { + swiperTest() +} \ No newline at end of file diff --git a/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/ets/test/swiper.ets b/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/ets/test/swiper.ets new file mode 100644 index 0000000000000000000000000000000000000000..c04cfdcbded0539f0eb3835a65a5f148506fed87 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/ets/test/swiper.ets @@ -0,0 +1,598 @@ +/* + * 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 hilog from '@ohos.hilog'; + +let emitKey = "emitUserAgent"; + +export default function swiperTest() { + describe('ActSwiperTest', function () { + + /** + * @tc.number ArkUX_Stage_Swiper_ItemHeight_0100 + * @tc.name Tests the itemHeight property of the swiper component + * @tc.desc Set the itemHeight property parameter to 3 + */ + it('ArkUX_Stage_Swiper_ItemHeight_0100', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_ItemHeight_0100 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_ItemHeight_0100'); + console.info('ArkUX_Stage_Swiper_ItemHeight_0100 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_ItemHeight_0100 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_ItemHeight_0100 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_ItemHeight_0100 component obj.$attrs.itemHeight is: " + + JSON.stringify(obj.$attrs.itemHeight)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_ItemHeight_0100 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.itemHeight).assertEqual("3.00px"); + console.info('ArkUX_Stage_Swiper_ItemHeight_0100 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_ItemHeight_0100 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_ItemHeight_0200 + * @tc.name Tests the itemHeight property of the swiper component + * @tc.desc Set the itemHeight property parameter to "" + */ + it('ArkUX_Stage_Swiper_ItemHeight_0200', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_ItemHeight_0200 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_ItemHeight_0200'); + console.info('ArkUX_Stage_Swiper_ItemHeight_0200 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_ItemHeight_0200 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_ItemHeight_0200 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_ItemHeight_0200 component obj.$attrs.itemHeight is: " + + JSON.stringify(obj.$attrs.itemHeight)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_ItemHeight_0200 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.itemHeight).assertEqual("6.00vp"); + console.info('ArkUX_Stage_Swiper_ItemHeight_0200 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_ItemHeight_0200 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_ItemHeight_0300 + * @tc.name Tests the itemHeight property of the swiper component + * @tc.desc Set the itemHeight property parameter to "9999vp" + */ + it('ArkUX_Stage_Swiper_ItemHeight_0300', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_ItemHeight_0300 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_ItemHeight_0300'); + console.info('ArkUX_Stage_Swiper_ItemHeight_0300 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_ItemHeight_0300 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_ItemHeight_0300 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_ItemHeight_0300 component obj.$attrs.itemHeight is: " + + JSON.stringify(obj.$attrs.itemHeight)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_ItemHeight_0300 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.itemHeight).assertEqual("9999.00vp"); + console.info('ArkUX_Stage_Swiper_ItemHeight_0300 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_ItemHeight_0300 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_ItemHeight_0400 + * @tc.name Tests the itemHeight property of the swiper component + * @tc.desc Set the itemHeight property parameter to -1 + */ + it('ArkUX_Stage_Swiper_ItemHeight_0400', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_ItemHeight_0400 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_ItemHeight_0400'); + console.info('ArkUX_Stage_Swiper_ItemHeight_0400 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_ItemHeight_0400 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_ItemHeight_0400 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_ItemHeight_0400 component obj.$attrs.itemHeight is: " + + JSON.stringify(obj.$attrs.itemHeight)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_ItemHeight_0400 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.itemHeight).assertEqual("6.00vp"); + console.info('ArkUX_Stage_Swiper_ItemHeight_0400 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_ItemHeight_0400 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_ItemHeight_0500 + * @tc.name Tests the itemHeight property of the swiper component + * @tc.desc Set the itemHeight property parameter to "abc" + */ + it('ArkUX_Stage_Swiper_ItemHeight_0500', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_ItemHeight_0500 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_ItemHeight_0500'); + console.info('ArkUX_Stage_Swiper_ItemHeight_0500 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_ItemHeight_0500 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_ItemHeight_0500 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_ItemHeight_0500 component obj.$attrs.itemHeight is: " + + JSON.stringify(obj.$attrs.itemHeight)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_ItemHeight_0500 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.itemHeight).assertEqual("6.00vp"); + console.info('ArkUX_Stage_Swiper_ItemHeight_0500 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_ItemHeight_0500 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_ItemHeight_0600 + * @tc.name Tests the itemHeight property of the swiper component + * @tc.desc Set the itemHeight property parameter to "8fp" + */ + it('ArkUX_Stage_Swiper_ItemHeight_0600', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_ItemHeight_0500 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_ItemHeight_0600'); + console.info('ArkUX_Stage_Swiper_ItemHeight_0600 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_ItemHeight_0600 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_ItemHeight_0600 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_ItemHeight_0600 component obj.$attrs.itemHeight is: " + + JSON.stringify(obj.$attrs.itemHeight)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_ItemHeight_0600 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.itemHeight).assertEqual("8.00fp"); + console.info('ArkUX_Stage_Swiper_ItemHeight_0600 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_ItemHeight_0600 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_ItemHeight_0700 + * @tc.name Tests the itemHeight property of the swiper component + * @tc.desc Set the itemHeight property parameter to "8lpx" + */ + it('ArkUX_Stage_Swiper_ItemHeight_0700', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_ItemHeight_0700 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_ItemHeight_0700'); + console.info('ArkUX_Stage_Swiper_ItemHeight_0700 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_ItemHeight_0700 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_ItemHeight_0700 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_ItemHeight_0700 component obj.$attrs.itemHeight is: " + + JSON.stringify(obj.$attrs.itemHeight)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_ItemHeight_0700 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.itemHeight).assertEqual("8.00lpx"); + console.info('ArkUX_Stage_Swiper_ItemHeight_0700 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_ItemHeight_0700 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_SelectedFontColor_0100 + * @tc.name Tests the selectedFontColor property of the swiper component + * @tc.desc Set the selectedFontColor property parameter to 0x00ff00 + */ + it('ArkUX_Stage_Swiper_SelectedFontColor_0100', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0100 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_SelectedFontColor_0100'); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0100 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0100 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0100 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0100 component obj.$attrs.selectedFontColor is: " + + JSON.stringify(obj.$attrs.selectedFontColor)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0100 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.selectedFontColor).assertEqual("#FF00FF00"); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0100 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0100 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_SelectedFontColor_0200 + * @tc.name Tests the selectedFontColor property of the swiper component + * @tc.desc Set the selectedFontColor property parameter to "#FFFF0000" + */ + it('ArkUX_Stage_Swiper_SelectedFontColor_0200', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0200 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_SelectedFontColor_0200'); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0200 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0200 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0200 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0200 component obj.$attrs.selectedFontColor is: " + + JSON.stringify(obj.$attrs.selectedFontColor)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0200 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.selectedFontColor).assertEqual("#FFFF0000"); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0200 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0200 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_SelectedFontColor_0300 + * @tc.name Tests the selectedFontColor property of the swiper component + * @tc.desc Set the selectedFontColor property parameter to "rgb(138,43,226)" + */ + it('ArkUX_Stage_Swiper_SelectedFontColor_0300', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0300 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_SelectedFontColor_0300'); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0300 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0300 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0300 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0300 component obj.$attrs.selectedFontColor is: " + + JSON.stringify(obj.$attrs.selectedFontColor)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0300 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.selectedFontColor).assertEqual("#FF8A2BE2"); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0300 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0300 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_SelectedFontColor_0400 + * @tc.name Tests the selectedFontColor property of the swiper component + * @tc.desc Set the selectedFontColor property parameter to Color.Pink + */ + it('ArkUX_Stage_Swiper_SelectedFontColor_0400', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0400 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_SelectedFontColor_0400'); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0400 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0400 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0400 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0400 component obj.$attrs.selectedFontColor is: " + + JSON.stringify(obj.$attrs.selectedFontColor)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0400 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.selectedFontColor).assertEqual("#FFFFC0CB"); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0400 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0400 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_SelectedFontColor_0500 + * @tc.name Tests the selectedFontColor property of the swiper component + * @tc.desc Set the selectedFontColor property parameter to "" + */ + it('ArkUX_Stage_Swiper_SelectedFontColor_0500', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0500 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_SelectedFontColor_0500'); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0500 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0500 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0500 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0500 component obj.$attrs.selectedFontColor is: " + + JSON.stringify(obj.$attrs.selectedFontColor)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0500 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.selectedFontColor).assertEqual("#FF182431"); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0500 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0500 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_SelectedFontColor_0600 + * @tc.name Tests the selectedFontColor property of the swiper component + * @tc.desc Set the selectedFontColor property parameter to null + */ + it('ArkUX_Stage_Swiper_SelectedFontColor_0600', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0600 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_SelectedFontColor_0600'); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0600 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0600 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0600 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0600 component obj.$attrs.selectedFontColor is: " + + JSON.stringify(obj.$attrs.selectedFontColor)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0600 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.selectedFontColor).assertEqual("#FF182431"); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0600 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0600 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_SelectedFontColor_0700 + * @tc.name Tests the selectedFontColor property of the swiper component + * @tc.desc Set the selectedFontColor property parameter to $r("app.color.selected_font_color_test") + */ + it('ArkUX_Stage_Swiper_SelectedFontColor_0700', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0700 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_SelectedFontColor_0700'); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0700 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0700 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0700 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0700 component obj.$attrs.selectedFontColor is: " + + JSON.stringify(obj.$attrs.selectedFontColor)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0700 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.selectedFontColor).assertEqual("#FFFF0000"); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0700 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0700 ERR ' + JSON.stringify(err)); + done(); + } + done(); + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_SelectedFontColor_0800 + * @tc.name Tests the selectedFontColor property of the swiper component + * @tc.desc Set the selectedFontColor property parameter to "bgr(138,43,226)" + */ + it('ArkUX_Stage_Swiper_SelectedFontColor_0800', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0800 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_SelectedFontColor_0800'); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0800 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0800 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0800 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0800 component obj.$attrs.selectedFontColor is: " + + JSON.stringify(obj.$attrs.selectedFontColor)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0800 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.selectedFontColor).assertEqual("#FF182431"); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0800 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0800 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_SelectedFontColor_0900 + * @tc.name Tests the selectedFontColor property of the swiper component + * @tc.desc Set the selectedFontColor property parameter to undefined + */ + it('ArkUX_Stage_Swiper_SelectedFontColor_0900', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0900 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_SelectedFontColor_0600'); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0900 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0900 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0900 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0900 component obj.$attrs.selectedFontColor is: " + + JSON.stringify(obj.$attrs.selectedFontColor)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_0900 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.selectedFontColor).assertEqual("#FF182431"); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0900 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_0900 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_SelectedFontColor_1000 + * @tc.name Tests the selectedFontColor property of the swiper component + * @tc.desc Set the selectedFontColor attribute parameter to "rgb (138,43,226)", + * and set the selectedFontColor attribute parameter to the normal value Color.Gray again + */ + it('ArkUX_Stage_Swiper_SelectedFontColor_1000', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_SelectedFontColor_1000 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_SelectedFontColor_1000'); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_1000 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_1000 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_1000 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_1000 component obj.$attrs.selectedFontColor is: " + + JSON.stringify(obj.$attrs.selectedFontColor)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_1000 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.selectedFontColor).assertEqual("#FF808080"); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_1000 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_1000 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_SelectedFontColor_1100 + * @tc.name Tests the selectedFontColor property of the swiper component + * @tc.desc Set the selectedFontColor property parameter to 0x00ff00, + * and set the general property backgroundColor parameter to Color.Pink + */ + it('ArkUX_Stage_Swiper_SelectedFontColor_1100', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_SelectedFontColor_1100 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_SelectedFontColor_1100'); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_1100 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_1100 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_1100 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_1100 component obj.$attrs.selectedFontColor is: " + + JSON.stringify(obj.$attrs.selectedFontColor)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_1100 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.selectedFontColor).assertEqual("#FF00FF00"); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_1100 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_1100 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + + /** + * @tc.number ArkUX_Stage_Swiper_SelectedFontColor_1200 + * @tc.name Tests the selectedFontColor property of the swiper component + * @tc.desc Set the selectedFontColor property parameter to "rgb (255,0,0)", + * and set the selectedFontColor property parameter to the outlier undefined again + */ + it('ArkUX_Stage_Swiper_SelectedFontColor_1200', 0, async function (done) { + console.info('ArkUX_Stage_Swiper_SelectedFontColor_1200 START'); + setTimeout(() => { + try { + let strJson = getInspectorByKey('ArkUX_Stage_Swiper_SelectedFontColor_1200'); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_1200 START :' + JSON.stringify(strJson)); + let obj = JSON.parse(strJson); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_1200 component obj is: " + JSON.stringify(obj)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_1200 component obj.$attrs is: " + + JSON.stringify(obj.$attrs)); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_1200 component obj.$attrs.selectedFontColor is: " + + JSON.stringify(obj.$attrs.selectedFontColor)); + let obj2 = JSON.parse(obj.$attrs.indicator); + console.info("ArkUX_Stage_Swiper_SelectedFontColor_1200 component obj2 is: " + JSON.stringify(obj2)); + expect(obj2.selectedFontColor).assertEqual("#FF182431"); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_1200 END '); + done(); + } catch (err) { + expect().assertFail(); + console.info('ArkUX_Stage_Swiper_SelectedFontColor_1200 ERR ' + JSON.stringify(err)); + done(); + } + }, 500) + }); + }) +} \ No newline at end of file diff --git a/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/module.json b/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/module.json new file mode 100644 index 0000000000000000000000000000000000000000..fd47168641b845c0b3543fb2f2bbd4c5172f3cf7 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/module.json @@ -0,0 +1,43 @@ +{ + "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" + ] + } + ] + } + ] + } +} \ No newline at end of file diff --git a/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/resources/base/element/color.json b/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/resources/base/element/color.json new file mode 100644 index 0000000000000000000000000000000000000000..1424d008fca75b7cee2e29b27382b857bf3d636a --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/resources/base/element/color.json @@ -0,0 +1,16 @@ +{ + "color": [ + { + "name": "start_window_background", + "value": "#FFFFFF" + }, + { + "name": "selected_font_color_test", + "value": "#FFFF0000" + }, + { + "name": "font_color_test", + "value": "#FFFF0000" + } + ] +} \ No newline at end of file diff --git a/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/resources/base/element/string.json b/arkui/ace_ets_components_ux/ace_ets_component_swiper/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_swiper/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_swiper/src/main/resources/base/media/icon.png b/arkui/ace_ets_components_ux/ace_ets_component_swiper/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_swiper/src/main/resources/base/media/icon.png differ diff --git a/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/resources/base/profile/test_pages.json b/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/resources/base/profile/test_pages.json new file mode 100644 index 0000000000000000000000000000000000000000..9896fb184f3db11f1ed9c3b073fa044ffc170e26 --- /dev/null +++ b/arkui/ace_ets_components_ux/ace_ets_component_swiper/src/main/resources/base/profile/test_pages.json @@ -0,0 +1,5 @@ +{ + "src": [ + "TestAbility/pages/Index" + ] +} \ No newline at end of file