# @ohos.UiTest
UiTest提供模拟UI操作的能力,供开发者在测试场景使用,主要支持如点击、双击、长按、滑动等UI操作能力。
该模块提供以下功能:
- [On9+](#on9):提供控件特征描述能力,用于控件筛选匹配查找。
- [Component9+](#component9):代表UI界面上的指定控件,提供控件属性获取,控件点击,滑动查找,文本注入等能力。
- [Driver9+](#driver9):入口类,提供控件匹配/查找,按键注入,坐标点击/滑动,截图等能力。
- [UiWindow9+](#uiwindow9):入口类,提供窗口属性获取,窗口拖动、调整窗口大小等能力。
- [By(deprecated)](#bydeprecated):提供控件特征描述能力,用于控件筛选匹配查找。从API version 9开始不再维护,建议使用[On9+](#on9)。
- [UiComponent(deprecated)](#uicomponentdeprecated):代表UI界面上的指定控件,提供控件属性获取,控件点击,滑动查找,文本注入等能力。从API version 9开始不再维护,建议使用[Component9+](#component9)。
- [UiDriver(deprecated)](#uidriverdeprecated):入口类,提供控件匹配/查找,按键注入,坐标点击/滑动,截图等能力。从API version 9开始不再维护,建议使用[Driver9+](#driver9)。
> **说明:**
> - 本模块首批接口从API version 8开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
> - 本模块接口在[自动化测试脚本](../../application-test/arkxtest-guidelines.md)中使用。
> - 本模块接口不支持并发调用。
## 导入模块
```ts
import { Component, Driver, UiWindow, ON, MatchPattern, DisplayRotation, ResizeDirection, WindowMode, PointerMatrix, UiDirection, MouseButton, UIElementInfo, UIEventObserver, UiComponent, UiDriver, BY } from '@kit.TestKit';
```
## MatchPattern
控件属性支持的匹配模式。
**系统能力**:SystemCapability.Test.UiTest
| 名称 | 值 | 说明 |
|-----------------------|---|---------------------------------------------------------------------|
| EQUALS | 0 | 等于给定值。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。 |
| CONTAINS | 1 | 包含给定值。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。 |
| STARTS_WITH | 2 | 以给定值开始。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。 |
| ENDS_WITH | 3 | 以给定值结束。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。 |
| REG_EXP18+ | 4 | 正则表达式匹配。
**原子化服务API:** 从API version 18开始,该接口支持在原子化服务中使用。 |
| REG_EXP_ICASE18+ | 5 | 正则表达式匹配,忽略大小写。
**原子化服务API:** 从API version 18开始,该接口支持在原子化服务中使用。 |
## ResizeDirection9+
窗口调整大小的方向。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
| 名称 | 值 | 说明 |
| ---------- | ---- | -------- |
| LEFT | 0 | 左方。 |
| RIGHT | 1 | 右方。 |
| UP | 2 | 上方。 |
| DOWN | 3 | 下方。 |
| LEFT_UP | 4 | 左上方。 |
| LEFT_DOWN | 5 | 左下方。 |
| RIGHT_UP | 6 | 右上方。 |
| RIGHT_DOWN | 7 | 右下方。 |
## Point9+
坐标点信息。
**系统能力**:SystemCapability.Test.UiTest
| 名称 | 类型 | 只读 | 可选 | 说明 |
| ---- | ------ | ---- | ---- |-----------|
| x | number | 否 | 否 | 坐标点的横坐标,取值大于0的整数。
**说明:** 从API version 20开始,该属性不再为只读属性。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。 |
| y | number | 否 | 否 | 坐标点的纵坐标,取值大于0的整数。
**说明:** 从API version 20开始,该属性不再为只读属性。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。|
| displayId20+ | number | 否 | 是 | 坐标点所属的屏幕ID,取值范围:大于等于0的整数。默认值为设备默认屏幕ID。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。|
## Rect9+
控件的边框信息。
**系统能力**:SystemCapability.Test.UiTest
| 名称 | 类型 | 只读 | 可选 | 说明 |
| ------ | ------ | ---- | ---- | ------------------------- |
| left | number | 否 | 否 |控件边框的左上角的X坐标,取值大于0的整数。
**说明:** 从API version 20开始,该属性不再为只读属性。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。 |
| top | number | 否 | 否 |控件边框的左上角的Y坐标,取值大于0的整数。
**说明:** 从API version 20开始,该属性不再为只读属性。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。 |
| right | number | 否 | 否 |控件边框的右下角的X坐标,取值大于0的整数。
**说明:** 从API version 20开始,该属性不再为只读属性。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。 |
| bottom | number | 否 | 否 |控件边框的右下角的Y坐标,取值大于0的整数。
**说明:** 从API version 20开始,该属性不再为只读属性。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。 |
| displayId20+ | number | 否 | 是 |控件边框所属的屏幕ID,取值大于或等于0的整数。默认值为设备默认屏幕ID。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。 |
## WindowMode9+
窗口的窗口模式。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
| 名称 | 值 | 说明 |
| ---------- | ---- | ---------- |
| FULLSCREEN | 0 | 全屏模式。 |
| PRIMARY | 1 | 主窗口。 |
| SECONDARY | 2 | 第二窗口。 |
| FLOATING | 3 | 浮动窗口。 |
## DisplayRotation9+
设备显示器的显示方向。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
| 名称 | 值 | 说明 |
| ------------ | ---- | ---------------------------------------- |
| ROTATION_0 | 0 | 设备显示器不旋转,初始形态垂直显示。 |
| ROTATION_90 | 1 | 设备显示器顺时针旋转90°,水平显示。 |
| ROTATION_180 | 2 | 设备显示器顺时针旋转180°,逆向垂直显示。 |
| ROTATION_270 | 3 | 设备显示器顺时针旋转270°,逆向水平显示。 |
## WindowFilter9+
窗口的标志属性信息。
**系统能力**:SystemCapability.Test.UiTest
| 名称 | 类型 | 只读 | 可选 | 说明 |
| -------------------- | ------- | ---- | ---- |----------------------------------------------------------------------------------------|
| bundleName | string | 否 | 是 | 窗口归属应用的包名,默认值为空。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。 |
| title | string | 否 | 是 | 窗口的标题信息,默认值为空。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。 |
| focused | boolean | 否 | 是 | 窗口是否处于获焦状态,true:获焦状态,false:未获焦状态,默认值为false。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。 |
| actived(deprecated) | boolean | 否 | 是 | 窗口是否正与用户进行交互,true:交互状态,false:未交互状态,默认值为false。
从API version 11开始废弃,建议使用active替代。 |
| active11+ | boolean | 否 | 是 | 窗口是否正与用户进行交互,true:交互状态,false:未交互状态,默认值为false。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。 |
| displayId20+ | number | 否 | 是 | 窗口所属的屏幕ID。取值大于或等于0的整数。默认值为设备默认屏ID。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。 |
## UiDirection10+
进行抛滑等UI操作时的方向。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
| 名称 | 值 | 说明 |
| ----- | ---- | ------ |
| LEFT | 0 | 向左。 |
| RIGHT | 1 | 向右。 |
| UP | 2 | 向上。 |
| DOWN | 3 | 向下。 |
## MouseButton10+
模拟注入的鼠标按钮。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
| 名称 | 值 | 说明 |
| ------------------- | ---- | ------------ |
| MOUSE_BUTTON_LEFT | 0 | 鼠标左键。 |
| MOUSE_BUTTON_RIGHT | 1 | 鼠标右键。 |
| MOUSE_BUTTON_MIDDLE | 2 | 鼠标中间键。 |
## UIElementInfo10+
UI事件的相关信息。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
| 名称 | 类型 | 只读 | 可选 | 说明 |
| ---------- | ------ | ---- | ---- | --------------------- |
| bundleName | string | 是 | 否 | 归属应用的包名。 |
| type | string | 是 | 否 | 控件/窗口类型。 |
| text | string | 是 | 否 | 控件/窗口的文本信息。 |
## TouchPadSwipeOptions18+
触摸板多指滑动手势选项相关信息。
**原子化服务API:** 从API version 18开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
| 名称 | 类型 | 只读 | 可选 | 说明 |
| ---------- | ------ |----|----|--------------------------------------------------------|
| stay | boolean | 否 | 是 | 触摸板多指滑动结束是否停留1s后再抬起,默认为false(不停留1s),true:停留,false:不停留。 |
| speed | number | 否 | 是 | 滑动速率,取值范围为200-40000的整数,默认值为2000,不在范围内设为默认值为2000,单位:px/s。 |
## InputTextMode20+
输入文本的方式。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
| 名称 | 类型 | 只读 | 可选 | 说明 |
| ---------- | ------ |----|----|----------------------------------------------------------|
| paste | boolean | 否 | 是 | 输入文本时是否指定以复制粘贴方式输入。true:指定以复制粘贴方式输入。false:指定以逐字键入方式输入。默认为false。
**说明:** 当输入文本中包含中文、特殊字符或文本长度超过200字符时,无论该参数取值为何,均以复制粘贴方式输入。|
| addition | boolean | 否 | 是 | 输入文本时是否以追加的方式进行输入。true:以追加方式输入。false:不以追加方式输入。默认为false。|
## On9+
UiTest框架从API version 9开始,通过On类提供了丰富的控件特征描述API,用于进行控件筛选来匹配/查找出目标控件。
On提供的API能力具有以下几个特点:
1、支持单属性匹配和多属性组合匹配,例如同时指定目标控件text和id。
2、控件属性支持多种匹配模式。
3、支持控件绝对定位,相对定位,可通过[ON.isBefore](#isbefore9)和[ON.isAfter](#isafter9)等API限定邻近控件特征进行辅助定位。
On类提供的所有API均为同步接口,建议使用者通过静态构造器ON来链式创建On对象。
```ts
import { ON } from '@kit.TestKit';
ON.text('123').type('Button');
```
### text9+
text(txt: string, pattern?: MatchPattern): On
指定目标控件文本属性,支持多种匹配模式,返回On对象自身。
> **说明**
>
> 如果控件的无障碍属性[accessibilityLevel](../apis-arkui/arkui-ts/ts-universal-attributes-accessibility.md#accessibilitylevel)设置为'no'或'no-hide-descendants',无法使用本接口指定目标控件的文本属性用于查找控件,可以使用[On.originalText()](#originaltext20)接口实现。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------- | ----------------------------- | ---- | --------------------------------------------------- |
| txt | string | 是 | 指定控件文本,用于匹配目标控件文本。 |
| pattern | [MatchPattern](#matchpattern) | 否 | 指定的文本匹配模式,默认为[EQUALS](#matchpattern)。 |
**返回值:**
| 类型 | 说明 |
| ---------- | ---------------------------------- |
| [On](#on9) | 返回指定目标控件文本属性的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
let on:On = ON.text('123'); // 使用静态构造器ON创建On对象,指定目标控件的text属性。
```
### id9+
id(id: string): On
指定目标控件id属性,返回On对象自身。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ---------------- |
| id | string | 是 | 指定控件的id值。 |
**返回值:**
| 类型 | 说明 |
| ---------- | -------------------------------- |
| [On](#on9) | 返回指定目标控件id属性的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
let on:On = ON.id('123'); // 使用静态构造器ON创建On对象,指定目标控件的id属性。
```
### id18+
id(id: string, pattern: MatchPattern): On
指定目标控件id属性,返回On对象自身。
**原子化服务API:** 从API version 18开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
|-----------------------| ------ |----|---------------------------------------|
| id | string | 是 | 指定控件的id值。 |
| pattern | [MatchPattern](#matchpattern) | 是 | 指定的文本匹配模式。 |
**返回值:**
| 类型 | 说明 |
| ---------- | -------------------------------- |
| [On](#on9) | 返回指定目标控件id属性的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { MatchPattern, On, ON } from '@kit.TestKit';
let on:On = ON.id('id', MatchPattern.REG_EXP_ICASE); // 忽略大小写匹配控件的id属性值
```
### type9+
type(tp: string): On
指定目标控件的控件类型属性,返回On对象自身。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | -------------- |
| tp | string | 是 | 指定控件类型。 |
**返回值:**
| 类型 | 说明 |
| ---------- | ---------------------------------------- |
| [On](#on9) | 返回指定目标控件的控件类型属性的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
let on:On = ON.type('Button'); // 使用静态构造器ON创建On对象,指定目标控件的控件类型属性。
```
### type18+
type(tp: string, pattern: MatchPattern): On
指定目标控件的控件类型属性,返回On对象自身。
**原子化服务API:** 从API version 18开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
|-----------------------| ------ |----|---------------------------------------|
| tp | string | 是 | 指定控件类型。 |
| pattern | [MatchPattern](#matchpattern) | 是 | 指定的文本匹配模式。 |
**返回值:**
| 类型 | 说明 |
| ---------- | ---------------------------------------- |
| [On](#on9) | 返回指定目标控件的控件类型属性的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { On, ON, MatchPattern } from '@kit.TestKit';
let on:On = ON.type('Button', MatchPattern.EQUALS); // 使用静态构造器ON创建On对象,指定目标控件的控件类型属性。
```
### clickable9+
clickable(b?: boolean): On
指定目标控件的可点击状态属性,返回On对象自身。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------- | ---- | ------------------------------------------------------------ |
| b | boolean | 否 | 指定控件可点击状态。true:可点击。false:不可点击。默认为true。 |
**返回值:**
| 类型 | 说明 |
| ---------- | ------------------------------------------ |
| [On](#on9) | 返回指定目标控件的可点击状态属性的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1. Incorrect parameter types; 2. Parameter verification failed.|
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
let on:On = ON.clickable(true); // 使用静态构造器ON创建On对象,指定目标控件的可点击状态属性。
```
### longClickable9+
longClickable(b?: boolean): On
指定目标控件的可长按点击状态属性,返回On对象自身。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------- | ---- | ------------------------------------------------------------ |
| b | boolean | 否 | 指定控件可长按点击状态。true:可长按点击。false:不可长按点击。默认为true。 |
**返回值:**
| 类型 | 说明 |
| ---------- | ---------------------------------------------- |
| [On](#on9) | 返回指定目标控件的可长按点击状态属性的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1. Incorrect parameter types; 2. Parameter verification failed.|
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
let on:On = ON.longClickable(true); // 使用静态构造器ON创建On对象,指定目标控件的可长按点击状态属性。
```
### scrollable9+
scrollable(b?: boolean): On
指定目标控件的可滑动状态属性,返回On对象自身。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------- | ---- | ----------------------------------------------------------- |
| b | boolean | 否 | 控件可滑动状态。true:可滑动。false:不可滑动。默认为true。 |
**返回值:**
| 类型 | 说明 |
| ---------- | ------------------------------------------ |
| [On](#on9) | 返回指定目标控件的可滑动状态属性的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1. Incorrect parameter types; 2. Parameter verification failed.|
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
let on:On = ON.scrollable(true); // 使用静态构造器ON创建On对象,指定目标控件的可滑动状态属性。
```
### enabled9+
enabled(b?: boolean): On
指定目标控件的使能状态属性,返回On对象自身。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------- | ---- | --------------------------------------------------------- |
| b | boolean | 否 | 指定控件使能状态。true:使能。false:未使能。默认为true。 |
**返回值:**
| 类型 | 说明 |
| ---------- | ---------------------------------------- |
| [On](#on9) | 返回指定目标控件的使能状态属性的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1. Incorrect parameter types; 2. Parameter verification failed.|
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
let on:On = ON.enabled(true); // 使用静态构造器ON创建On对象,指定目标控件的使能状态属性。
```
### focused9+
focused(b?: boolean): On
指定目标控件的获焦状态属性,返回On对象自身。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------- | ---- | ----------------------------------------------------- |
| b | boolean | 否 | 控件获焦状态。true:获焦。false:未获焦。默认为true。 |
**返回值:**
| 类型 | 说明 |
| ---------- | ---------------------------------------- |
| [On](#on9) | 返回指定目标控件的获焦状态属性的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1. Incorrect parameter types; 2. Parameter verification failed.|
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
let on:On = ON.focused(true); // 使用静态构造器ON创建On对象,指定目标控件的获焦状态属性。
```
### selected9+
selected(b?: boolean): On
指定目标控件的被选中状态属性,返回On对象自身。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------- | ---- | ------------------------------------------------------------ |
| b | boolean | 否 | 指定控件被选中状态。true:被选中。false:未被选中。默认为true。 |
**返回值:**
| 类型 | 说明 |
| ---------- | ------------------------------------------ |
| [On](#on9) | 返回指定目标控件的被选中状态属性的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1. Incorrect parameter types; 2. Parameter verification failed.|
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
let on:On = ON.selected(true); // 使用静态构造器ON创建On对象,指定目标控件的被选中状态属性。
```
### checked9+
checked(b?: boolean): On
指定目标控件的被勾选状态属性,返回On对象自身。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------- | ---- | ------------------------------------------------------------ |
| b | boolean | 否 | 指定控件被勾选状态。true:被勾选。false:未被勾选。默认为true。 |
**返回值:**
| 类型 | 说明 |
| ---------- | ------------------------------------------ |
| [On](#on9) | 返回指定目标控件的被勾选状态属性的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1. Incorrect parameter types; 2. Parameter verification failed.|
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
let on:On = ON.checked(true); // 使用静态构造器ON创建On对象,指定目标控件的被勾选状态属性
```
### checkable9+
checkable(b?: boolean): On
指定目标控件能否被勾选状态属性,返回On对象自身。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------- | ---- | ------------------------------------------------------------ |
| b | boolean | 否 | 指定控件能否被勾选状态。true:能被勾选。false:不能被勾选。默认为true。 |
**返回值:**
| 类型 | 说明 |
| ---------- | -------------------------------------------- |
| [On](#on9) | 返回指定目标控件能否被勾选状态属性的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. 1. Incorrect parameter types; 2. Parameter verification failed. |
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
let on:On = ON.checkable(true); // 使用静态构造器ON创建On对象,指定目标控件的能否被勾选状态属性。
```
### isBefore9+
isBefore(on: On): On
指定目标控件位于给出的特征属性控件之前,返回On对象自身。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ---------- | ---- | -------------------- |
| on | [On](#on9) | 是 | 特征控件的属性要求。 |
**返回值:**
| 类型 | 说明 |
| ---------- | ---------------------------------------------------- |
| [On](#on9) | 返回指定目标控件位于给出的特征属性控件之前的On对象。|
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
// 使用静态构造器ON创建On对象,指定目标控件位于给出的特征属性控件之前。
let on:On = ON.type('Button').isBefore(ON.text('123')); // 查找text为123之前的第一个Button组件
```
### isAfter9+
isAfter(on: On): On
指定目标控件位于给出的特征属性控件之后,返回On对象自身。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ---------- | ---- | -------------------- |
| on | [On](#on9) | 是 | 特征控件的属性要求。 |
**返回值:**
| 类型 | 说明 |
| ---------- | ---------------------------------------------------- |
| [On](#on9) | 返回指定目标控件位于给出的特征属性控件之后的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
// 使用静态构造器ON创建On对象,指定目标控件位于给出的特征属性控件之后。
let on:On = ON.type('Text').isAfter(ON.text('123')); // 查找 text为123之后的第一个Text组件
```
### within10+
within(on: On): On
指定目标控件位于给出的特征属性控件之内,返回On对象自身。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ---------- | ---- | -------------------- |
| on | [On](#on9) | 是 | 特征控件的属性要求。 |
**返回值:**
| 类型 | 说明 |
| ---------- | -------------------------------------------------- |
| [On](#on9) | 返回指定目标控件位于给出的特征属性控件内的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
// 使用静态构造器ON创建On对象,指定目标控件位于给出的特征属性控件之内。
let on:On = ON.text('java').within(ON.type('Scroll')); // 查找Scroller里面的text为java的子组件
```
### inWindow10+
inWindow(bundleName: string): On
指定目标控件位于给出的应用窗口内,返回On对象自身。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ---------- | ------ | ---- | ---------------- |
| bundleName | string | 是 | 应用窗口的包名。 |
**返回值:**
| 类型 | 说明 |
| ---------- | ---------------------------------------------- |
| [On](#on9) | 返回指定目标控件位于给出的应用窗口内的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
let on:On = ON.inWindow('com.uitestScene.acts'); // 使用静态构造器ON创建On对象,指定目标控件位于给出的应用窗口内。
```
### description11+
description(val: string, pattern?: MatchPattern): On
指定目标控件的描述属性,支持多种匹配模式,返回On对象自身。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------- | ----------------------------- | ---- | --------------------------------------------------- |
| val | string | 是 | 控件的描述属性。 |
| pattern | [MatchPattern](#matchpattern) | 否 | 指定的文本匹配模式,默认为[EQUALS](#matchpattern)。 |
**返回值:**
| 类型 | 说明 |
| ---------- | ----------------------------------------- |
| [On](#on9) | 返回指定目标控件description属性的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
let on:On = ON.description('123'); // 使用静态构造器ON创建On对象,指定目标控件的description属性。
```
### hint18+
hint(val: string, pattern?: MatchPattern): On
获取指定提示文本的控件对象,返回On对象自身。
**原子化服务API:** 从API version 18开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ |----|---------------------------------------|
| val | string | 是 | 指定控件提示文本。 |
| pattern | [MatchPattern](#matchpattern) | 否 | 指定的文本匹配模式,默认为[EQUALS](#matchpattern)。 |
**返回值:**
| 类型 | 说明 |
| ---------- | ---------------------------------------- |
| [On](#on9) | 返回指定提示文本控件的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { MatchPattern, On, ON } from '@kit.TestKit';
let on:On = ON.hint('welcome', MatchPattern.EQUALS); // 使用静态构造器ON创建On对象,指定目标控件的提示文本属性。
```
### belongingDisplay20+
belongingDisplay(displayId: number): On
获取指定屏幕内的控件对象,返回On对象自身。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ |----|---------------------------------------|
| displayId | number | 是 | 指定控件所属屏幕ID,取值范围:大于等于0的整数。
**说明:** 传入displayId不存在时,将抛出17000007异常。可通过[getAllDisplays](../apis-arkui/js-apis-display.md#displaygetalldisplays9)获取当前所有的display对象,并由display对象获取对应的屏幕ID。 |
**返回值:**
| 类型 | 说明 |
| ---------- | ---------------------------------------- |
| [On](#on9) | 返回指定控件所属屏幕的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000007 | Parameter verification failed.|
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
let on:On = ON.belongingDisplay(0); // 使用静态构造器ON创建On对象,指定目标控件所属屏幕ID
```
### originalText20+
originalText(text: string, pattern?: MatchPattern): On
指定目标控件的文本属性,支持多种匹配模式,返回On对象自身。
> **说明**
>
> 如果控件的无障碍属性[accessibilityLevel](../apis-arkui/arkui-ts/ts-universal-attributes-accessibility.md#accessibilitylevel)设置为'no'或'no-hide-descendants',可以使用本接口指定目标控件的文本属性用于查找控件,使用[On.text()](#text9)接口不生效。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------- | ----------------------------- | ---- | --------------------------------------------------- |
| text | string | 是 | 指定控件文本,用于匹配目标控件文本。 |
| pattern | [MatchPattern](#matchpattern) | 否 | 指定的文本匹配模式,默认为[EQUALS](#matchpattern)。 |
**返回值:**
| 类型 | 说明 |
| ---------- | ---------------------------------- |
| [On](#on9) | 返回指定目标控件文本属性的On对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000007 | Parameter verification failed.|
**示例:**
```ts
import { On, ON } from '@kit.TestKit';
let on:On = ON.originalText('123'); // 使用静态构造器ON创建On对象,指定目标控件的originalText属性
```
## Component9+
UiTest框架在API9中,Component类代表了UI界面上的一个控件,提供控件属性获取,控件点击,滑动查找,文本注入等API。
该类提供的所有方法都使用Promise方式作为异步方法,需使用await调用。
### click9+
click(): Promise\
控件对象进行点击操作,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Driver, ON, Component } from '@kit.TestKit';
async function demo() {
let driver:Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('Button'));
await button.click();
}
```
### doubleClick9+
doubleClick(): Promise\
控件对象进行双击操作,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import {Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('Button'));
await button.doubleClick();
}
```
### longClick9+
longClick(): Promise\
控件对象进行长按操作,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('Button'));
await button.longClick();
}
```
### getId9+
getId(): Promise\
获取控件对象的id值,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ---------------- | ------------------------------- |
| Promise\ | Promise对象,返回控件的id值。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('Button'));
let id = await button.getId();
}
```
### getText9+
getText(): Promise\
获取控件对象的文本信息,使用Promise异步回调。
> **说明**
>
> 如果控件的无障碍属性[accessibilityLevel](../apis-arkui/arkui-ts/ts-universal-attributes-accessibility.md#accessibilitylevel)设置为'no'或'no-hide-descendants',无法使用本接口获取控件的文本信息,可以使用[Component.getOriginalText()](#getoriginaltext20)获取控件的文本信息。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ---------------- | --------------------------------- |
| Promise\ | Promise对象,返回控件的文本信息。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('Button'));
let text = await button.getText();
}
```
### getType9+
getType(): Promise\
获取控件对象的控件类型,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ---------------- | ----------------------------- |
| Promise\ | Promise对象,返回控件的类型。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('Button'));
let type = await button.getType();
}
```
### getBounds9+
getBounds(): Promise\
获取控件对象的边框信息,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ------------------------ | ------------------------------------- |
| Promise\<[Rect](#rect9)> | Promise对象,返回控件对象的边框信息。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('Button'));
let rect = await button.getBounds();
}
```
### getBoundsCenter9+
getBoundsCenter(): Promise\
获取控件对象所占区域的中心点信息,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| -------------------------- | ----------------------------------------------- |
| Promise\<[Point](#point9)> | Promise对象,返回控件对象所占区域的中心点信息。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('Button'));
let point = await button.getBoundsCenter();
}
```
### isClickable9+
isClickable(): Promise\
获取控件对象可点击属性,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ----------------- | ------------------------------------------------------------ |
| Promise\ | Promise对象,返回控件对象是否可点击。true:可点击。false:不可点击。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('Button'));
if(await button.isClickable()) {
console.info('This button can be Clicked');
} else {
console.info('This button can not be Clicked');
}
}
```
### isLongClickable9+
isLongClickable(): Promise\
获取控件对象可长按点击属性,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ----------------- |--------------------------------------------------|
| Promise\ | Promise对象,返回控件对象是否可长按点击。true:可长按点击。false:不可长按点击。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('Button'));
if(await button.isLongClickable()) {
console.info('This button can longClick');
} else {
console.info('This button can not longClick');
}
}
```
### isChecked9+
isChecked(): Promise\
获取控件对象被勾选状态,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ----------------- | ------------------------------------------------------------ |
| Promise\ | Promise对象,返回控件对象被勾选状态。true:被勾选。false:未被勾选。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let checkBox: Component = await driver.findComponent(ON.type('Checkbox'));
if(await checkBox.isChecked()) {
console.info('This checkBox is checked');
} else {
console.info('This checkBox is not checked');
}
}
```
### isCheckable9+
isCheckable(): Promise\
获取控件对象能否被勾选属性,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ----------------- | ------------------------------------------------------------ |
| Promise\ | Promise对象,返回控件对象能否可被勾选属性。true:可被勾选。false:不可被勾选。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let checkBox: Component = await driver.findComponent(ON.type('Checkbox'));
if(await checkBox.isCheckable()) {
console.info('This checkBox is checkable');
} else {
console.info('This checkBox is not checkable');
}
}
```
### isScrollable9+
isScrollable(): Promise\
获取控件对象可滑动属性,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ----------------- | ------------------------------------------------------------ |
| Promise\ | Promise对象,返回控件对象是否可滑动。true:可滑动。false:不可滑动。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let scrollBar: Component = await driver.findComponent(ON.scrollable(true));
if(await scrollBar.isScrollable()) {
console.info('This scrollBar can be operated');
} else {
console.info('This scrollBar can not be operated');
}
}
```
### isEnabled9+
isEnabled(): Promise\
获取控件使能状态,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ----------------- | ---------------------------------------------------------- |
| Promise\ | Promise对象,返回控件使能状态。true:使能。false:未使能。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('Button'));
if(await button.isEnabled()) {
console.info('This button can be operated');
} else {
console.info('This button can not be operated');
}
}
```
### isFocused9+
isFocused(): Promise\
判断控件对象获焦状态,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ----------------- | ------------------------------------------------------------ |
| Promise\ | Promise对象,返回控件对象获焦状态。true:获焦。false:未获焦。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('Button'));
if(await button.isFocused()) {
console.info('This button is focused');
} else {
console.info('This button is not focused');
}
}
```
### isSelected9+
isSelected(): Promise\
获取控件对象被选中状态,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ----------------- | --------------------------------------------------- |
| Promise\ | Promise对象,返回控件对象被选中状态。true:被选中。false:未被选中。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('Button'));
if(await button.isSelected()) {
console.info('This button is selected');
} else {
console.info('This button is not selected');
}
}
```
### inputText9+
inputText(text: string): Promise\
清空组件内原有文本并输入指定文本内容,仅针对可编辑的文本组件生效,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ---------------------------------------- |
| text | string | 是 | 输入的文本信息,当前支持英文、中文和特殊字符。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let text: Component = await driver.findComponent(ON.text('hello world'));
await text.inputText('123');
}
```
### inputText20+
inputText(text: string, mode: InputTextMode): Promise\
向控件中输入文本,并支持指定文本输入方式,仅针对可编辑的文本组件生效,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ---------------------------------------- |
| text | string | 是 | 输入的文本信息,当前支持英文、中文和特殊字符。 |
| mode | [InputTextMode](#inputtextmode20) | 是 | 输入文本的方式,取值请参考[InputTextMode](#inputtextmode20)。
**说明:** InputTextMode.addition取值为ture时,在控件已有文本末尾后追加指定文本。取值为false时,指定文本将覆盖控件已有文本。|
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
| 801 | Capability not supported, function can not work correctly due to limited device capabilities.|
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function mode_demo() {
let driver: Driver = Driver.create();
let text: Component = await driver.findComponent(ON.text('hello world'));
await text.inputText('123', { paste: true, addition: false });
}
```
### clearText9+
clearText(): Promise\
清除控件的文本信息,仅针对可编辑的文本组件生效,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let text: Component = await driver.findComponent(ON.text('hello world'));
await text.clearText();
}
```
### scrollSearch9+
scrollSearch(on: On): Promise\
在控件上滑动查找目标控件(适用支持滑动的控件),使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ---------- | ---- | -------------------- |
| on | [On](#on9) | 是 | 目标控件的属性要求。 |
**返回值:**
| 类型 | 说明 |
| ---------------------------------- | ------------------------------------- |
| Promise\<[Component](#component9)> | Promise对象,返回目标控件对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let scrollBar: Component = await driver.findComponent(ON.type('Scroll'));
let button = await scrollBar.scrollSearch(ON.text('next page'));
}
```
### scrollSearch18+
scrollSearch(on: On, vertical?: boolean, offset?: number): Promise\
在控件上滑动查找目标控件(适用支持滑动的控件),使用Promise异步回调。
**原子化服务API:** 从API version 18开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
|------------------------| ---------- | ---- |-----------------------------------|
| on | [On](#on9) | 是 | 目标控件的属性要求。 |
| vertical | boolean | 否 | 默认为true,表示查找方向是纵向。false表示查找方向为横向。 |
| offset | number| 否 | 滑动起点/终点到组件边框的偏移,默认80,单位:px,取值范围:大于等于0的整数。 |
**返回值:**
| 类型 | 说明 |
| ---------------------------------- | ------------------------------------- |
| Promise\<[Component](#component9)> | Promise对象,返回目标控件对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let scrollBar: Component = await driver.findComponent(ON.type('Scroll'));
let button = await scrollBar.scrollSearch(ON.text('next page'));
}
```
### scrollToTop9+
scrollToTop(speed?: number): Promise\
在控件上滑动到顶部(适用支持滑动的控件),使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- |--------------------------------------------------------|
| speed | number | 否 | 滑动速率,取值范围为200-40000的整数,默认值为600,不在范围内设为默认值为600,单位:px/s。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
| 401 | Parameter error. Possible causes: 1. Incorrect parameter types; 2. Parameter verification failed.|
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let scrollBar: Component = await driver.findComponent(ON.type('Scroll'));
await scrollBar.scrollToTop();
}
```
### scrollToBottom9+
scrollToBottom(speed?: number): Promise\
在控件上滑动到底部(适用支持滑动的控件),使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- |--------------------------------------------------------|
| speed | number | 否 | 滑动速率,取值范围为200-40000的整数,默认值为600,不在范围内设为默认值为600,单位:px/s。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
| 401 | Parameter error. Possible causes: 1. Incorrect parameter types; 2. Parameter verification failed.|
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let scrollBar: Component = await driver.findComponent(ON.type('Scroll'));
await scrollBar.scrollToBottom();
}
```
### dragTo9+
dragTo(target: Component): Promise\
将控件拖拽至目标控件处,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**设备行为差异**:该接口在Phone、Tablet、PC/2in1、TV设备上生效,在其他设备中调用无效果。
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------------------------ | ---- | ---------- |
| target | [Component](#component9) | 是 | 目标控件。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('Button'));
let text: Component = await driver.findComponent(ON.text('hello world'));
await button.dragTo(text);
}
```
### pinchOut9+
pinchOut(scale: number): Promise\
将控件按指定的比例进行捏合放大,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ------------------------------- |
| scale | number | 是 | 指定放大的比例。取值范围大于1。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let image: Component = await driver.findComponent(ON.type('Image'));
await image.pinchOut(1.5);
}
```
### pinchIn9+
pinchIn(scale: number): Promise\
将控件按指定的比例进行捏合缩小,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ------------------------------- |
| scale | number | 是 | 指定缩小的比例。取值范围为0~1。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let image: Component = await driver.findComponent(ON.type('Image'));
await image.pinchIn(0.5);
}
```
### getDescription11+
getDescription(): Promise\
获取控件对象的描述信息,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ---------------- | --------------------------------- |
| Promise\ | Promise对象,返回控件的描述信息。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('Button'));
let description = await button.getDescription();
}
```
### getHint18+
getHint(): Promise\
获取控件对象的提示文本,使用Promise异步回调。
**原子化服务API:** 从API version 18开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ---------------- |----------------------|
| Promise\ | Promise对象,返回控件的提示文本。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('TextInput'));
let hints = await button.getHint();
}
```
### getDisplayId20+
getDisplayId(): Promise\
获取控件对象所属的屏幕ID,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ---------------- |----------------------|
| Promise\ | Promise对象,返回控件所属的屏幕ID。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('TextInput'));
let displayId = await button.getDisplayId();
}
```
### getOriginalText20+
getOriginalText(): Promise\
获取控件对象的文本信息,使用Promise异步回调。
> **说明**
>
> 如果控件的无障碍属性[accessibilityLevel](../apis-arkui/arkui-ts/ts-universal-attributes-accessibility.md#accessibilitylevel)设置为'no'或'no-hide-descendants',可以使用本接口获取控件的文本信息,无法使用[Component.getText()](#gettext9)获取控件的文本信息。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ---------------- | --------------------------------- |
| Promise\ | Promise对象,返回控件的文本信息。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.type('Button'));
let text = await button.getOriginalText();
}
```
## Driver9+
Driver类为uitest测试框架的总入口,提供控件匹配/查找,按键注入,坐标点击/滑动,截图等能力。
该类提供的方法除Driver.create()以外的所有方法都使用Promise方式作为异步方法,需使用await方式调用。
### create9+
static create(): Driver
静态方法,构造一个Driver对象,并返回该对象。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| -------- | ---------------------- |
| Driver | 返回构造的Driver对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------- |
| 17000001 | Initialization failed. |
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
}
```
### delayMs9+
delayMs(duration: number): Promise\
在给定的时间内延时,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | ------ | ---- | ------------------------------- |
| duration | number | 是 | 给定的时间,单位:ms,取值范围:大于等于0的整数。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.delayMs(1000);
}
```
### findComponent9+
findComponent(on: On): Promise\
根据给出的目标控件属性要求查找目标控件,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ---------- | ---- | -------------------- |
| on | [On](#on9) | 是 | 目标控件的属性要求。 |
**返回值:**
| 类型 | 说明 |
| ---------------------------------- | --------------------------------- |
| Promise\<[Component](#component9)> | Promise对象,返回控件对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.findComponent(ON.text('next page'));
}
```
### findComponents9+
findComponents(on: On): Promise\>
根据给出的目标控件属性要求查找出所有匹配控件,以列表保存,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ---------- | ---- | -------------------- |
| on | [On](#on9) | 是 | 目标控件的属性要求。 |
**返回值:**
| 类型 | 说明 |
| ------------------------------------------ | --------------------------------------- |
| Promise\> | Promise对象,返回控件对象的列表。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let buttonList: Array = await driver.findComponents(ON.text('next page'));
}
```
### findWindow9+
findWindow(filter: WindowFilter): Promise\
通过指定窗口的属性来查找目标窗口,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------------------------------ | ---- | ---------------- |
| filter | [WindowFilter](#windowfilter9) | 是 | 目标窗口的属性。 |
**返回值:**
| 类型 | 说明 |
| -------------------------------- | ------------------------------------- |
| Promise\<[UiWindow](#uiwindow9)> | Promise对象,返回目标窗口对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver, UiWindow } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let window: UiWindow = await driver.findWindow({actived: true});
}
```
### waitForComponent9+
waitForComponent(on: On, time: number): Promise\
在用户给定的时间内,持续查找满足控件属性要求的目标控件,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ---------- | ---- | ----------------------------------------- |
| on | [On](#on9) | 是 | 目标控件的属性要求。 |
| time | number | 是 | 查找目标控件的持续时间。单位ms,取值范围:大于等于0的整数。 |
**返回值:**
| 类型 | 说明 |
| --------------------------------- | --------------------------------- |
| Promise\<[Component](#component9)> | Promise对象,返回控件对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let button: Component = await driver.waitForComponent(ON.text('next page'),500);
}
```
### assertComponentExist9+
assertComponentExist(on: On): Promise\
断言API,用于断言当前界面是否存在满足给出的目标属性的控件,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ---------- | ---- | -------------------- |
| on | [On](#on9) | 是 | 目标控件的属性要求。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000003 | Assertion failed. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.assertComponentExist(ON.text('next page'));
}
```
### pressBack9+
pressBack(): Promise\
进行点击BACK键的操作,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.pressBack();
}
```
### pressBack20+
pressBack(displayId: number): Promise\
对指定屏幕进行点击BACK键的操作,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------- | ------ | ---- | ------------- |
| displayId | number | 是 | 指定的屏幕ID,取值范围:大于等于0的整数。
**说明:** 传入displayId不存在时,将抛出17000007异常。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000007 | Parameter verification failed. |
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.pressBack(0);
}
```
### triggerKey9+
triggerKey(keyCode: number): Promise\
传入key值实现模拟点击对应按键的效果,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------- | ------ | ---- | ------------- |
| keyCode | number | 是 | 指定的key值,取值范围:大于等于0的整数。取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode)。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
import { KeyCode } from '@kit.InputKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.triggerKey(KeyCode.KEYCODE_BACK); // 返回键
}
```
### triggerKey20+
triggerKey(keyCode: number, displayId: number): Promise\
在指定屏幕,传入key值实现模拟点击对应按键的效果,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------- | ------ | ---- | ------------- |
| keyCode | number | 是 | 指定的key值,取值范围:大于等于0的整数。取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode)。 |
| displayId | number | 是 | 指定的屏幕ID,取值范围:大于等于0的整数。
**说明:** 传入displayId不存在时,将抛出17000007异常。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
import { KeyCode } from '@kit.InputKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.triggerKey(KeyCode.KEYCODE_BACK, 0); // 返回键
}
```
### triggerCombineKeys9+
triggerCombineKeys(key0: number, key1: number, key2?: number): Promise\
通过给定的key值,找到对应组合键并点击,使用Promise异步回调。例如,Key值为(2072, 2019)时,找到key值对应的组合键并点击,如Ctrl+c。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ------------------------------ |
| key0 | number | 是 | 指定的第一个key值,取值大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode)。 |
| key1 | number | 是 | 指定的第二个key值,取值大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode)。 |
| key2 | number | 否 | 指定的第三个key值,取值范围:大于等于0的整数。取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode),默认值为0。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.triggerCombineKeys(2072, 2047, 2035);
}
```
### triggerCombineKeys20+
triggerCombineKeys(key0: number, key1: number, key2?: number, displayId?: number): Promise\
通过给定的key值,找到对应组合键,并在指定屏幕下进行点击,使用Promise异步回调。例如,Key值为(2072, 2019)时,找到key值对应的组合键并点击,如Ctrl+c。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ------------------------------ |
| key0 | number | 是 | 指定的第一个key值,取值大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode)。 |
| key1 | number | 是 | 指定的第二个key值,取值大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode)。 |
| key2 | number | 否 | 指定的第三个key值,取值范围:大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode),默认值为0。 |
| displayId | number | 否 | 指定的屏幕ID,取值范围:大于等于0的整数,默认值为设备默认屏幕ID。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.triggerCombineKeys(2072, 2047, 2035, 0);
}
```
### click9+
click(x: number, y: number): Promise\
在目标坐标点单击,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ----------------------------------------------- |
| x | number | 是 | 以number的形式传入目标点的横坐标信息,取值范围:大于等于0的整数。 |
| y | number | 是 | 以number的形式传入目标点的纵坐标信息,取值范围:大于等于0的整数。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.click(100,100);
}
```
### clickAt20+
clickAt(point: Point): Promise\
在目标坐标点进行单击,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ----------------------------------------------- |
| point | [Point](#point9) | 是 | 以Point对象的形式传入目标点信息。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000007 | Parameter verification failed. |
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.clickAt({ x: 100, y: 100, displayId: 0 });
}
```
### doubleClick9+
doubleClick(x: number, y: number): Promise\
在目标坐标点双击,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ----------------------------------------------- |
| x | number | 是 | 以number的形式传入目标点的横坐标信息,取值范围:大于等于0的整数。 |
| y | number | 是 | 以number的形式传入目标点的纵坐标信息,取值范围:大于等于0的整数。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.doubleClick(100,100);
}
```
### doubleClickAt20+
doubleClickAt(point: Point): Promise\
对目标坐标进行双击,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ----------------------------------------------- |
| point | [Point](#point9) | 是 | 以Point对象的形式传入目标点信息。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000007 | Parameter verification failed. |
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.doubleClickAt({ x: 100, y: 100, displayId: 0 });
}
```
### longClick9+
longClick(x: number, y: number): Promise\
在目标坐标点长按,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ----------------------------------------------- |
| x | number | 是 | 以number的形式传入目标点的横坐标信息,取值范围:大于等于0的整数。 |
| y | number | 是 | 以number的形式传入目标点的纵坐标信息,取值范围:大于等于0的整数。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.longClick(100,100);
}
```
### longClickAt20+
longClickAt(point: Point, duration?: number): Promise\
长按目标坐标点,支持指定长按时长,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ----------------------------------------------- |
| point | [Point](#point9) | 是 | 以Point对象的形式传入目标点信息。 |
| duration | number | 否 | 长按持续的时间,取值范围为大于等于1500的整数,默认值为1500,单位:ms。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000007 | Parameter verification failed. |
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.longClickAt({ x: 100, y: 100, displayId: 0 }, 1500);
}
```
### swipe9+
swipe(startx: number, starty: number, endx: number, endy: number, speed?: number): Promise\
从起始坐标点滑向目的坐标点,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- |------------------------------------------------------|
| startx | number | 是 | 以number的形式传入起始点的横坐标信息,取值范围:大于等于0的整数。 |
| starty | number | 是 | 以number的形式传入起始点的纵坐标信息,取值范围:大于等于0的整数。 |
| endx | number | 是 | 以number的形式传入目的点的横坐标信息,取值范围:大于等于0的整数。 |
| endy | number | 是 | 以number的形式传入目的点的纵坐标信息,取值范围:大于等于0的整数。 |
| speed | number | 否 | 滑动速率,取值范围为200-40000的整数,默认值为600,不在范围内设为默认值为600,单位:px/s。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.swipe(100,100,200,200,600);
}
```
### swipeBetween20+
swipeBetween(from: Point, to: Point, speed?: number): Promise\
从起始坐标点滑向目标坐标点,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- |------------------------------------------------------|
| from | [Point](#point9) | 是 | 以Point对象的形式传入起始点的坐标信息和所属屏幕ID。 |
| to | [Point](#point9) | 是 | 以Point对象的形式传入终止点的坐标信息和所属屏幕ID。
**说明:** 应与起始点属于同一个屏幕,否则将抛出17000007异常。 |
| speed | number | 否 | 滑动速率,取值范围为200-40000的整数,默认值为600,不在范围内设为默认值为600,单位:px/s。|
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000007 | Parameter verification failed. |
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.swipeBetween({x: 100, y: 100, displayId: 0}, {x: 1000, y: 1000, displayId: 0}, 800);
}
```
### drag9+
drag(startx: number, starty: number, endx: number, endy: number, speed?: number): Promise\
从起始坐标点拖拽至目的坐标点,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**设备行为差异**:该接口在Phone、Tablet、PC/2in1、TV设备上生效,在其他设备中调用无效果。
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ------------------------------------------------------------ |
| startx | number | 是 | 以number的形式传入起始点的横坐标信息,取值范围:大于等于0的整数。 |
| starty | number | 是 | 以number的形式传入起始点的纵坐标信息,取值范围:大于等于0的整数。 |
| endx | number | 是 | 以number的形式传入目的点的横坐标信息,取值范围:大于等于0的整数。 |
| endy | number | 是 | 以number的形式传入目的点的纵坐标信息,取值范围:大于等于0的整数。 |
| speed | number | 否 | 滑动速率,取值范围为200-40000的整数,默认值为600,不在范围内设为默认值为600,单位:px/s。|
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.drag(100, 100, 200, 200, 600);
}
```
### dragBetween20+
dragBetween(from: Point, to: Point, speed?: number, duration?: number): Promise\
从起始坐标点拖拽至目标坐标点,支持指定拖拽速度和拖拽前长按时间,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**设备行为差异**:该接口在Phone、Tablet、PC/2in1、TV设备上生效,在其他设备中调用无效果。
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- |--------------------------------------------------------|
| from | [Point](#point9) | 是 | 以Point对象的形式传入起始点的坐标信息和所属屏幕ID。 |
| to | [Point](#point9) | 是 | 以Point对象的形式传入终止点的坐标信息和所属屏幕ID。
**说明:** 应与起始点属于同一个屏幕,否则将抛出17000007异常。 |
| speed | number | 否 | 滑动速率,取值范围为200-40000的整数,默认值为600,不在范围内设为默认值为600,单位:px/s。|
| duration | number | 否 | 拖拽前长按持续的时间,取值范围为大于等于1500的整数,默认值为1500,单位:ms。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000007 | Parameter verification failed. |
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.dragBetween( {x: 100, y: 100, displayId: 0}, {x: 1000, y: 1000, displayId: 0}, 800, 1500);
}
```
### screenCap9+
screenCap(savePath: string): Promise\
捕获当前屏幕,并保存为PNG格式的图片至给出的保存路径中,使用Promise异步回调。适用于支持截屏的场景。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | ------ | ---- | ------------------------------------------ |
| savePath | string | 是 | 文件保存路径。路径需为当前应用的[沙箱路径](../../file-management/app-sandbox-directory.md)。 |
**返回值:**
| 类型 | 说明 |
| ----------------- |-------------------------------------------|
| Promise\ | Promise对象,返回截图操作是否成功完成。true:完成,false:未完成。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.screenCap('/data/storage/el2/base/cache/1.png');
}
```
### screenCap20+
screenCap(savePath: string, displayId: number): Promise\
捕获指定屏幕,并保存为PNG格式的图片至给出的保存路径中,使用Promise异步回调。适用于支持截屏的场景。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | ------ | ---- | ------------------------------------------ |
| savePath | string | 是 | 文件保存路径。路径需为当前应用的[沙箱路径](../../file-management/app-sandbox-directory.md)。 |
| displayId | number | 是 | 指定设备屏幕ID。取值范围:大于等于0的整数。
**说明:** 传入displayId不存在时,将抛出17000007异常。 |
**返回值:**
| 类型 | 说明 |
| ----------------- |-------------------------------------------|
| Promise\ | Promise对象,返回截图操作是否成功完成。true:完成。false:未完成。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.screenCap('/data/storage/el2/base/cache/1.png', 0);
}
```
### setDisplayRotation9+
setDisplayRotation(rotation: DisplayRotation): Promise\
将当前场景的显示方向设置为指定的显示方向,使用Promise异步回调。适用于可旋转的应用场景。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**设备行为差异**:该接口在Phone、Tablet、PC/2in1、TV设备上生效,在其他设备中调用无效果。
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | ------------------------------------ | ---- | ---------------- |
| rotation | [DisplayRotation](#displayrotation9) | 是 | 设备的显示方向。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver, DisplayRotation } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.setDisplayRotation(DisplayRotation.ROTATION_180);
}
```
### getDisplayRotation9+
getDisplayRotation(): Promise\
获取当前设备的屏幕显示方向,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ---------------------------------------------- | --------------------------------------- |
| Promise\<[DisplayRotation](#displayrotation9)> | Promise对象,返回当前设备的显示方向。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
**示例:**
```ts
import { DisplayRotation, Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let rotation: DisplayRotation = await driver.getDisplayRotation();
}
```
### getDisplayRotation20+
getDisplayRotation(displayId: number): Promise\
获取当前设备指定屏幕的显示方向,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | ------ | ---- | ------------------------------------------ |
| displayId | number | 是 | 指定设备屏幕ID。取值范围:大于等于0的整数。
**说明:** 传入displayId不存在时,将抛出17000007异常。 |
**返回值:**
| 类型 | 说明 |
| ---------------------------------------------- | --------------------------------------- |
| Promise\<[DisplayRotation](#displayrotation9)> | Promise对象,返回指定屏幕的显示方向。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000007 | Parameter verification failed. |
**示例:**
```ts
import { DisplayRotation, Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let rotation: DisplayRotation = await driver.getDisplayRotation(0);
}
```
### setDisplayRotationEnabled9+
setDisplayRotationEnabled(enabled: boolean): Promise\
启用/禁用设备旋转屏幕的功能,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**设备行为差异**:该接口在Phone、Tablet、PC/2in1、TV设备上生效,在其他设备中调用无效果。
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------- | ------- | ---- | ------------------------------------------------------- |
| enabled | boolean | 是 | 能否旋转屏幕的标识。true:可以旋转。false:不可以旋转。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.setDisplayRotationEnabled(false);
}
```
### getDisplaySize9+
getDisplaySize(): Promise\
获取当前设备的屏幕大小,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| -------------------------- | --------------------------------------- |
| Promise\<[Point](#point9)> | Promise对象,返回Point对象,当前设备屏幕的大小为Point.x * Point.y。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let size = await driver.getDisplaySize();
}
```
### getDisplaySize20+
getDisplaySize(displayId: number): Promise\
获取当前设备指定屏幕的大小,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | ------ | ---- | ------------------------------------------ |
| displayId | number | 是 | 指定设备屏幕ID。取值范围:大于等于0的整数。
**说明:** 传入displayId不存在时,将抛出17000007异常。 |
**返回值:**
| 类型 | 说明 |
| -------------------------- | --------------------------------------- |
| Promise\<[Point](#point9)> | Promise对象,返回Point对象,当前设备指定屏幕的大小为Point.x * Point.y。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000007 | Parameter verification failed. |
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let size = await driver.getDisplaySize(0);
}
```
### getDisplayDensity9+
getDisplayDensity(): Promise\
获取当前设备屏幕的分辨率,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| -------------------------- | ----------------------------------------- |
| Promise\<[Point](#point9)> | Promise对象,返回Point对象,当前设备屏幕的分辨率为Point.x*Point.y。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let density = await driver.getDisplayDensity();
}
```
### getDisplayDensity20+
getDisplayDensity(displayId: number): Promise\
获取当前设备指定屏幕的分辨率,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | ------ | ---- | ------------------------------------------ |
| displayId | number | 是 | 指定设备屏幕ID。取值范围:大于等于0的整数。
**说明:** 传入displayId不存在时,将抛出17000007异常。 |
**返回值:**
| 类型 | 说明 |
| -------------------------- | ----------------------------------------- |
| Promise\<[Point](#point9)> | Promise对象,返回Point对象,当前设备指定屏幕的分辨率为Point.x*Point.y。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000007 | Parameter verification failed. |
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let density = await driver.getDisplayDensity(0);
}
```
### wakeUpDisplay9+
wakeUpDisplay(): Promise\
唤醒当前设备即设备亮屏,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.wakeUpDisplay();
}
```
### pressHome9+
pressHome(): Promise\
设备注入返回桌面操作,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**设备行为差异**:该接口在Phone、Tablet、PC/2in1、TV设备上生效,在其他设备中调用无效果。
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.pressHome();
}
```
### pressHome20+
pressHome(displayId: number): Promise\
设备指定屏幕上注入返回桌面操作,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**设备行为差异**:该接口在Phone、Tablet、PC/2in1、TV设备上生效,在其他设备中调用无效果。
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | ------ | ---- | ------------------------------------------ |
| displayId | number | 是 | 指定设备屏幕ID。取值范围:大于等于0的整数。
**说明:** 传入displayId不存在时,将抛出17000007异常。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000007 | Parameter verification failed. |
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.pressHome(0);
}
```
### waitForIdle9+
waitForIdle(idleTime: number, timeout: number): Promise\
判断当前界面的所有控件是否已经空闲,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | ------ | ---- | ------------------------------------------------------------ |
| idleTime | number | 是 | 空闲时间的阈值。在这个时间段控件不发生变化,视为该控件空闲,单位:毫秒,取值范围:大于等于0的整数。 |
| timeout | number | 是 | 等待空闲的最大时间,单位:毫秒,取值范围:大于等于0的整数。 |
**返回值:**
| 类型 | 说明 |
| ----------------- |---------------------------------------------------|
| Promise\ | Promise对象,返回当前界面的所有控件是否已经空闲。true:已经空闲,false:不空闲。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let idled:boolean = await driver.waitForIdle(4000,5000);
}
```
### fling9+
fling(from: Point, to: Point, stepLen: number, speed: number): Promise\
模拟手指滑动后脱离屏幕的快速滑动操作,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------- | ---------------- | ---- |------------------------------------------------------|
| from | [Point](#point9) | 是 | 手指接触屏幕的起始点坐标。 |
| to | [Point](#point9) | 是 | 手指离开屏幕时的坐标点。 |
| stepLen | number | 是 | 间隔距离,取值大于等于0的整数,单位:px。 |
| speed | number | 是 | 滑动速率,取值范围为200-40000的整数,默认值为600,不在范围内设为默认值为600,单位:px/s。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.fling({x: 500, y: 480},{x: 450, y: 480}, 5, 600);
}
```
### injectMultiPointerAction9+
injectMultiPointerAction(pointers: PointerMatrix, speed?: number): Promise\
向设备注入多指操作,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------------------------------- | ---- |--------------------------------------------------------|
| pointers | [PointerMatrix](#pointermatrix9) | 是 | 滑动轨迹,包括操作手指个数和滑动坐标序列。 |
| speed | number | 否 | 滑动速率,取值范围为200-40000的整数,默认值为600,不在范围内设为默认值为600,单位:px/s。 |
**返回值:**
| 类型 | 说明 |
| ----------------- | ------------------------------------- |
| Promise\ | Promise对象,返回操作是否成功完成。true:完成,false:未完成。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver, PointerMatrix } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let pointers: PointerMatrix = PointerMatrix.create(2, 5);
pointers.setPoint(0, 0, {x:250, y:480});
pointers.setPoint(0, 1, {x:250, y:440});
pointers.setPoint(0, 2, {x:250, y:400});
pointers.setPoint(0, 3, {x:250, y:360});
pointers.setPoint(0, 4, {x:250, y:320});
pointers.setPoint(1, 0, {x:250, y:480});
pointers.setPoint(1, 1, {x:250, y:440});
pointers.setPoint(1, 2, {x:250, y:400});
pointers.setPoint(1, 3, {x:250, y:360});
pointers.setPoint(1, 4, {x:250, y:320});
await driver.injectMultiPointerAction(pointers);
}
```
### fling10+
fling(direction: UiDirection, speed: number): Promise\;
指定方向和速度,模拟手指滑动后脱离屏幕的快速滑动操作,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| --------- | ----------------------------- | ---- |--------------------------------------------------------|
| direction | [UiDirection](#uidirection10) | 是 | 进行抛滑的方向。 |
| speed | number | 是 | 滑动速率,取值范围为200-40000的整数,默认值为600,不在范围内设为默认值为600,单位:px/s。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver, UiDirection } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.fling(UiDirection.DOWN, 10000);
}
```
### fling20+
fling(direction: UiDirection, speed: number, displayId: number): Promise\
指定方向和速度,模拟手指滑动后脱离屏幕的快速滑动操作,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| --------- | ----------------------------- | ---- |--------------------------------------------------------|
| direction | [UiDirection](#uidirection10) | 是 | 进行抛滑的方向。 |
| speed | number | 是 | 滑动速率,取值范围为200-40000,默认值为600,不在范围内设为默认值为600,单位:px/s。 |
| displayId | number | 是 | 指定设备屏幕ID。取值范围:大于等于0的整数。
**说明:** 传入displayId不存在时,将抛出17000007异常。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver, UiDirection } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.fling(UiDirection.DOWN, 10000, 0);
}
```
### screenCapture10+
screenCapture(savePath: string, rect?: Rect): Promise\;
捕获当前屏幕的指定区域,并保存为PNG格式的图片至给出的保存路径中,使用Promise异步回调。适用于支持截屏的场景。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------------- | ---- | ------------------------------------------ |
| savePath | string | 是 | 文件保存路径。路径需为当前应用的[沙箱路径](../../file-management/app-sandbox-directory.md)。 |
| rect | [Rect](#rect9) | 否 | 截图区域,默认为全屏。 |
**返回值:**
| 类型 | 说明 |
| ----------------- |---------------------------------------------|
| Promise\ | Promise对象,返回截图操作是否成功完成。true:成功完成,false:未成功完成。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.screenCapture('/data/storage/el2/base/cache/1.png', {left: 0, top: 0, right: 100, bottom: 100});
}
```
### mouseClick10+
mouseClick(p: Point, btnId: MouseButton, key1?: number, key2?: number): Promise\;
在指定坐标点注入鼠标点击动作,支持同时按下对应键盘组合键,使用Promise异步回调。例如,Key值为2072时,按下Ctrl并进行鼠标点击动作。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ----------------------------- | ---- | ------------------------------ |
| p | [Point](#point9) | 是 | 鼠标点击的坐标。 |
| btnId | [MouseButton](#mousebutton10) | 是 | 按下的鼠标按钮。 |
| key1 | number | 否 | 指定的第一个key值,取值大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode),默认值为0。 |
| key2 | number | 否 | 指定的第二个key值,取值大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode),默认值为0。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver,MouseButton } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.mouseClick({x:248, y:194}, MouseButton.MOUSE_BUTTON_LEFT, 2072);
}
```
### mouseScroll10+
mouseScroll(p: Point, down: boolean, d: number, key1?: number, key2?: number): Promise\;
在指定坐标点注入鼠标滚轮滑动动作,支持同时按下对应键盘组合键,使用Promise异步回调。例如,Key值为2072时,按下Ctrl并进行鼠标滚轮滑动动作。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ---------------- | ---- | ----------------------------------------------------------- |
| p | [Point](#point9) | 是 | 鼠标点击的坐标。 |
| down | boolean | 是 | 滚轮滑动方向是否向下。true表示向下滑动。false表示向上滚动。 |
| d | number | 是 | 鼠标滚轮滚动的格数,取值大于等于0的整数,每格对应目标点位移120px。 |
| key1 | number | 否 | 指定的第一个key值,取值大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode),默认值为0。 |
| key2 | number | 否 | 指定的第二个key值,取值大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode),默认值为0。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.mouseScroll({x:360, y:640}, true, 30, 2072);
}
```
### mouseMoveTo10+
mouseMoveTo(p: Point): Promise\;
将鼠标光标移到目标点,使用Promise异步回调。
**系统能力**:SystemCapability.Test.UiTest
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ---------------- | ---- | -------------- |
| p | [Point](#point9) | 是 | 目标点的坐标。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.mouseMoveTo({x:100, y:100});
}
```
### createUIEventObserver10+
createUIEventObserver(): UIEventObserver;
创建一个UI事件监听器。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ------------------------------------ | ------------------------------------- |
|[UIEventObserver](#uieventobserver10) | 返回找到的目标窗口对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
**示例:**
```ts
import { Driver, UIEventObserver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let observer: UIEventObserver = await driver.createUIEventObserver();
}
```
### mouseScroll11+
mouseScroll(p: Point, down: boolean, d: number, key1?: number, key2?: number, speed?: number): Promise\
在指定坐标点注入鼠标滚轮滑动动作,支持同时按下对应键盘组合键并且指定滑动速度,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ---------------- | ---- | ------------------------------------------------------------ |
| p | [Point](#point9) | 是 | 鼠标点击的坐标。 |
| down | boolean | 是 | 滚轮滑动方向是否向下。true表示向下滑动。false表示向上滚动。 |
| d | number | 是 | 鼠标滚轮滚动的格数,取值大于等于0的整数,每格对应目标点位移120px。 |
| key1 | number | 否 | 指定的第一个key值,取值大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode),默认值为0。 |
| key2 | number | 否 | 指定的第二个key值,取值大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode),默认值为0。 |
| speed | number | 否 | 鼠标滚轮滚动的速度,范围:1-500的整数,不在范围内设为默认值为20,单位:格/秒。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.mouseScroll({x:360, y:640}, true, 30, 2072,20);
}
```
### mouseDoubleClick11+
mouseDoubleClick(p: Point, btnId: MouseButton, key1?: number, key2?: number): Promise\
在指定坐标点注入鼠标双击动作,支持同时按下对应键盘组合键,使用Promise异步回调。例如,Key值为2072时,按下Ctrl并进行鼠标双击动作。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ----------------------------- | ---- | ------------------------------ |
| p | [Point](#point9) | 是 | 鼠标双击的坐标。 |
| btnId | [MouseButton](#mousebutton10) | 是 | 按下的鼠标按钮。 |
| key1 | number | 否 | 指定的第一个key值,取值大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode),默认值0。 |
| key2 | number | 否 | 指定的第二个key值,取值大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode),默认值0。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver,MouseButton } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.mouseDoubleClick({x:248, y:194}, MouseButton.MOUSE_BUTTON_LEFT, 2072);
}
```
### mouseLongClick11+
mouseLongClick(p: Point, btnId: MouseButton, key1?: number, key2?: number): Promise\
在指定坐标点注入鼠标长按动作,支持同时按下对应键盘组合键,使用Promise异步回调。例如,Key值为2072时,按下Ctrl并进行鼠标长按动作。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ----------------------------- | ---- | ------------------------------ |
| p | [Point](#point9) | 是 | 鼠标长按的坐标。 |
| btnId | [MouseButton](#mousebutton10) | 是 | 按下的鼠标按钮。 |
| key1 | number | 否 | 指定的第一个key值,取值大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode),默认值为0。 |
| key2 | number | 否 | 指定的第二个key值,取值大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode),默认值为0。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver,MouseButton } from '@kit.TestKit';
async function demo() {
let driver:Driver = Driver.create();
await driver.mouseLongClick({x:248, y:194}, MouseButton.MOUSE_BUTTON_LEFT, 2072);
}
```
### mouseLongClick20+
mouseLongClick(p: Point, btnId: MouseButton, key1?: number, key2?: number, duration?: number): Promise\
在指定坐标点注入鼠标长按动作,支持同时按下对应键盘组合键,支持指定长按时长,使用Promise异步回调。例如,Key值为2072时,按下Ctrl并进行鼠标长按动作。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | ----------------------------- | ---- | ------------------------------ |
| p | [Point](#point9) | 是 | 鼠标长按的坐标。 |
| btnId | [MouseButton](#mousebutton10) | 是 | 按下的鼠标按钮。 |
| key1 | number | 否 | 指定的第一个key值,取值大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode),默认值为0。 |
| key2 | number | 否 | 指定的第二个key值,取值大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode),默认值为0。 |
| duration | number | 否 | 长按持续的时间,取值范围为大于等于1500的整数,默认值为1500,单位:ms。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver,MouseButton } from '@kit.TestKit';
async function demo() {
let driver:Driver = Driver.create();
await driver.mouseLongClick({x:248, y:194}, MouseButton.MOUSE_BUTTON_LEFT, 2072, 0, 2000);
}
```
### mouseMoveWithTrack11+
mouseMoveWithTrack(from: Point, to: Point, speed?: number): Promise\
鼠标从起始坐标点滑向终点坐标点,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ---------------- | ---- |--------------------------------------------------------|
| from | [Point](#point9) | 是 | 起始点坐标。 |
| to | [Point](#point9) | 是 | 终点坐标。 |
| speed | number | 否 | 滑动速率,取值范围为200-40000的整数,默认值为600,不在范围内设为默认值为600,单位:px/s。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.mouseMoveWithTrack({x:100, y:100}, {x:200, y:200}, 600);
}
```
### mouseDrag11+
mouseDrag(from: Point, to: Point, speed?: number): Promise\
鼠标按住鼠标左键从起始坐标点拖拽至终点坐标点,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**设备行为差异**:该接口在Phone、Tablet、PC/2in1、TV设备上生效,在其他设备中调用无效果。
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ---------------- | ---- |--------------------------------------------------------|
| from | [Point](#point9) | 是 | 起始点坐标。 |
| to | [Point](#point9) | 是 | 终点坐标。 |
| speed | number | 否 | 滑动速率,取值范围为200-40000的整数,默认值为600,不在范围内设为默认值为600,单位:px/s。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.mouseDrag({x:100, y:100},{x:200, y:200}, 600);
}
```
### mouseDrag20+
mouseDrag(from: Point, to: Point, speed?: number, duration?: number): Promise\
鼠标按住鼠标左键从起始坐标点拖拽至终点坐标点,支持指定拖拽速度和拖拽前长按时间,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**设备行为差异**:该接口在Phone、Tablet、PC/2in1、TV设备上生效,在其他设备中调用无效果。
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| --------- | ---------------- | ---- |--------------------------------------------------------|
| from | [Point](#point9) | 是 | 起始点坐标。 |
| to | [Point](#point9) | 是 | 终点坐标。 |
| speed | number | 否 | 滑动速率,取值范围为200-40000的整数,默认值为600,不在范围内设为默认值为600,单位:px/s。 |
| duration | number | 否 | 拖拽前长按持续的时间,取值范围为大于等于1500的整数,默认值为1500,单位:ms。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.mouseDrag({x:100, y:100},{x:200, y:200}, 600, 2000);
}
```
### inputText11+
inputText(p: Point, text: string): Promise\
在指定坐标点输入文本,不清空组件内原有文本,直接在坐标处追加输入,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ---------------- | ---- | ------------------ |
| p | [Point](#point9) | 是 | 输入文本的坐标点。 |
| text | string | 是 |输入的文本信息,当前支持英文、中文和特殊字符。|
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver:Driver = Driver.create();
let text: Component = await driver.findComponent(ON.type('TextInput'));
let point = await text.getBoundsCenter();
await driver.inputText(point, '123');
}
```
### inputText20+
inputText(p: Point, text: string, mode: InputTextMode): Promise\
在指定坐标点输入文本,支持指定文本输入方式,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ---------------- | ---- | ------------------ |
| p | [Point](#point9) | 是 | 输入文本的坐标点。 |
| text | string | 是 |输入的文本信息,当前支持英文、中文和特殊字符。 |
| mode | [InputTextMode](#inputtextmode20) | 是 | 输入文本的方式,取值请参考[InputTextMode](#inputtextmode20)。
**说明:**
InputTextMode.addition取值为ture时,将光标移动至文本末尾后输入指定文本。取值为false时,将在坐标点位置输入指定文本。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
| 801 | Capability not support, function can not work correctly due to limited device capabilities.|
**示例:**
```ts
import { Component, Driver, ON } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let text: Component = await driver.findComponent(ON.type('TextInput'));
let point = await text.getBoundsCenter();
await driver.inputText(point, '123', {paste: true, addition: false});
}
async function demo_Chinese() {
let driver: Driver = Driver.create();
let text: Component = await driver.findComponent(ON.type('TextInput'));
let point = await text.getBoundsCenter();
await driver.inputText(point, '中文&', { paste: false, addition: true });
// 以复制粘贴方式输入中文、特殊符号, 指定文本追加到指定坐标所在文本段的末尾。
}
```
### touchPadMultiFingerSwipe18+
touchPadMultiFingerSwipe(fingers: number, direction: UiDirection, options?: TouchPadSwipeOptions): Promise\
模拟触摸板多指滑动手势,使用Promise异步回调。
**原子化服务API:** 从API version 18开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**设备行为差异**:该接口在PC/2in1设备中可正常调用,在其他设备中返回17000005错误码。
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ |-----------------------------------------------|----|-----------------------|
| fingers | number | 是 | 触摸板多指滑动的手指数。取值为3或者4。 |
| direction | [UiDirection](#uidirection10) | 是 | 触摸板多指滑动的方向。 |
| options | [TouchPadSwipeOptions](#touchpadswipeoptions18) | 否 | 触摸板多指滑动手势附加选项。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象,返回无结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 17000005 | This operation is not supported. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver, UiDirection } from '@kit.TestKit';
async function demo() {
let driver:Driver = Driver.create();
await driver.touchPadMultiFingerSwipe(3, UiDirection.UP);
}
```
### penClick18+
penClick(point: Point): Promise\
模拟手写笔点击操作,使用Promise异步回调。
**原子化服务API:** 从API version 18开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ |-----------------------------------------------|----|---------|
| point | [Point](#point9) | 是 | 点击的坐标点。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象,返回无结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.penClick({x: 100, y: 100});
}
```
### penLongClick18+
penLongClick(point: Point, pressure?: number): Promise\
模拟手写笔长按操作,使用Promise异步回调。
**原子化服务API:** 从API version 18开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ |-----------------------------------------------|----|-------------------------------|
| point | [Point](#point9) | 是 | 长按的坐标点。 |
| pressure | number | 否 | 手写笔滑动操作的压力,默认为1.0,取值范围为0.0到1.0。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象,返回无结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.penLongClick({x: 100, y: 100}, 0.5);
}
```
### penDoubleClick18+
penDoubleClick(point: Point): Promise\
模拟手写笔双击操作,使用Promise异步回调。
**原子化服务API:** 从API version 18开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ |-----------------------------------------------|----|---------|
| point | [Point](#point9) | 是 | 双击的坐标点。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象,返回无结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.penDoubleClick({x: 100, y: 100});
}
```
### penSwipe18+
penSwipe(startPoint: Point, endPoint: Point, speed?: number, pressure?: number): Promise\
模拟手写笔的滑动操作,使用Promise异步回调。
**原子化服务API:** 从API version 18开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ |-----------------------------------------------|----|--------------------------------------------------------|
| startPoint | [Point](#point9) | 是 | 起始位置的坐标点。 |
| endPoint | [Point](#point9) | 是 | 结束位置的坐标点。 |
| speed | number | 否 | 滑动速率,取值范围为200-40000的整数,默认值为600,不在范围内设为默认值为600,单位:px/s。 |
| pressure | number | 否 | 手写笔滑动操作的压力,默认为1.0,取值范围为0.0到1.0。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象,返回无结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
await driver.penSwipe({x: 100, y: 100}, {x: 100, y: 500}, 600, 0.5);
}
```
### injectPenPointerAction18+
injectPenPointerAction(pointers: PointerMatrix, speed?: number, pressure?: number): Promise\
模拟手写笔多点连续注入操作,使用Promise异步回调。
**原子化服务API:** 从API version 18开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ |-----------------------------------------------|----|-------------------------------------------------------------------|
| pointers | [PointerMatrix](#pointermatrix9) | 是 |滑动轨迹,包括操作手指个数和滑动坐标序列。当前仅支持单指操作,PointerMatrix中的操作手指个数fingers必须设置为1。 |
| speed | number| 否 | 滑动速率,取值范围为200-40000的整数,默认值为600,不在范围内设为默认值为600,单位:px/s。 |
| pressure | number | 否 | 手写笔多点连续注入的压力,默认为1.0,取值范围为0.0到1.0。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象,返回无结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver, PointerMatrix } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let pointer = PointerMatrix.create(1, 8);
for (let step = 0; step < 8; step++) {
pointer.setPoint(0, step, {x: 500, y: 1100 - 100 *step});
}
await driver.injectPenPointerAction(pointer, 600, 0.5);
}
```
### crownRotate20+
crownRotate(d: number, speed?: number): Promise\
注入手表表冠旋转事件,可指定旋转速度,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**设备行为差异**:该接口在Wearable设备中可正常调用,在其他设备中返回801错误码。
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ |-----------------------------------------------|----|-------------------------------------------------------------------|
| d | number | 是 | 手表表冠旋转的格数,正值表示顺时针旋转,负值表示逆时针旋转,取值需为整数。 |
| speed | number | 否 | 手表表冠旋转的速度,取值范围:1-500的整数,默认值为20,单位:格/秒。
**说明:** 参数取值超出合法范围时,设为默认值20。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 17000007 | Parameter verification failed. |
| 801 | Capability not support, function can not work correctly due to limited device capabilities. |
**示例:**
```ts
import { Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
// 顺时针旋转50格,旋转速度为30格/秒
await driver.crownRotate(50, 30);
// 逆时针旋转20格,旋转速度为30格/秒
await driver.crownRotate(-20, 30);
}
```
## PointerMatrix9+
存储多指操作中每根手指每一步动作的坐标点及其行为的二维数组。
### create9+
static create(fingers: number, steps: number): PointerMatrix
静态方法,构造一个PointerMatrix对象,并返回该对象。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------- | ------ | ---- | ------------------------------------------ |
| fingers | number | 是 | 多指操作中注入的手指数,取值范围:[1,10]的整数。 |
| steps | number | 是 | 每根手指操作的步骤数,取值范围:[1,1000]的整数。 |
**返回值:**
| 类型 | 说明 |
| -------------------------------- | ----------------------------- |
| [PointerMatrix](#pointermatrix9) | 返回构造的PointerMatrix对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { PointerMatrix } from '@kit.TestKit';
async function demo() {
let pointerMatrix: PointerMatrix = PointerMatrix.create(2, 3);
}
```
### setPoint9+
setPoint(finger: number, step: number, point: Point): void
设置PointerMatrix对象中指定手指和步骤对应动作的坐标点。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ---------------- | ---- | ---------------------------------------------------------- |
| finger | number | 是 | 手指的序号,取值大于等于0的整数,且不超过构造PointerMatrix对象时设置的手指数。 |
| step | number | 是 | 步骤的序号,取值大于等于0的整数,且不超过构造PointerMatrix对象时设置的操作的步骤数。 |
| point | [Point](#point9) | 是 | 该行为的坐标点。建议相邻的坐标点距离在10px至80px范围内。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { PointerMatrix } from '@kit.TestKit';
async function demo() {
let pointers: PointerMatrix = PointerMatrix.create(2, 5);
pointers.setPoint(0, 0, {x:250, y:480});
pointers.setPoint(0, 1, {x:250, y:440});
pointers.setPoint(0, 2, {x:250, y:400});
pointers.setPoint(0, 3, {x:250, y:360});
pointers.setPoint(0, 4, {x:250, y:320});
pointers.setPoint(1, 0, {x:250, y:480});
pointers.setPoint(1, 1, {x:250, y:440});
pointers.setPoint(1, 2, {x:250, y:400});
pointers.setPoint(1, 3, {x:250, y:360});
pointers.setPoint(1, 4, {x:250, y:320});
}
```
## UiWindow9+
UiWindow代表了UI界面上的一个窗口,提供窗口属性获取,窗口拖动、调整窗口大小等能力。
该类提供的所有方法都使用Promise方式作为异步方法,需使用await方式调用。
### getBundleName9+
getBundleName(): Promise\
获取窗口归属应用的包名信息,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ---------------- | ----------------------------------------- |
| Promise\ | Promise对象,返回窗口归属应用的包名信息。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Driver, UiWindow } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let window: UiWindow = await driver.findWindow({actived: true});
let name: string = await window.getBundleName();
}
```
### getBounds9+
getBounds(): Promise\
获取窗口的边框信息,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ------------------------ | --------------------------------- |
| Promise\<[Rect](#rect9)> | Promise对象,返回窗口的边框信息。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Driver, UiWindow } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let window: UiWindow = await driver.findWindow({actived: true});
let rect = await window.getBounds();
}
```
### getTitle9+
getTitle(): Promise\
获取窗口的标题信息,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ---------------- | --------------------------------- |
| Promise\ | Promise对象,返回窗口的标题信息。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Driver, UiWindow } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let window: UiWindow = await driver.findWindow({actived: true});
let title = await window.getTitle();
}
```
### getWindowMode9+
getWindowMode(): Promise\
获取窗口的窗口模式信息,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ------------------------------------ | ------------------------------------- |
| Promise\<[WindowMode](#windowmode9)> | Promise对象,返回窗口的窗口模式信息。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Driver, UiWindow } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let window: UiWindow = await driver.findWindow({actived: true});
let mode = await window.getWindowMode();
}
```
### isFocused9+
isFocused(): Promise\
判断窗口是否处于获焦状态,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ----------------- | ------------------------------------------------------------ |
| Promise\ | Promise对象,返回窗口对象是否获取获焦状态。true:获焦。false:未获焦。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Driver, UiWindow } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let window: UiWindow = await driver.findWindow({actived: true});
let focused = await window.isFocused();
}
```
### isActived(deprecated)
isActived(): Promise\
判断窗口是否为用户正在交互窗口,使用Promise异步回调。
从API version 9开始支持,从API version 11开始废弃,建议使用[isActive11+](#isactive11)替代。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ----------------- | ------------------------------------------------------------ |
| Promise\ | Promise对象,返回窗口对象是否为用户正在交互窗口。true表示是交互窗口。false表示非交互窗口。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Driver, UiWindow } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let window: UiWindow = await driver.findWindow({actived: true});
let focused = await window.isActived();
}
```
### focus9+
focus(): Promise\
让窗口获焦,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象,返回无结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Driver, UiWindow } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let window: UiWindow = await driver.findWindow({actived: true});
await window.focus();
}
```
### moveTo9+
moveTo(x: number, y: number): Promise\
将窗口移动到目标点,使用Promise异步回调。适用于支持移动的窗口。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**设备行为差异**:该接口在PC/2in1、Tablet设备中可正常调用,在其他设备中返回17000005错误码。
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ----------------------------------------------- |
| x | number | 是 | 以number的形式传入目标点的横坐标信息,取值范围:大于等于0的整数。 |
| y | number | 是 | 以number的形式传入目标点的纵坐标信息,取值范围:大于等于0的整数。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象,返回无结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
| 17000005 | This operation is not supported. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver, UiWindow } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let window: UiWindow = await driver.findWindow({actived: true});
await window.moveTo(100, 100);
}
```
### resize9+
resize(wide: number, height: number, direction: ResizeDirection): Promise\
根据传入的宽、高和调整方向来调整窗口的大小,使用Promise异步回调。适用于支持调整大小的窗口。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| --------- | ------------------------------------ | ---- | ------------------------------------------------------------ |
| wide | number | 是 | 以number的形式传入调整后窗口的宽度,取值范围:大于等于0的整数。 |
| height | number | 是 | 以number的形式传入调整后窗口的高度,取值范围:大于等于0的整数。 |
| direction | [ResizeDirection](#resizedirection9) | 是 | 以[ResizeDirection](#resizedirection9)的形式传入窗口调整的方向。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象,返回无结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)和[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
| 17000005 | This operation is not supported. |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver, ResizeDirection, UiWindow } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let window: UiWindow = await driver.findWindow({actived: true});
await window.resize(100, 100, ResizeDirection.LEFT);
}
```
### split9+
split(): Promise\
将窗口模式切换成分屏模式,使用Promise异步回调。适用于支持切换分屏模式的窗口。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**设备行为差异**:该接口在PC/2in1、Tablet设备中可正常调用,在其他设备中返回17000005错误码。
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象,返回无结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
| 17000005 | This operation is not supported. |
**示例:**
```ts
import { Driver, UiWindow } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let window: UiWindow = await driver.findWindow({actived: true});
await window.split();
}
```
### maximize9+
maximize(): Promise\
将窗口最大化,使用Promise异步回调。适用于支持窗口最大化操作的窗口。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**设备行为差异**:该接口在PC/2in1、Tablet设备中可正常调用,在其他设备中返回17000005错误码。
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象,返回无结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
| 17000005 | This operation is not supported. |
**示例:**
```ts
import { Driver, UiWindow } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let window: UiWindow = await driver.findWindow({actived: true});
await window.maximize();
}
```
### minimize9+
minimize(): Promise\
将窗口最小化,使用Promise异步回调。适用于支持窗口最小化操作的窗口。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**设备行为差异**:该接口在PC/2in1、Tablet设备中可正常调用,在其他设备中返回17000005错误码。
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象,返回无结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
| 17000005 | This operation is not supported. |
**示例:**
```ts
import { Driver, UiWindow } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let window: UiWindow = await driver.findWindow({actived: true});
await window.minimize();
}
```
### resume9+
resume(): Promise\
将窗口恢复到之前的窗口模式,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**设备行为差异**:该接口在PC/2in1、Tablet设备中可正常调用,在其他设备中返回17000005错误码。
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
| 17000005 | This operation is not supported. |
**示例:**
```ts
import { Driver, UiWindow } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let window: UiWindow = await driver.findWindow({actived: true});
await window.resume();
}
```
### close9+
close(): Promise\
将窗口关闭,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**设备行为差异**:该接口在PC/2in1、Tablet设备中可正常调用,在其他设备中返回17000005错误码。
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
| 17000005 | This operation is not supported. |
**示例:**
```ts
import { Driver, UiWindow } from '@kit.TestKit';
async function demo() {
let driver:Driver = Driver.create();
let window: UiWindow = await driver.findWindow({actived: true});
await window.close();
}
```
### isActive11+
isActive(): Promise\
判断窗口是否为用户正在交互窗口,使用Promise异步回调。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ----------------- | ------------------------------------------------------------ |
| Promise\ | Promise对象,返回窗口对象是否为用户正在交互窗口。true:交互窗口。false:非交互窗口。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------ |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { Driver, UiWindow } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let window: UiWindow = await driver.findWindow({active: true});
let focused = await window.isActive();
}
```
### getDisplayId20+
getDisplayId(): Promise\
获取窗口所属的屏幕ID,使用Promise异步回调。
**原子化服务API:** 从API version 20开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ---------------- |----------------------|
| Promise\ | Promise对象,返回窗口所属的屏幕ID。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ---------------------------------------- |
| 17000002 | The async function is not called with await. |
| 17000004 | The window or component is invisible or destroyed. |
**示例:**
```ts
import { UiWindow, Driver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let window: UiWindow = await driver.findWindow({active: true});
let id = await window.getDisplayId();
}
```
## UIEventObserver10+
UI事件监听器。
### once('toastShow')10+
once(type: 'toastShow', callback: Callback\): void;
开始监听toast控件出现的事件,使用callback的形式返回结果。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------------------------------------------- | ---- | --------------------------------- |
| type | string | 是 | 订阅的事件类型,取值为'toastShow'。 |
| callback | Callback\<[UIElementInfo](#uielementinfo10)> | 是 | 事件发生时执行的回调函数。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver, UIElementInfo, UIEventObserver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let observer: UIEventObserver = await driver.createUIEventObserver();
let callback = (UIElementInfo: UIElementInfo)=>{
console.info(UIElementInfo.bundleName);
console.info(UIElementInfo.text);
console.info(UIElementInfo.type);
}
observer.once('toastShow', callback);
}
```
### once('dialogShow')10+
once(type: 'dialogShow', callback: Callback\): void;
开始监听dialog控件出现的事件,使用callback的形式返回结果。
**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------------------------------------------- | ---- | ---------------------------------- |
| type | string | 是 | 订阅的事件类型,取值为'dialogShow'。 |
| callback | Callback\<[UIElementInfo](#uielementinfo10)> | 是 | 事件发生时执行的回调函数。 |
**错误码:**
以下错误码的详细介绍请参见[通用错误码](../errorcode-universal.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------------------ |
| 401 | Parameter error. Possible causes: 1.Mandatory parameters are left unspecified; 2. Incorrect parameter types; 3. Parameter verification failed.|
**示例:**
```ts
import { Driver, UIElementInfo, UIEventObserver } from '@kit.TestKit';
async function demo() {
let driver: Driver = Driver.create();
let observer: UIEventObserver = await driver.createUIEventObserver();
let callback = (UIElementInfo: UIElementInfo)=>{
console.info(UIElementInfo.bundleName);
console.info(UIElementInfo.text);
console.info(UIElementInfo.type);
}
observer.once('dialogShow', callback);
}
```
## By(deprecated)
UiTest框架通过By类提供了丰富的控件特征描述API,用于进行控件筛选来匹配/查找出目标控件。
By提供的API能力具有以下几个特点:
1、支持单属性匹配和多属性组合匹配,例如同时指定目标控件text和id。
2、控件属性支持多种匹配模式。
3、支持控件绝对定位,相对定位,可通过[By.isBefore(deprecated)](#isbeforedeprecated)和[By.isAfter(deprecated)](#isafterdeprecated)等API限定邻近控件特征进行辅助定位。
By类提供的所有API均为同步接口,建议使用者通过静态构造器BY来链式创建By对象。
从API version 9开始不再维护,建议使用[On9+](#on9)。
```ts
import { BY } from '@kit.TestKit';
BY.text('123').type('Button');
```
### text(deprecated)
text(txt: string, pattern?: MatchPattern): By
指定目标控件文本属性,支持多种匹配模式,返回By对象自身。
从API version 9开始不再维护,建议使用[text9+](#text9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------- | ----------------------------- | ---- | --------------------------------------------------- |
| txt | string | 是 | 指定控件文本,用于匹配目标控件文本。 |
| pattern | [MatchPattern](#matchpattern) | 否 | 指定的文本匹配模式,默认为[EQUALS](#matchpattern)。 |
**返回值:**
| 类型 | 说明 |
| ------------------- | ---------------------------------- |
| [By](#bydeprecated) | 返回指定目标控件文本属性的By对象。 |
**示例:**
```ts
import { BY, By } from '@kit.TestKit';
let by: By = BY.text('123'); // 使用静态构造器BY创建by对象,指定目标控件的text属性。
```
### key(deprecated)
key(key: string): By
指定目标控件key值属性,返回By对象自身。
从API version 9开始不再维护,建议使用[id9+](#id9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ----------------- |
| key | string | 是 | 指定控件的Key值。 |
**返回值:**
| 类型 | 说明 |
| ------------------- | ----------------------------------- |
| [By](#bydeprecated) | 返回指定目标控件key值属性的By对象。 |
**示例:**
```ts
import { By, BY } from '@kit.TestKit';
let by: By = BY.key('123'); // 使用静态构造器BY创建by对象,指定目标控件的key值属性。
```
### id(deprecated)
id(id: number): By
指定目标控件id属性,返回By对象自身。
从API version 9开始废弃。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ---------------- |
| id | number | 是 | 指定控件的id值。 |
**返回值:**
| 类型 | 说明 |
| ------------------- | -------------------------------- |
| [By](#bydeprecated) | 返回指定目标控件id属性的By对象。 |
**示例:**
```ts
import { By, BY } from '@kit.TestKit';
let by: By = BY.id(123); // 使用静态构造器BY创建by对象,指定目标控件的id属性。
```
### type(deprecated)
type(tp: string): By
指定目标控件的控件类型属性,返回By对象自身。
从API version 9开始不再维护,建议使用[type9+](#type9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | -------------- |
| tp | string | 是 | 指定控件类型。 |
**返回值:**
| 类型 | 说明 |
| ------------------- | ---------------------------------------- |
| [By](#bydeprecated) | 返回指定目标控件的控件类型属性的By对象。 |
**示例:**
```ts
import { By, BY } from '@kit.TestKit';
let by: By = BY.type('Button'); // 使用静态构造器BY创建by对象,指定目标控件的控件类型属性。
```
### clickable(deprecated)
clickable(b?: boolean): By
指定目标控件的可点击状态属性,返回By对象自身。
从API version 9开始不再维护,建议使用[clickable9+](#clickable9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------- | ---- | ------------------------------------------------------------ |
| b | boolean | 否 | 指定控件可点击状态。true:可点击。false:不可点击。默认为true。 |
**返回值:**
| 类型 | 说明 |
| ------------------- | ------------------------------------------ |
| [By](#bydeprecated) | 返回指定目标控件的可点击状态属性的By对象。 |
**示例:**
```ts
import { By, BY } from '@kit.TestKit';
let by: By = BY.clickable(true); // 使用静态构造器BY创建by对象,指定目标控件的可点击状态属性。
```
### scrollable(deprecated)
scrollable(b?: boolean): By
指定目标控件的可滑动状态属性,返回By对象自身。
从API version 9开始不再维护,建议使用[scrollable9+](#scrollable9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------- | ---- | ----------------------------------------------------------- |
| b | boolean | 否 | 控件可滑动状态。true:可滑动。false:不可滑动。默认为true。 |
**返回值:**
| 类型 | 说明 |
| ------------------- | ------------------------------------------ |
| [By](#bydeprecated) | 返回指定目标控件的可滑动状态属性的By对象。 |
**示例:**
```ts
import { By, BY } from '@kit.TestKit';
let by: By = BY.scrollable(true); // 使用静态构造器BY创建by对象,指定目标控件的可滑动状态属性。
```
### enabled(deprecated)
enabled(b?: boolean): By
指定目标控件的使能状态属性,返回By对象自身。
从API version 9开始不再维护,建议使用[enabled9+](#enabled9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------- | ---- | --------------------------------------------------------- |
| b | boolean | 否 | 指定控件使能状态。true:使能。false:未使能。默认为true。 |
**返回值:**
| 类型 | 说明 |
| ------------------- | ---------------------------------------- |
| [By](#bydeprecated) | 返回指定目标控件的使能状态属性的By对象。 |
**示例:**
```ts
import { By, BY } from '@kit.TestKit';
let by: By = BY.enabled(true); // 使用静态构造器BY创建by对象,指定目标控件的使能状态属性。
```
### focused(deprecated)
focused(b?: boolean): By
指定目标控件的获焦状态属性,返回By对象自身。
从API version 9开始不再维护,建议使用[focused9+](#focused9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------- | ---- | ----------------------------------------------------- |
| b | boolean | 否 | 控件获焦状态。true:获焦。false:未获焦。默认为true。 |
**返回值:**
| 类型 | 说明 |
| ------------------- | ---------------------------------------- |
| [By](#bydeprecated) | 返回指定目标控件的获焦状态属性的By对象。 |
**示例:**
```ts
import { By, BY } from '@kit.TestKit';
let by: By = BY.focused(true); // 使用静态构造器BY创建by对象,指定目标控件的获焦状态属性。
```
### selected(deprecated)
selected(b?: boolean): By
指定目标控件的被选中状态属性,返回By对象自身。
从API version 9开始不再维护,建议使用[selected9+](#selected9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------- | ---- | ------------------------------------------------------------ |
| b | boolean | 否 | 指定控件被选中状态。true:被选中。false:未被选中。默认为true。 |
**返回值:**
| 类型 | 说明 |
| ------------------- | ------------------------------------------ |
| [By](#bydeprecated) | 返回指定目标控件的被选中状态属性的By对象。 |
**示例:**
```ts
import { By, BY } from '@kit.TestKit';
let by: By = BY.selected(true); // 使用静态构造器BY创建by对象,指定目标控件的被选中状态属性。
```
### isBefore(deprecated)
isBefore(by: By): By
指定目标控件位于给出的特征属性控件之前,返回By对象自身。
从API version 9开始不再维护,建议使用[isBefore9+](#isbefore9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------------------- | ---- | ---------------- |
| by | [By](#bydeprecated) | 是 | 特征控件的属性。 |
**返回值:**
| 类型 | 说明 |
| ------------------- | ---------------------------------------------------- |
| [By](#bydeprecated) | 返回指定目标控件位于给出的特征属性控件之前的By对象。 |
**示例:**
```ts
import { By, BY } from '@kit.TestKit';
// 使用静态构造器BY创建by对象,指定目标控件位于给出的特征属性控件之前。
let by: By = BY.type('Button').isBefore(BY.text('123')); // 查找text为123之前的第一个Button组件
```
### isAfter(deprecated)
isAfter(by: By): By
指定目标控件位于给出的特征属性控件之后,返回By对象自身。
从API version 9开始不再维护,建议使用[isAfter9+](#isafter9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------------------- | ---- | ---------------- |
| by | [By](#bydeprecated) | 是 | 特征控件的属性。 |
**返回值:**
| 类型 | 说明 |
| ------------------- | ---------------------------------------------------- |
| [By](#bydeprecated) | 返回指定目标控件位于给出的特征属性控件之后的By对象。 |
**示例:**
```ts
import { By, BY } from '@kit.TestKit';
// 使用静态构造器BY创建by对象,指定目标控件位于给出的特征属性控件之后。
let by: By = BY.type('Text').isAfter(BY.text('123')); // 查找 text为123之后的第一个Text组件
```
## UiComponent(deprecated)
UiTest中,UiComponent类代表了UI界面上的一个控件,提供控件属性获取,控件点击,滑动查找,文本注入等API。
该类提供的所有方法都使用Promise方式作为异步方法,需使用await调用。
从API version 9开始不再维护,建议使用[Component9+](#component9)。
### click(deprecated)
click(): Promise\
控件对象进行点击操作。
从API version 9开始不再维护,建议使用[click9+](#click9)。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**示例:**
```ts
import { UiDriver, BY, Driver, UiComponent } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
let button: UiComponent = await driver.findComponent(BY.type('Button'));
await button.click();
}
```
### doubleClick(deprecated)
doubleClick(): Promise\
控件对象进行双击操作。
从API version 9开始不再维护,建议使用[doubleClick9+](#doubleclick9)。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**示例:**
```ts
import { UiDriver, BY, UiComponent } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
let button: UiComponent = await driver.findComponent(BY.type('Button'));
await button.doubleClick();
}
```
### longClick(deprecated)
longClick(): Promise\
控件对象进行长按操作。
从API version 9开始不再维护,建议使用[longClick9+](#longclick9)。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**示例:**
```ts
import { UiDriver, BY, UiComponent } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
let button: UiComponent = await driver.findComponent(BY.type('Button'));
await button.longClick();
}
```
### getId(deprecated)
getId(): Promise\
获取控件对象的id值。
从API version 9开始不再维护,被废弃。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ---------------- | ------------------------------- |
| Promise\ | Promise对象,返回控件的id值。 |
**示例:**
```ts
import { UiDriver, BY, UiComponent } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
let button: UiComponent = await driver.findComponent(BY.type('Button'));
let id = await button.getId();
}
```
### getKey(deprecated)
getKey(): Promise\
获取控件对象的key值。
从API version 9开始不再维护,建议使用[getId9+](#getid9)
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ---------------- | ------------------------------ |
| Promise\ | Promise对象,返回控件的key值。 |
**示例:**
```ts
import { UiDriver, BY, UiComponent } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
let button: UiComponent = await driver.findComponent(BY.type('Button'));
let str_key = await button.getKey();
}
```
### getText(deprecated)
getText(): Promise\
获取控件对象的文本信息。
从API version 9开始不再维护,建议使用[getText9+](#gettext9)。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ---------------- | --------------------------------- |
| Promise\ | Promise对象,返回控件的文本信息。 |
**示例:**
```ts
import { UiDriver, BY, UiComponent } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
let button: UiComponent = await driver.findComponent(BY.type('Button'));
let text = await button.getText();
}
```
### getType(deprecated)
getType(): Promise\
获取控件对象的控件类型。
从API version 9开始不再维护,建议使用[getType9+](#gettype9)。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ---------------- | ----------------------------- |
| Promise\ | Promise对象,返回控件的类型。 |
**示例:**
```ts
import { UiDriver, BY, UiComponent } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
let button: UiComponent = await driver.findComponent(BY.type('Button'));
let type = await button.getType();
}
```
### isClickable(deprecated)
isClickable(): Promise\
获取控件对象可点击状态。
从API version 9开始不再维护,建议使用[isClickable9+](#isclickable9)。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ----------------- | ------------------------------------------------------------ |
| Promise\ | Promise对象,返回控件对象可点击状态。true:可点击。false:不可点击。 |
**示例:**
```ts
import { UiDriver, BY, UiComponent } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
let button: UiComponent = await driver.findComponent(BY.type('Button'));
if (await button.isClickable()) {
console.info('This button can be Clicked');
} else {
console.info('This button can not be Clicked');
}
}
```
### isScrollable(deprecated)
isScrollable(): Promise\
获取控件对象可滑动状态。
从API version 9开始不再维护,建议使用[isScrollable9+](#isscrollable9)。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ----------------- | ------------------------------------------------------------ |
| Promise\ | Promise对象,返回控件对象可滑动状态。true:可滑动。false:不可滑动。 |
**示例:**
```ts
import { UiDriver, BY, UiComponent } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
let scrollBar: UiComponent = await driver.findComponent(BY.scrollable(true));
if (await scrollBar.isScrollable()) {
console.info('This scrollBar can be operated');
} else {
console.info('This scrollBar can not be operated');
}
}
```
### isEnabled(deprecated)
isEnabled(): Promise\
获取控件使能状态。
从API version 9开始不再维护,建议使用[isEnabled9+](#isenabled9)。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ----------------- | ---------------------------------------------------------- |
| Promise\ | Promise对象,返回控件使能状态。true:使能。false:未使能。 |
**示例:**
```ts
import { UiDriver, BY, UiComponent } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
let button: UiComponent = await driver.findComponent(BY.type('Button'));
if (await button.isEnabled()) {
console.info('This button can be operated');
} else {
console.info('This button can not be operated');
}
}
```
### isFocused(deprecated)
isFocused(): Promise\
判断控件对象是否获焦。
从API version 9开始不再维护,建议使用[isFocused9+](#isfocused9)。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ----------------- | ------------------------------------------------------------ |
| Promise\ | Promise对象,返回控件对象是否获焦。true:获焦。false:未获焦。 |
**示例:**
```ts
import { UiDriver, BY, UiComponent } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
let button: UiComponent = await driver.findComponent(BY.type('Button'));
if (await button.isFocused()) {
console.info('This button is focused');
} else {
console.info('This button is not focused');
}
}
```
### isSelected(deprecated)
isSelected(): Promise\
获取控件对象被选中状态。
从API version 9开始不再维护,建议使用[isSelected9+](#isselected9)。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| ----------------- | ----------------------------------------------------- |
| Promise\ | Promise对象,返回控件对象被选中的状态。true:被选中。false:未被选中。 |
**示例:**
```ts
import { UiDriver, BY, UiComponent } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
let button: UiComponent = await driver.findComponent(BY.type('Button'));
if (await button.isSelected()) {
console.info('This button is selected');
} else {
console.info('This button is not selected');
}
}
```
### inputText(deprecated)
inputText(text: string): Promise\
向控件中输入文本,仅针对可编辑的文本组件生效。
从API version 9开始不再维护,建议使用[inputText9+](#inputtext9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | ---------------- |
| text | string | 是 | 输入的文本信息。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**示例:**
```ts
import { UiDriver, BY, UiComponent } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
let text: UiComponent = await driver.findComponent(BY.text('hello world'));
await text.inputText('123');
}
```
### scrollSearch(deprecated)
scrollSearch(by: By): Promise\
在控件上滑动查找目标控件(适用于List等支持滑动的控件)。
从API version 9开始不再维护,建议使用[scrollSearch9+](#scrollsearch9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------------------- | ---- | -------------------- |
| by | [By](#bydeprecated) | 是 | 目标控件的属性要求。 |
**返回值:**
| 类型 | 说明 |
| ----------------------------------------------- | ------------------------------------- |
| Promise\<[UiComponent](#uicomponentdeprecated)> | Promise对象,返回目标控件对象。 |
**示例:**
```ts
import { UiDriver, BY, UiComponent } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
let scrollBar: UiComponent = await driver.findComponent(BY.type('Scroll'));
let button = await scrollBar.scrollSearch(BY.text('next page'));
}
```
## UiDriver(deprecated)
UiDriver类为uitest测试框架的总入口,提供控件匹配/查找,按键注入,坐标点击/滑动,截图等API。
该类提供的方法除UiDriver.create()以外的所有方法都使用Promise方式作为异步方法,需使用await调用。
从API version 9开始不再维护,建议使用[Driver9+](#driver9)。
### create(deprecated)
static create(): UiDriver
静态方法,构造一个UiDriver对象,并返回该对象。
从API version 9开始不再维护,建议使用[create9+](#create9)。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
| -------- | ------------------------ |
| UiDriver | 返回构造的UiDriver对象。 |
**示例:**
```ts
import { UiDriver } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
}
```
### delayMs(deprecated)
delayMs(duration: number): Promise\
UiDriver对象在给定的时间内延时。
从API version 9开始不再维护,建议使用[delayMs9+](#delayms9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | ------ | ---- | ------------ |
| duration | number | 是 | 给定的时间。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**示例:**
```ts
import { UiDriver } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
await driver.delayMs(1000);
}
```
### findComponent(deprecated)
findComponent(by: By): Promise\
在UiDriver对象中,根据给出的目标控件属性要求查找目标控件。
从API version 9开始不再维护,建议使用[findComponent9+](#findcomponent9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------------------- | ---- | -------------------- |
| by | [By](#bydeprecated) | 是 | 目标控件的属性要求。 |
**返回值:**
| 类型 | 说明 |
| ----------------------------------------------- | --------------------------------- |
| Promise\<[UiComponent](#uicomponentdeprecated)> | Promise对象,返回控件对象。 |
**示例:**
```ts
import { UiDriver, BY, UiComponent } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
let button: UiComponent = await driver.findComponent(BY.text('next page'));
}
```
### findComponents(deprecated)
findComponents(by: By): Promise\>
在UiDriver对象中,根据给出的目标控件属性要求查找出所有匹配控件,以列表保存。
从API version 9开始不再维护,建议使用[findComponents9+](#findcomponents9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------------------- | ---- | -------------------- |
| by | [By](#bydeprecated) | 是 | 目标控件的属性要求。 |
**返回值:**
| 类型 | 说明 |
| ------------------------------------------------------- | --------------------------------------- |
| Promise\> | Promise对象,返回控件对象的列表。 |
**示例:**
```ts
import { UiDriver, BY, UiComponent } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
let buttonList: Array = await driver.findComponents(BY.text('next page'));
}
```
### assertComponentExist(deprecated)
assertComponentExist(by: By): Promise\
断言API,用于断言当前界面存在满足给出的目标控件属性的控件; 如果控件不存在,该API将抛出JS异常,使当前测试用例失败。
从API version 9开始不再维护,建议使用[assertComponentExist9+](#assertcomponentexist9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------------------- | ---- | -------------------- |
| by | [By](#bydeprecated) | 是 | 目标控件的属性要求。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**错误码:**
以下错误码的详细介绍请参见[uitest测试框架错误码](errorcode-uitest.md)。
| 错误码ID | 错误信息 |
| -------- | ------------------------------------------------ |
| 401 | if the input parameters are invalid. |
| 17000002 | if the async function was not called with await. |
| 17000003 | if the assertion failed. |
**示例:**
```ts
import { UiDriver, BY } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
await driver.assertComponentExist(BY.text('next page'));
}
```
### pressBack(deprecated)
pressBack(): Promise\
UiDriver对象进行点击BACK键的操作。
从API version 9开始不再维护,建议使用[pressBack9+](#pressback9)。
**系统能力**:SystemCapability.Test.UiTest
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**示例:**
```ts
import { UiDriver } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
await driver.pressBack();
}
```
### triggerKey(deprecated)
triggerKey(keyCode: number): Promise\
UiDriver对象采取如下操作:通过key值找到对应键并点击。
从API version 9开始不再维护,建议使用[triggerKey9+](#triggerkey9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------- | ------ | ---- | ------------- |
| keyCode | number | 是 | 指定的key值,取值大于等于0的整数,取值范围:[KeyCode键码值](../apis-input-kit/js-apis-keycode.md#keycode)。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**示例:**
```ts
import { Driver, UiDriver } from '@kit.TestKit';
import { KeyCode } from '@kit.InputKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
await driver.triggerKey(KeyCode.KEYCODE_BACK); // 返回键
}
```
### click(deprecated)
click(x: number, y: number): Promise\
UiDriver对象采取如下操作:在目标坐标点单击。
从API version 9开始不再维护,建议使用[click9+](#click9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | -------------------------------------- |
| x | number | 是 | 以number的形式传入目标点的横坐标信息,取值范围:大于等于0的整数。 |
| y | number | 是 | 以number的形式传入目标点的纵坐标信息,取值范围:大于等于0的整数。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**示例:**
```ts
import { UiDriver } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
await driver.click(100, 100);
}
```
### doubleClick(deprecated)
doubleClick(x: number, y: number): Promise\
UiDriver对象采取如下操作:在目标坐标点双击。
从API version 9开始不再维护,建议使用[doubleClick9+](#doubleclick9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | -------------------------------------- |
| x | number | 是 | 以number的形式传入目标点的横坐标信息,取值范围:大于等于0的整数。 |
| y | number | 是 | 以number的形式传入目标点的纵坐标信息,取值范围:大于等于0的整数。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**示例:**
```ts
import { UiDriver } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
await driver.doubleClick(100, 100);
}
```
### longClick(deprecated)
longClick(x: number, y: number): Promise\
UiDriver对象采取如下操作:在目标坐标点长按下鼠标左键。
从API version 9开始不再维护,建议使用[longClick9+](#longclick9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | -------------------------------------- |
| x | number | 是 | 以number的形式传入目标点的横坐标信息,取值范围:大于等于0的整数。 |
| y | number | 是 | 以number的形式传入目标点的纵坐标信息,取值范围:大于等于0的整数。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**示例:**
```ts
import { UiDriver } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
await driver.longClick(100, 100);
}
```
### swipe(deprecated)
swipe(startx: number, starty: number, endx: number, endy: number): Promise\
UiDriver对象采取如下操作:从给出的起始坐标点滑向给出的目的坐标点。
从API version 9开始不再维护,建议使用[swipe9+](#swipe9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------ | ------ | ---- | -------------------------------------- |
| startx | number | 是 | 以number的形式传入起始点的横坐标信息,取值范围:大于等于0的整数。 |
| starty | number | 是 | 以number的形式传入起始点的纵坐标信息,取值范围:大于等于0的整数。 |
| endx | number | 是 | 以number的形式传入目的点的横坐标信息,取值范围:大于等于0的整数。 |
| endy | number | 是 | 以number的形式传入目的点的纵坐标信息,取值范围:大于等于0的整数。 |
**返回值:**
| 类型 | 说明 |
|----------------|-----------------|
| Promise\ | Promise对象。无返回结果的Promise对象。 |
**示例:**
```ts
import { UiDriver } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
await driver.swipe(100, 100, 200, 200);
}
```
### screenCap(deprecated)
screenCap(savePath: string): Promise\
UiDriver对象采取如下操作:捕获当前屏幕,并保存为PNG格式的图片至给出的保存路径中。
从API version 9开始不再维护,建议使用[screenCap9+](#screencap9)。
**系统能力**:SystemCapability.Test.UiTest
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | ------ | ---- | -------------- |
| savePath | string | 是 | 文件保存路径。 |
**返回值:**
| 类型 | 说明 |
| ----------------- |-----------------------------------------------|
| Promise\ | Promise对象,返回截图操作是否成功完成。true:成功完成,false:未成功完成。 |
**示例:**
```ts
import { UiDriver } from '@kit.TestKit';
async function demo() {
let driver: UiDriver = UiDriver.create();
await driver.screenCap('/data/storage/el2/base/cache/1.png');
}
```