GUI测试工具Huxley、Swing Inspector、Dagger、iQuery介绍

以下为你介绍的GUI测试工具都可用在Linux系统上:Huxley(Web UI 测试工具)、Swing Inspector(Swing界面分析和调试工具)、Dagger(WebUI自动化测试框架)、iQuery(UI 自动化测试)。

1、Huxley(Web UI 测试工具)

Huxley 是一款来自 Facebook 出品的 Web 应用的 UI 测试工具,由  Pete Hunt 和 Maykel Loomans 用 Python 开发。

Huxley 可以监控你浏览的内容,进行屏幕截图,然后告诉你发生了什么变化。

安装方法:

pip install huxley

为什么要用它代替单元测试?

首先,如果您对UI进行了充分的组成,则可以将Huxley用作单元测试工具。话虽如此,单元测试有两个缺点:

1]、他们通常需要很长时间才能写,网络上的Instagram拥有一名工程师和一名设计师来并行处理大量事情,我们没有时间编写依赖注入和综合断言的精美隔离的测试,我们只需要确保在疯狂交付代码时不会引起错误即可,许多小型Web团队可能会认同这一点。

2]、他们不测试用户界面的外观,Huxley对UI进行逐像素比较,传统的UI测试系统会检查DOM,但不会查看其实际呈现方式,我们曾经有一个bug,其中CSS规则将所有图像组件的高度设置为0px,如果没有逐像素的比较,我们不太可能为此编写明确的测试。

下载地址:https://github.com/facebookarchive/huxley

2、Swing Inspector(Swing界面分析和调试工具)

GUI测试工具Huxley、Swing Inspector、Dagger、iQuery介绍

Swing Inspector是一个Java Swing/AWT用户界面分析和调试工具,功能与firebug类似,具有强大的Swing/AWT用户界面分析和调试相关功能。 适用于从java swing初级到高级的所有开发人员,能够快速定位问题,UI快速调试,分析其他软件界面的实现原理,能够给开发工作效率带来大幅提升。

特点:

具备UI组件联动功能,在用户界面中Ctrl+移动鼠标,可以在Swing Inspector主界面中显示对应组件信息,并高亮当前Component。

可以在Swing Inspector组件树中联动到用户界面,即双向联动,且不需要提供界面的源代码。

Applet支持,可以定位嵌入到任何网页中的applet界面。

强大的window捕获功能,可以捕获加载agent的jvm创建的所有Swing/AWT窗口(网页中的applet,浏览器加载appet/webstart后启动的console窗口),模式对话框等。

绿色,无需安装,只需给java命令添加一行参数,即可启动Swing Inspector。

支持所有的AWT/Swing程序,netbeans、visualvm等。

强大的表达式支持,允许对选定组进执行表达式运算,实时显示计算结果,运算结果支持属性浏览和编辑。

强大的Javascript支持功能,支持用javascript实时修改用户界面中的组件,执行脚本后立即生效。

高性能,核心功能采用c/c++实现,直接操纵jvm,对性能影响很小,主界面采用lazy机制,刷新组件时只更新可见viewer。属性编辑器可直接修改选定的组件属性,且直接生效。

可以记录组件添加到parent时的stacktrace,可以快速定位到相应的代码行。

简单易用,快捷键与常用软件一致(F5刷新、Alt+Left后退,Alt+Right前进等),界面非常简洁、直观,没有学习成本。

免费,为软件行业发展尽一份力量是我们的宗旨。

下载地址:http://www.swinginspector.com/

3、Dagger(WebUI自动化测试框架)

Dagger是网易杭州研究院QA团队开发的一个轻量级、运行稳定的WebUI自动化测试框架,主要基于Selenium及TestNg可以认为是对Selenium进行二次封装的一个框架(俗称造轮子)。之所以把这个轮子开源出来,主要在于经过了公司内部多个项目的实践,也取得了不错的成效,因此,希望开源以后可以对大家有所帮助及参考。

设计理念:

Dagger首先是一个WebUI自动化框架,提供了赖以操纵浏览器的一些API。API数量不多,少于20个,但从实践上,已经基本涵盖95%的应用场景了(其余5%比较个性的自动化操作一般是封装在业务逻辑层面,有时候甚至会须要hack)。

Dagger其次是一个测试框架,使用TestNg管理和运行用例,TestNg相关断言内嵌于上述API中。因此,在我们的测试用例里面不应该看到单独的TestNg断言的。

Dagger还是一种设计风格:简约。无论是Dagger框架本身还是基于Dagger编写的测试用例,都是十分light及straightforward的,以至于会让人感觉有点土。但实践中,这两者确保了低成本、易用性、可维护性。

WebUI自动化从业界看,难推进,易烂尾,原因基本在于:维护成本高、运行速度慢、稳定性差。

Dagger专注于WebUI自动化,从技术上克服了速度与稳定问题。只封装够用的浏览器操作为API,并充分简化/强化这些API,以简约的风格去降低自动化的学习及使用成本。同时,在实践中,我们主要使用Dagger编写冒烟用例、其次是主干用例,少写逻辑复杂功能,不写边边角角功能,让用例也保持清爽(在整个自动化实施过程中,会定期进行用例Review),同样易于后期维护。

主要特性:

API极少,易于上手。

提供比较完备的文档,便于快速入门。

支持单机多浏览器并发执行,大大缩短用例执行时间。

通过修改TestNg源码实现失败用例自动重运行,由此几乎消除WebUI自动化中常见的虚假失败。

默认使用Chrome浏览器。

失败用例自动截屏。

后续工作:

加入Flex/Flash自动化支持。

如何使用:

Dagger十分适合中小型团队从零开始WebUI自动化,这样的话,只须要直接下载整个Dagger代码就行了,Dagger本身都已经配置好了,下载后看一下使用文档就可以直接开始写用例了。

也可以把Dagger打成Jar包,导入已有的自动化框架中。

下载地址:https://github.com/NetEase/Dagger

4、iQuery(UI 自动化测试)

GUI测试工具Huxley、Swing Inspector、Dagger、iQuery介绍

在程序界面(UI)自动化测试中,最烦人的就是抓取控件的过程了,要么是程序员忘记在代码里给控件添加自动化测试用的标签;要么就是界面布局经常变,如果是基于坐标位置抓取的话,一点小变化都很麻烦。碰到这种问题很讨厌,界面变更导致的测试失败由于跟产品问题无关,因此开发一方经常会拒绝修改代码,问题全部丢给测试工程师一方。而在手机应用上,这种问题就更突出了,一个市场占有率较广的应用通常都支持好几个平台,而各个平台的编程方式还不一样。

iQuery的思路借鉴自jQuery(或者说是CSS)的选择器,一方面提供一个比较简单的方式在自动化测试程序里抓取控件,一方面试图通过将控件归类提供一种跨平台统一的控件抓取表述语法。它是一个多平台通用的控件查询语法,当前已经实现了iOS版,支持在Instrument里使用。我们尽量将iQuery的语法与jQuery的语法保持一致,然而由于二者的目标不一致(jQuery致力于尽可能多的抓取控件,而iQuery则致力于以最快的速度抓取目标控件),所以iQuery和jQuery的语法有一些细微的差别。

下载地址:https://github.com/vowei/iQuery

注明

以上就是GUI测试工具Huxley、Swing Inspector、Dagger、iQuery的介绍内容,这些GUI测试工具都能使用在Linux操作系统中。

栏目相关文章