Android UI自动化测试最佳实践

发表于:2012-12-07 10:29

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:未知    来源:51Testing软件测试网采编

分享:

  对于Test case的形式如下,实际内容为对不同ActivityPage的操作,这样当页面的控件变化时只需要改动ActivityPage而不用动测试逻辑了,而且可读性更强。

  三、Robotium框架改写与封装

  通过以上示例可以看到为了更好地支持这种测试模式需要对robotium进行一些封装和改动,现阶段Robotium存在以下问题:

  1)Api不是面向对象的,用起来比较变扭,比如当你获得了一个EditText的对象,不能editText.putText(“abc”)而必须solo. enterText(editText,”abc”)

  2)不能很好地支持PageFactory模式,使用时需要写额外的代码

  3)由于UI测试存在偶尔的不稳定因素,需要有失败重试和截图机制

  为了改良以上问题,需要对Robotium进行扩展和封装,一个初略的类结构图如下:

  element包主要是各种Android控件,这样在查找到控件后明确规定了它可以的操作;

  support包主要是各种支持类,PageFactory可以将ActivityPage中的控件通过@FindBy注入进来,Failover支持失败重试和截图;

  根目录下的类主要是公用基类和核心类,Zinc继承自Robotium的Solo类。

  具体的代码见:http://code.google.com/p/zinc30/(暂时还未上传代码)

  另外,对于ActivityPage的代码很大一部分可以通过解析Android源工程layout中的xml自动生成,所以后续会增加相应的工具类。

22/2<12
2023测试行业从业人员调查问卷已开启,千元大奖正在等你~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2023
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号