基于Android的C/S移动应用中访问后端数据的场景是非常多的,异步接口测试主要是在单元测试完成的基础上检查接口级访问是否正确,主要保证对外请求的组装与发送是否符合后端的约定。现在项目的异步接口访问都遵循一个特定的访问模式:前台的Activity获取到触发事件后将接受到的参数传给一个异步任务,这些任务大都是AsyncTask的实现——即启动一个新的线程访问后台接口数据,完毕后调用回调函数更新UI展示,示意图如下:

  一、测试框架

  对于Android中这种异步接口的自动化测试需要解决3个问题:

  1)如何获取到异步任务执行结果;

  2)如何让上层测试代码尽量不处理任务等待;

  3)如何处理需要登录的接口。

  对于问题1)每个异步任务在获取结果后直接调用onPostExecute()方法了,测试代码获取不到结果,所以必须有一个专门的桩Activity负责异步任务的执行并将结果暴露出来;

  对于问题2)尽量将等待操作交给测试基类,上层测试代码只需要执行被测逻辑而不需要关心细节;

  对于问题3)采用模板模式,如果接口需要登录则先执行登录操作后再调用,整体解决方案如下:

  先介绍桩Activity,它负责异步任务的实际调用,同时承担分发器的作用,如果需要登录则先分发给需要登录的流程,不需要登录则直接调用不需要登录的流程。当然它还有重要作用是取到异步接口调用后的结果,这样Test Case获取到并比对结果,示意代码如下:

  可以看到isCompleted是标识异步任务是否执行完毕的,无论异步任务返回是onSuccess、onError还是onIOException都会进行置位;result则是异步调用的返回,可以看到这里无论接口调用是成功、失败还是io异常都会将这个结果暴露出来以使测试代码能够获取到。