网站发布与推广方式,巩义网站建设费用,南宁信息建设网站,怎么注册公司域名邮箱黑盒测试中关键截图如何打点Android黑盒测试过程中如何进行有效的打点是我们经常遇到的问题#xff0c;我们一般会在脚本内部进行数据打点#xff0c;也可以使用其他进程录屏或截图。那我们如何选取合适的方式进行打点记录呢#xff1f;下图是对常用打点方式的统计#xff…
黑盒测试中关键截图如何打点Android黑盒测试过程中如何进行有效的打点是我们经常遇到的问题我们一般会在脚本内部进行数据打点也可以使用其他进程录屏或截图。那我们如何选取合适的方式进行打点记录呢下图是对常用打点方式的统计对于测试开发人员来说有效的关键截图信息是最直观的数据可以很快定位问题场景本文重点介绍如何在Shell进程内统计屏幕截图变化。 第三方服务截图
本方案可以在uiautomator1.0脚本内实现也可以自定义Shell进程服务来实现。个人推荐自定义Shell服务然后用app_process命令启动。即使脚本出现异常退出了也不会影响截图服务并且可以截取脚本启动前和结束后的状态。最主要的是Android R开始不再支持uiautomator1.0脚本。
主要通过Activity监听、定时器、进程监听服务触发截图操作在页面变化时、进程状态变化时以及定时检测页面状态。除此之外我们需要一个App提供图片相似度的比较或者搭建其他图片匹配服务也可以。
Activity变化和应用异常时截图
1.首先我们要注册ActivityController
①. 直接通过IActivityController.Stub()方法获取ActivityController对象
②. 通过ActivityManager的setActivityController方法设置监听设置成功后切换页面时就会回调对应的方法
2.我们可以在ActivityController的回调中记录关键截屏信息主要信息有
**①. **新打开的Activity点击按钮跳转页面时
**②. **恢复显示的Activity按返回键退回到上一级页面时显示的页面
**③. **App产生崩溃的详细信息以及截图
**④. **App产生ANR时的详细信息以及截图
**⑤. **我们可以在activityStarting和activityResuming方法中对打开的页面进行控制。
3.缺点
**①. **如果其他进程也注册这个服务那么会相互影响只有最后注册的服务有效
**②. **当在页面中切换Fragment时无法感知到事件变化
**③. **必须在Shell进程内执行普通App内是无法注册成功的
IActivityController mActivityController new IActivityController.Stub() {//当调用Activity的onCreate方法跳转新页面时回调此方法//return false时不会启动Activityreturn true时正常启动Activity//不要在这个方法内做耗时操作Overridepublic boolean activityStarting(Intent intent, String pkg) throws RemoteException {return true;}//当调用Activity的onResume方法比如dialog消失时会调用这个方法Overridepublic boolean activityResuming(String pkg) throws RemoteException {return true;}/*** 有应用在Java层产生异常时回调此方法* 返回true时会显示应用crash的弹窗返回false时会立即kill应用*/Overridepublic boolean appCrashed(String processName, int pid, String shortMsg, String longMsg, long timeMillis, String stackTrace) throws RemoteException {return false;}/*** 检测到ANR异常时就会回调此方法*/Overridepublic int appEarlyNotResponding(String s, int i, String s1) throws RemoteException {return 0;}/*** 应用产生ANR时回调此方法* Return 0 时显示 应用停止响应 弹窗。* Return 1 时不做任何操作等待应用恢复正常* Return -1 时结束产生ANR的应用.*/Overridepublic int appNotResponding(String processName, int pid, String processStats) throws RemoteException {return -1;}/*** 系统停止响应时回调此方法可以在这个方法里面对设备进行些恢复工作 */Overridepublic int systemNotResponding(String msg) throws RemoteException {return 0;}
};
进程变化监听
由于ActivityController服务存在被干扰的情况我们需要其他服务进行辅助判断通过ActivityManager注册IProcessObserver可以获取进程变化的回调特别是在onForegroundActivitiesChanged方法内可以判断是否触发页面切换。
通过IProcessObserver可以实现的功能
**①. **在onForegroundActivitiesChanged方法内监听页面变化
**②. **在onProcessStateChanged和onProcessDied方法内可以统计App的线程生命周期
**③. **可以统计app运行期间创建的线程信息
**④. **该服务被不同进程注册时相互间互不影响
缺点
**①. **没有直观信息需要使用uid进行关联处理复杂
IProcessObserver mProcessObserver new IProcessObserver.Stub() {//与用户交互的Activity发生变化时foregroundActivities为true否则foregroundActivities为false//uid产生该活动的应用标识可以用包信息匹配到具体的应用//pid 当前活动的线程/进城IDOverridepublic void onForegroundActivitiesChanged(int pid, int uid,boolean foregroundActivities) throws RemoteException {if(foregroundActivities) {//}}//活动状态发生变化时调用在此方案内实际意义不大Overridepublic void onProcessStateChanged(int pid, int uid, int importance) throws RemoteException {}//结束时调用Overridepublic void onProcessDied(int pid, int uid) throws RemoteException {}
};
综合应用
上面两种方案各有优劣我们可以将他们整合在一个流程内实现较为完善的截图机制
①. 首先我们的服务主要依赖于ActivityController进行页面变化的感知以便于获取详细的信息和精确控制
**②. **我们注册IProcessObserver进行辅助验证当页面发生变化时我们进行截屏并通过ActivityController最后一次接收事件的时间判断其服务状态如果服务状态异常那么我们重新注册ActivityController服务
**③. **开始监控页面时我们初始化一个定时器可以定时2S截取屏幕将当前截图Bitmap与上一次的截图Bitmap做图像匹配如果图片相似度小于0.8那么可以认定页面发生了变化如果5S内没有保存过页面信息那么需要重新初始化ActivityController服务。
Root设备的特殊方案
Android系统是基于Linux系统的移动操作系统。它们可以通过getevent命令输出键盘和屏幕事件包括响应事件的坐标区域和键盘key值。但是Android系统基于安全考虑大部分真机系统是没有权限执行getevent命令的它不会输出任何有效信息但是华为手机荣耀20 i上却可以正常使用。这是一个非常危险的权限大家自己的手机还是不要开启开发者模式了
/dev/input/event2: EV_ABS ABS_MT_POSITION_X 0000024b
/dev/input/event2: EV_ABS ABS_MT_POSITION_Y 0000065d
/dev/input/event2: EV_ABS ABS_MT_PRESSURE 000000f5
/dev/input/event2: EV_ABS ABS_MT_TRACKING_ID 00000000
/dev/input/event2: EV_ABS ABS_MT_TOUCH_MAJOR 000000a5
/dev/input/event2: EV_ABS ABS_MT_TOUCH_MINOR 00000087
/dev/input/event2: EV_ABS ABS_MT_ORIENTATION ffffffc6
/dev/input/event2: EV_ABS ABS_MT_BLOB_ID 00000002
/dev/input/event2: EV_SYN SYN_MT_REPORT 00000000
/dev/input/event2: EV_KEY BTN_TOUCH DOWN
/dev/input/event2: EV_SYN SYN_REPORT 00000000
/dev/input/event2: EV_ABS ABS_MT_POSITION_X 0000024b
/dev/input/event2: EV_ABS ABS_MT_POSITION_Y 0000065c
/dev/input/event2: EV_ABS ABS_MT_PRESSURE 00000067
/dev/input/event2: EV_ABS ABS_MT_TRACKING_ID 00000000
/dev/input/event2: EV_ABS ABS_MT_TOUCH_MAJOR 000000b4
/dev/input/event2: EV_ABS ABS_MT_TOUCH_MINOR 000000a5
/dev/input/event2: EV_ABS ABS_MT_ORIENTATION ffffffc1
/dev/input/event2: EV_ABS ABS_MT_BLOB_ID 00000002
/dev/input/event2: EV_SYN SYN_MT_REPORT 00000000
/dev/input/event2: EV_SYN SYN_REPORT 00000000
/dev/input/event2: EV_SYN SYN_MT_REPORT 00000000
/dev/input/event2: EV_KEY BTN_TOUCH UP
/dev/input/event2: EV_SYN SYN_REPORT 00000000
**ABS_MT_POSITION_X **屏幕的横坐标后面一列是坐标的十六进制数据
**ABS_MT_POSITION_Y **屏幕纵坐标后面一列是坐标的十六进制数据
BTN_TOUCH 代表屏幕事件后面如果是DOWN则代表按下后面如果是UP代表抬起
我们可以根据ABS_MT_POSITION_X和ABS_MT_POSITION_Y信息和BTN_TOUCH为DOWN的事件计算响应按下事件的屏幕位置然后通过BTN_TOUCH为UP的事件计算抬起的屏幕位置然后用按下和抬起的坐标差来判断该时间是点击还是滑动然后我们可以进行屏幕截图甚至在截图上绘制事件的轨迹。
最后感谢每一个认真阅读我文章的人礼尚往来总是要有的虽然不是什么很值钱的东西如果你用得到的话可以直接拿走 这些资料对于【软件测试】的朋友来说应该是最全面最完整的备战仓库这个仓库也陪伴上万个测试工程师们走过最艰难的路程希望也能帮助到你