# wukong部件
## 简介
OpenHarmony稳定性测试自动化工具,通过模拟用户行为,对OpenHarmony系统及应用进行稳定性压力测试。
wukong部件架构图
![架构图](figures/wukong部件架构图.png)
部件内子模块职责:
1. 命令行解析:支持命令行获取参数并解析命令行参数。
2. 运行环境管理:根据命令行初始化wukong整体运行环境。
3. 系统接口管理:检查并获取指定的mgr,注册controller和dfx的faultlog的回调函数。
4. 随机事件生成:通过random函数生成指定种子数的随机序列,生成事件。
5. 事件注入:根据支持的事件类型向系统注入事件,依赖窗口、多模、安全等子系统。
6. 异常捕获处理/报告生成:通过DFX子系统获取运行中的异常信息并记录log,生成报告。
## 目录
```
├── wukong # wukong主要代码文件
| └── common # 提供应用管控能力,随机事件注入能力,多模事件注入能力
| └── component_event # 定义ability、page、Component树,提供添加节点、遍历树、依据NodeId查找子节点等能力
| └── input_factory # 实现屏幕点击、滑动、拖拽、键盘等事件注入能力
| └── report # 监听异常信息,对其进行收集、统计、显示功能
| └── shell_command # 用来创建命令行map,解析命令行参数并执行命令行
| └── test_flow
│ └── include # 定义头文件
│ └── src
│ ├── random_test_flow.cpp # 继承TestFlow,是随机测试的执行流
│ ├── special_test_flow.cpp # 继承TestFlow,是顺序专项测试的执行流
│ ├── test_flow.cpp # 检查命令行参数是否符合规范
│ ── BUILD.gn # 存放wukong构建的配置,具体包括构建对象、方式、依赖、硬件架构、文件格式
│ ── README_zh.md # readme文件
```
## 约束
1. wukong在3.2系统版本后开始预置使用。
2. wukong在3.2系统版本之前的版本不随版本编译,使用时需自行编译后推送至被测OpenHarmony设备,步骤如下:
2.1. 构建方式
```
./build.sh --product-name rk3568 --build-target wukong
```
2.2. 推送方式
```
hdc_std shell mount -o rw,remount /
hdc_std file send wukong /
hdc_std shell chmod a+x /wukong
hdc_std shell mv /wukong /bin/
```
## 使用说明
### 功能特性及命令说明
| 命令 | 说明 | 备注 |
| -------------- | ---------------------------------------------- | ------------- |
| version | 获取wukong版本信息。 | -v, --version。 |
| help | 获取wukong帮助信息。 | |
| appinfo | 查询支持拉起应用bundleName和对应的mainAbility名。 | |
| special | wukong专项测试。 | |
| exec | wukong随机测试。 | |
### wukong special描述
| 命令 | 功能 | 必选 | 备注 |
| :------------------ | ---------------------- | ---- | :------------------ |
| -h, --help | 获取当前测试的帮助信息。 | 否 | 专项测试帮助信息。 |
| -k, --spec_insomnia | 休眠唤醒专项测试。 | 否 | - |
| -c, --count | 设置执行次数。 | 否 | 默认10次。 |
| -i, --interval | 设置执行间隔。 | 否 | 单位ms,默认1500ms。 |
| -S, --swap | 滑动测试。 | 否 | - |
|-s, --start[x,y] | 设置滑动测试起点坐标。 | 否 | - |
| -e, --end[x,y] | 设置滑动测试终点坐标。 | 否 | - |
| -b, --bilateral | 设置往返滑动。 | 否 | 默认不往返滑动。 |
| -t, --touch[x,y] | 点击测试。 | 否 | - |
| -T, --time | 设置测试总时间。 | 否 | 单位分钟,默认10分钟。 |
| -C, --component | 控件顺序遍历测试。 | 否 | 需要设置测试应用名称。 |
| -r, --record | 录制。 | 否 | 需要指定录制文件。 |
| -R, --replay | 回放。 | 否 | 需要指定回放文件。 |
| -p, --screenshot | 控件测试截图。 | 否 | - |
#### wukong special 专项测试使用示例
```bash
> hdc_std shell
# wukong special -C [bundlename] -p
```
专项测试示例解析:
| 命令 | 参数值 | 说明 |
| -------------- |-------------- | ---------------------------------------------- |
| wukong special | | 主命令。 |
| -C [bundlename] |[bundlename] | 控件顺序遍历测试参数设置,bundlename为测试应用名称。 |
| -p | | 表示截图。 |
### wukong random描述
| 命令 | 功能 | 必选 | 备注 |
| --------------- | ------------------------------------ | ---- | ---------------------------------------- |
| -h,--help | 获取当前测试的帮助信息。 | 否 | 随机测试帮助信息。 |
| -c,--count | 设置执行次数,与-T冲突。 | 否 | 单位次数,默认10次。 |
| -i,--interval | 设置执行间隔。 | 否 | 单位ms,默认1500ms。 |
| -s,--seed | 设置随机种子。 | 否 | 配置相同随机种子,会生成相同随机事件序列。 |
| -b,--bundle[bundlename,……,bundlename] | 设置本次测试的允许应用名单,与-p冲突。 | 否 | 默认测试当前设备所有应用(应用名称用逗号隔开)。 |
| -p,--prohibit[bundlename,……,bundlename] | 设置本次测试的禁止应用名单,与-b冲突。 | 否 | 默认不禁止任何应用(应用名称用逗号隔开)。 |
| -a,--appswitch | 设置应用随机拉起测试比例。 | 否 | 默认10%。 |
| -t,--touch | 设置屏幕随机touch测试比例。 | 否 | 默认10%。 |
| -S,--swap | 设置屏幕随机swap测试比例。 | 否 | 默认3%。 |
| -m,--mouse | 设置屏幕随机mouse测试比例。 | 否 | 默认1%。 |
| -k,--keyboard | 设置屏幕随机keyboard测试比例。 | 否 | 默认2%。 |
| -H,--hardkey | 设置随机hardkey测试比例。 | 否 | 默认4%。 |
| -C, --component | 设置随机控件测试比例。 | 否 | 默认70%。 |
| -T,--time | 设置测试总时间,与-c冲突。 | 否 | 单位分钟,默认10分钟。 |
> 说明:配置相同随机种子,会生成相同随机事件序列
#### wukong exec 随机测试使用示例
```bash
> hdc_std shell
# wukong exec -s 10 -i 1000 -a 0.28 -t 0.72 -c 100
```
随机测试示例解析:
| 命令 | 参数值 | 说明 |
| -------------- | -------------- | ---------------------------------------------- |
| wukong exec | | 主命令。 |
| -s | 10 | 参数设置随机种子,10为种子值。 |
| -i | 1000 | 参数设置应用拉起间隔,1000单位ms。 |
| -a | 0.28 | 参数设置应用随机拉起测试比例28%。 |
| -t | 0.72 | 参数设置屏幕随机touch测试比例为72%。 |
| -c | 100 | 参数设置执行次数为100次。 |
## 版本说明
3.2.0.0 版本发布内容:预置wukong,支持以下功能:
1. 支持整机应用拉起、设置随机种子、设置应用拉起间隔、设置应用拉起次数、支持查询应用拉起bundle名和ability名。
2. 支持随机注入事件、支持随机注入控件、支持休眠唤醒专项测试、支持控件顺序遍历截图专项测试。
3. 支持wukong运行日志打印。
4. 支持应用白、黑名单。