老李推荐:第5章6节《MonkeyRunner源码剖析》Monkey原理分析-启动运行: 初始化事件源

时间:2022-02-11 08:12:08

老李推荐:第5章6节《MonkeyRunner源码剖析》Monkey原理分析-启动运行: 初始化事件源

 

poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标。如果对课程感兴趣,请大家咨询qq:908821478,咨询电话010-84505200。

事件源代表要注入系统的命令事件数据是从哪里过来的。这一小节我们不会对事件源的实现进行深入的分析,因为下一章会做这个事情。这里大家对事件源有个基本概念就足够了。

对Monkey来说,事件的来源可以有多个地方,比如我们用它来做随机压力测试的时候由Monkey自身生成的各种随机事件,又或者作为MonkeyRunner测试框架一部分时从USB/TCP过来的命令,这里我们对USB/TCP过来的事件来源统称为网络事件源。不同的事件源会有不同的类来做相应的实现:

  • MonkeySourceNetwork: 事件是从网络MonkeyRunner客户端过来的,处理的是界面控制操作相关的事件,比如press等

  • MonkeySourceNetworkVars: 事件也是从网络如MonkeyRunner过来的,处理的是获取系统属性这个getProperties这个事件

  • MonkeySourceNetworkViews:事件也是从网络如MonkeyRunner过来的,处理的是控件相关的事件

  • MonkeySourceRandom:事件是从monkey内部生成的随机事件集,也就是我们通过命令行启动monkey测试目标app的常用方式

  • MonkeySourceRandomScript: 上面的随机内部数据源也可以通过指定setup脚本来创建

  • MonkeySourceScript: 用户也可以遵循一定的规则编写monkey脚本来驱动monkey进行相关测试,与上面不同的是它不再是随机的

前面的三个事件源是跟我们的MonkeyRunner框架相关的,下一章我们会针对其进行详细分析,在这里我们只需要知道这些事件源代表了事件的不同的来源,然后主要就是处理下面两个事情就好了:

  • 从指定的源获取事件

  • 把命令翻译成monkey事件然后放到命令队列中,事件源的所有事件都是通过命令队列来管理起来的,有事件产生的时候就会往队列里面放,处理完事件后就会把该事件从命令队列中去掉

那么我们继续往下分析Monkey类的run方法,去了解下Monkey在启动的过程中是怎么去根据不同的情况去初始化不同的事件源的。

代码5-6-1 Monkey - run 初始化事件源

      /**
* Run the command!
*
* @param args The command-line arguments
* @return Returns a posix-style result code. 0 for no error.
*/
private int run(String[] args) {
...//省略其他事件源初始化代码
} else if (mServerPort != -1) {
try {
mEventSource = new MonkeySourceNetwork(mServerPort);
} catch (IOException e) {
System.out.println("Error binding to network socket.");
return -5;
}
...
}

run方法前面省略的一大段代码的作用简要来说就是根据不同的情况来初始化不同的事件源,比如如果在启动Monkey的时候指定了” -f scriptfile”且指定了一个脚本文件的话,那么就初始化MonkeySourceScript事件源。但这些在这里其实都不重要,因为它们跟Monkey作为MonkeyRunner的服务没有很大关系,MonkeyRunner启动Monkey使用的命令是”monkey -port 12345”。 所以这里真正的重点是第514-516行的代码,如果启动Monkey的时候指定了”-port”这个参数的话,初始化的就是MonkeySourceNetwork这个事件源,专门用来从网络上获取事件。

也许大家在这里会有疑问,网络来的事件源不是还有MonkeySourceNetworkViews和MonkeySourceNetworkVars吗?怎么这里没有看到呢?其实这两个类提供的主要是静态方法,没有必要初始化,当MonkeySourceNetwork需要用到它们的时候会在内部调用它们的方法。