Android集成测试主要是在单元测试的基础上测试接口访问或者异步任务是否正确,在移动凤巢系统中,大概有30+个接口需要测试,他们都遵循一个特定的访问模式:前台的Activity获取到触发事件后,将它传给这些接口,这些接口都是AsyncTask的实现——即后台异步线程执行某个任务(一般是发送http请求到后端服务或者执行存取数据库等耗时操作),完毕后调用回调函数,示意图如下:
一、测试框架
对于Android中这种异步接口的自动化测试需要解决3个问题:
1)如何获取到异步任务执行结果;
2)如何让上层测试代码尽量不处理任务等待;
3)如何处理需要登录的接口。
对于问题1)每个异步任务在获取结果后就直接调用onPostExecute()方法了,测试代码获取不到结果,所以必须有一个专门的桩Activity负责异步任务的执行并将结果暴露出来;
对于问题2)尽量将等待操作交给测试基类,上层测试代码只需要执行被测逻辑;
对于问题3)采用模板模式,如果接口需要登录则先执行登录操作后再调用,整体解决方案如下:
其中桩Activity的逻辑如下,它实际决定接口的调用方式,如果被测接口需要登录则先登录后调用,如果不需要登录则直接调用。