一、UiWatcher类说明
1、Uiwatcher用于处理脚本执行过程中遇到非预想的步骤
2、UiWatcher使用场景
1)测试过程中来了一个电话
2)测试过程中来了一条短信
3)测试过程中闹钟响了
4)出现各种非预想的步骤
3、中断监听检查条件
public boolean checkForCondition();
二、UiWatcher监听器操作相关API
在测试框架无法找到一个匹配时,使用UiSelector测试框架将自动调用此处理程序方法。在超时未找到匹配项时,框架调用checkForCondition()方法查找设备上的所有已注册的监听检查条件。可以使用此方法来处理中断问题保证测试用例正常运行。
返回值 | API | 说明 |
void | registerWatcher(String name,Uiwatcher watcher) | 注册一个监听器,当Uiselector无法匹配到对象的时候,触发监听器 |
void | removeWatcger(String name) | 取消之前注册的指定监听器 |
void | resetWatcherTriggers() | 充值已触发过的UiWatcher,重置后相当于没运行过 |
void | runWatchers() | 强制运行所有的监听器 |
三、注册监听器示例代码
public void testDemo() throws IOException, UiObjectNotFoundException {
////////////////////注册监听器////////////////
/////////////////////////////////////////////
UiDevice.getInstance().registerWatcher("phone",new UiWatcher(){
@Override
public boolean checkForCondition(){
//电话监听
UiObject call = new UiObject(new UiSelector().resourceId("com.android.incallui:id/unlock_answer_text").text("接听"));//由接听按钮判断为来电
UiObject call_reject = new UiObject(new UiSelector().resourceId("com.android.incallui:id/unlock_reject"));//挂断按钮
if(call.exists()){
System.out.println("电话监听器被触发啦!!!!");
try{
call_reject.click();
return true;
}catch(UiObjectNotFoundException e){
e.printStackTrace();
}
}
return false;
}
} );
////////////监听器注册移除////////////
/////////////////////////////////////
UiDevice.getInstance().removeWatcher("phone");//移除之后,后面的测试过程中有电话拨进来,不会调用监听器
////////////////////////////////////////////////////
/////////////////常规测试用例开始///////////////////
//////////////////////////////////////////////////
}
返回值 | API | 说明 |
boolean | hasAnyWatcherTriggered() | 检查是否有监听器触发过 |
boolean | hasWatcherTriggered(String watcgerName) | 检查某个特定的监听器是否触发过 |
//////////检查监听器是否被触发过/////////////
///////////////////////////////////////////
System.out.println("是否有监听器触发过:" + UiDevice.getInstance().hasAnyWatcherTriggered());
System.out.println("电话监听器是否被触发过:" + UiDevice.getInstance().hasWatcherTriggered("phone"));
注意一:
检查监听器代码卸载所有的正常测试用例代码之后,在测试完成之后,打印是否触发过监听器。