未验证 提交 78c7eae4 编写于 作者: O openharmony_ci 提交者: Gitee

!8027 button 组件UX规格与特征动效 新增XTS用例

Merge pull request !8027 from chensi10/buttonxts
......@@ -15,6 +15,7 @@ group("componentUxTest") {
testonly = true
if (is_standard_system) {
deps = [
"ace_ets_component_button:ActsAceButtonTest",
"ace_ets_component_datepicker:ActsAceDatePickerTest",
"ace_ets_component_radio:ActsAceRadioTest",
"ace_ets_component_select:ActsAceSelectTest",
......
{
"app": {
"bundleName": "com.example.buttontest",
"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
{
"string":[
{
"name":"app_name",
"value":"MyApplication"
}
]
}
\ No newline at end of file
# 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("ActsAceButtonTest") {
hap_profile = "src/main/module.json"
js_build_mode = "debug"
deps = [
":ace_ets_component_button_js_assets",
":ace_ets_component_button_resources",
]
ets2abc = true
certificate_profile = "signature/openharmony_sx.p7b"
hap_name = "ActsAceButtonTest"
part_name = "ace_engine"
subsystem_name = "arkui"
}
ohos_app_scope("ace_ets_component_button_profile") {
app_profile = "AppScope/app.json"
sources = [ "AppScope/resources" ]
}
ohos_js_assets("ace_ets_component_button_js_assets") {
source_dir = "src/main/ets"
}
ohos_resources("ace_ets_component_button_resources") {
sources = [ "src/main/resources" ]
deps = [ ":ace_ets_component_button_profile" ]
hap_profile = "src/main/module.json"
}
{
"description": "Configuration for hjunit demo Tests",
"driver": {
"type": "OHJSUnitTest",
"test-timeout": "600000",
"bundle-name": "com.example.buttontest",
"module-name": "phone",
"shell-timeout": "600000",
"testcase-timeout": 240000
},
"kits": [{
"test-file-name": [
"ActsAceButtonTest.hap"
],
"type": "AppInstallKit",
"cleanup-apps": true
},
{
"type": "ShellKit",
"run-command": [
"power-shell wakeup",
"power-shell setmode 602"
]
}
]
}
\ No newline at end of file
/*
* 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');
}
}
/*
* 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'
@Entry
@Component
struct textInputTest {
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 txtA: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtB: string = 'overflowTextOverlengthTextOverflow.Ellipsis';
@State txtC: string = 'overflowTextOverlengthTextOverflow.None';
@State txtD: string = 'overflowTextOverflow.Race';
@State txtE: string = 'overflowTextOverflow.MultilineClip';
@State txtF: string = 'overflowTextOverflow.MultilineEllipsis';
@State txtG: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtH: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtI: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtJ: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtK: string = 'overfloTextOverlengthTextOverflow.Clip';
@State txtL: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtM: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtN: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtO: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtP: string = 'overflowTextOverlengthTextOverflow.Clipe';
@State txtQ: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtR: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtS: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtT: string = 'overflowTextOverlengthTextOverflow.Clipe';
@State txtU: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtV: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtW: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtX: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtY: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtZ: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txta: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtb: string = 'overflowTextOverlengthTextOverflow.Clip';
@State txtc: string = 'overflowTextOverlength TextOverflow.Clip';
@State txtd: string = 'overflowTextOverlength TextOverflow.Clip';
@State widthLongSize: number = 300;
@State widthShortSize: number = 200;
@State colorInfo: string = "#f2eada";
private scroller: Scroller = new Scroller()
build() {
Column() {
Stack({ alignContent: Alignment.End }) {
Scroll(this.scroller) {
Flex({ direction: FlexDirection.Column }) {
Text('ArkUX_Stage_Button_LabelStyle_0100').fontSize(15).margin({top:20})
Button(this.txtA)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Clip,
maxLines: 1, minFontSize: 5,
heightAdaptivePolicy: TextHeightAdaptivePolicy.MaxLines,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic }
})
.key("ArkUX_Stage_Button_LabelStyle_0100")
Text('ArkUX_Stage_Button_LabelStyle_0200').fontSize(15).margin({top:20})
Button(this.txtB)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Clip,
maxLines: 3, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MaxLines,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_0200")
Text('ArkUX_Stage_Button_LabelStyle_0300').fontSize(15).margin({top:20})
Button(this.txtC)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Clip,
maxLines: 1, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MinFontSize,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_0300")
Text('ArkUX_Stage_Button_LabelStyle_0400').fontSize(15).margin({top:20})
Button(this.txtD)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Clip,
maxLines: 1, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MinFontSize,
font: { weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Normal } })
.key("ArkUX_Stage_Button_LabelStyle_0400")
Text('ArkUX_Stage_Button_LabelStyle_0500').fontSize(15).margin({top:20})
Button(this.txtE)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Clip,
maxLines: 3, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.LayoutConstraint,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_0500")
Text('ArkUX_Stage_Button_LabelStyle_0600').fontSize(15).margin({top:20})
Button(this.txtF)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Ellipsis,
maxLines: 1, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MaxLines,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_0600")
Text('ArkUX_Stage_Button_LabelStyle_0700').fontSize(15).margin({top:20})
Button(this.txtG)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Ellipsis,
maxLines: 3, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MaxLines,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_0700")
Text('ArkUX_Stage_Button_LabelStyle_0800').fontSize(15).margin({top:20})
Button(this.txtH)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Ellipsis,
maxLines: 1, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MinFontSize,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_0800")
Text('ArkUX_Stage_Button_LabelStyle_0900').fontSize(15).margin({top:20})
Button(this.txtI)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Ellipsis,
maxLines: 1, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MinFontSize,
font: { weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Normal } })
.key("ArkUX_Stage_Button_LabelStyle_0900")
Text('ArkUX_Stage_Button_LabelStyle_1000').fontSize(15).margin({top:20})
Button(this.txtJ)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Ellipsis,
maxLines: 3, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.LayoutConstraint,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_1000")
Text('ArkUX_Stage_Button_LabelStyle_1100').fontSize(15).margin({top:20})
Button(this.txtK)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.None,
maxLines: 1, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MaxLines,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_1100")
Text('ArkUX_Stage_Button_LabelStyle_1200').fontSize(15).margin({top:20})
Button(this.txtL)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.None,
maxLines: 3, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MaxLines,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_1200")
Text('ArkUX_Stage_Button_LabelStyle_1300').fontSize(15).margin({top:20})
Button(this.txtM)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.None,
maxLines: 1, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MinFontSize,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_1300")
Text('ArkUX_Stage_Button_LabelStyle_1400').fontSize(15).margin({top:20})
Button(this.txtN)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.None,
maxLines: 1, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MinFontSize,
font: { weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Normal } })
.key("ArkUX_Stage_Button_LabelStyle_1400")
Text('ArkUX_Stage_Button_LabelStyle_1500').fontSize(15).margin({top:20})
Button(this.txtO)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.None,
maxLines: 3, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.LayoutConstraint,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_1500")
Text('ArkUX_Stage_Button_LabelStyle_1600').fontSize(15).margin({top:20})
Button(this.txtP)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Ellipsis,
maxLines: 1 })
.key("ArkUX_Stage_Button_LabelStyle_1600")
Text('ArkUX_Stage_Button_LabelStyle_1700').fontSize(15).margin({top:20})
Button(this.txtQ)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Ellipsis,
minFontSize: 5 })
.key("ArkUX_Stage_Button_LabelStyle_1700")
Text('ArkUX_Stage_Button_LabelStyle_1800').fontSize(15).margin({top:20})
Button(this.txtR)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Ellipsis,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MaxLines
})
.key("ArkUX_Stage_Button_LabelStyle_1800")
Text('ArkUX_Stage_Button_LabelStyle_1900').fontSize(15).margin({top:20})
Button(this.txtS)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Ellipsis,
font: { size: 15, weight: FontWeight.Medium, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_1900")
Text('ArkUX_Stage_Button_LabelStyle_2000').fontSize(15).margin({top:20})
Button(this.txtT)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Ellipsis })
.key("ArkUX_Stage_Button_LabelStyle_2000")
Text('ArkUX_Stage_Button_LabelStyle_2100').fontSize(15).margin({top:20})
Button(this.txtU)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ maxLines: 1, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MaxLines,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_2100")
Text('ArkUX_Stage_Button_LabelStyle_2200').fontSize(15).margin({top:20})
Button(this.txtV)
.width(this.widthShortSize)
.key("ArkUX_Stage_Button_LabelStyle_2200")
Text('ArkUX_Stage_Button_LabelStyle_2300').fontSize(15).margin({top:20})
Button(this.txtW)
.width(this.widthLongSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Clip,
maxLines: 1, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MaxLines,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_2300")
Text('ArkUX_Stage_Button_LabelStyle_2400').fontSize(15).margin({top:20})
Button(this.txtX)
.width(this.widthLongSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Ellipsis,
maxLines: 1, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MaxLines,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_2400")
Text('ArkUX_Stage_Button_LabelStyle_2500').fontSize(15).margin({top:20})
Button(this.txtY)
.width(this.widthLongSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.None,
maxLines: 1, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MaxLines,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_2500")
Text('ArkUX_Stage_Button_LabelStyle_2600').fontSize(15).margin({top:20})
Button(this.txtZ)
.width(this.widthLongSize)
.key("ArkUX_Stage_Button_LabelStyle_2600")
Text('ArkUX_Stage_Button_LabelStyle_2700').fontSize(15).margin({top:20})
Button(this.txta)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: null,
maxLines: 1, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MaxLines,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_2700")
Text('ArkUX_Stage_Button_LabelStyle_2800').fontSize(15).margin({top:20})
Button(this.txtb)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: 0,
maxLines: 1, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MaxLines,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_2800")
Text('ArkUX_Stage_Button_LabelStyle_2900').fontSize(15).margin({top:20})
Button(this.txtc,{ type: ButtonType.Capsule, stateEffect: false }).opacity(0.4)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Clip,
maxLines: 1, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MaxLines,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_2900")
Text('ArkUX_Stage_Button_LabelStyle_3000').fontSize(15).margin({top:20})
Button(this.txtd)
.width(this.widthShortSize)
// @ts-ignore
.labelStyle({ overflow: TextOverflow.Race,
maxLines: 1, minFontSize: 5,
heightAdaptivePolicy:TextHeightAdaptivePolicy.MaxLines,
font: { size: 15, weight: FontWeight.Bolder, family: 'cursive', style: FontStyle.Italic } })
.key("ArkUX_Stage_Button_LabelStyle_3000")
}
}
.scrollBar(BarState.Off)
.scrollable(ScrollDirection.Vertical)
ScrollBar({ scroller: this.scroller, direction: ScrollBarDirection.Vertical, state: BarState.Auto })
}
}
.width('100%')
}
}
/*
* 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
/*
* 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 buttonTest from './button'
export default function testsuite() {
buttonTest()
}
\ No newline at end of file
{
"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"
]
}
]
}
]
}
}
{
"color": [
{
"name": "start_window_background",
"value": "#FFFFFF"
},
{
"name": "Divider_color",
"value": "#000000"
},
{
"name": "TextInput_Color",
"value": "#FFFD0000"
}
]
}
\ No newline at end of file
{
"string": [
{
"name": "module_test_desc",
"value": "test ability description"
},
{
"name": "TestAbility_desc",
"value": "the test ability"
},
{
"name": "TestAbility_label",
"value": "test label"
},
{
"name": "Divider_width",
"value": "10px"
},
{
"name": "Divider_startMargin",
"value": "5px"
},
{
"name": "Divider_endMargin",
"value": "5px"
},
{
"name": "textInput_Size_test",
"value": "4"
}
]
}
\ No newline at end of file
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册