QCon北京「鸿蒙专场」火热来袭!即刻报名,与创新同行~ 了解详情
写点什么

使用 JRuby 测试 Java GUI

  • 2008-10-31
  • 本文字数:2032 字

    阅读完需:约 7 分钟

与单元测试相比,GUI 测试要耗时和困难的多,即使是在测试驱动的开发团队中,因此也常被忽视。让我们来看一看两个为 SWT 和 Swing 应用创建 GUI 测试的解决方案,它们均宣称能够使 GUI 测试工作更加简单。

为什么 GUI 测试难以编写?比起简单的实例化一个类,GUI 通常需要更多的创建工作,同时因为 GUI 交互是异步的而且涉及到鼠标操作,所以难以模拟 用户行为。GUI 测试的一个方法是提供一个交互录制器,监控测试人员,创建一个以后能够重用的脚本。这种方法存在若干问题:根据录制格式的不同,脚本在 UI 改变之后可能难以修改;很自然地,测试优先的开发模式不可行。

另外一种选择是编程创建 GUI 测试。这依赖于框架是否适合编写测试。找到一个能够识别 UI 元素和相关设施,并能等待异步操作结束的简单并有效办法至关重要。 SWTBot Marathon 都用于为 Java 应用编写 GUI 测试。SWTBot 使用 Java,所以存在使用 JRuby 的可能性。Marathon 则更进一步,直接使用 JRuby(或者 Jython)编写测试脚本。

SWTBot

SWTBot 是一个用于 SWT、基于 Eclipse 应用的测试工具,提供了简化访问 SWT 和 Eclipse 组件的 API。测试脚本可以通过 Ant 任务运行,因此你可以把测试集成到持续集成构建中。SWTBot 基于 Apache 2 许可协议。

InfoQ 采访了 SWTBot 的开发人员——Ketan Padegaonkar。Ketan 在 ThoughtWorks 工作,因此我们询问了有关 JRuby 和 DSL 的发展动向:

毫无疑问,这些都在 SWTBot 的日程表上。SWTBot 仍然缺少大量 API,我们正在原来的基础上不断进步。SWTBot 的大部分功能都是基于 Twist 开发团队的需求、反馈和 SWTBot 社区。目前还没有真正需要集成 JRuby 的理由。我相信这是因为没有太多人使用 JRuby 开发 SWT/Eclipse。所以,JRuby 集成目前还不在考虑中。

SWTBot 2.0(目前是 beta 版)组合了 FluentInterface 和微型的 DSL 来查询 widgets。我认为这是一种不断发展和提供足够句法支持而不使用完全 JRuby 方式的好办法。

SWTBot 也提供了一个录制器,目前它处在什么状态呢?

录制器只是为了体现概念而开发,所有没有投放太多的精力在上面。它对大多数控件都不支持,也不会录制所有操作,虽然添加这些支持很简单。录制器采用中间格式录制代码,类似于抽象语法树。这种表示随后会输出成你选择的语言,目前它支持 Java,但 Ruby 也是可以的。

还要注意:录制和回放不是编写测试的推荐方式(参见 TestingGUIApplications 录制 vs. 编码)。这主要是因为一个工作流(或者所有脚本)的完整脚本在被测应用发生微小改动之后需要重新录制。SWTBot 提倡采用 PageObject/ScreenObject 模式(或参见重用功能性测试)。

那么,未来有什么规划?

SWTBot 对于参与其中的每一个人来说在很多方面都是一个学习的历程。SWTBot 目前在进行第三次重写。我们在 2.0 版中改正了 1.x 版的很多错误。

我们移除了 Java 1.4 代码库以便使用 Java 1.5 的新功能,特别是泛型。我们也分解了 SWTBot 的一些子系统。这使得 SWTBot 更具扩展性,能够支持多页面编辑器、Eclipse 富表单编辑器和 GEF。

同时,申请把 SWTBot 移到 eclipse.org ,这可以方便更多用户访问 SWTBot,使所有人受益。

一些有关使用 SWTBot 测试的好技巧可以浏览 David Green 的博客文章“"Eclipse GUI Testing Is Viable With SWTBot ”。

Marathon

与 SWTBot 相反, Marathon 可以用于测试 Swing 应用。 Marathon 带有自己的编辑器和测试运行器,也支持调试和提供 Ant 任务。 Marathon 由 Bangalore 的 Jalian Systems 公司开发,基于 GNU LGPL 协议。我们采访了 Marathon 的主要维护者和开发人员 Dakshinamurthy Karra。

相比 SWT,已经有太多测试 Swing 应用的工具,所以我们询问是否计划支持 WST:

我们计划发布一个基于 Eclipse 的商业版本。由于各种原因推迟了。我们希望在未来几个月能够发布。作为一个团队,我们目前关注的是添加对 Web 测试的支持。根据需求的不同,我们随时准备添加对 SWT 的支持。但目前我们收到了更多支持 Web 应用的要求。

Marathon 支持 JRuby 和 Jython,为什么选择这两种语言?

Jython 是初期开发人员选择的语言。我们个人喜欢 Ruby,所以添加了对 JRuby 的支持。Marathon 架构支持插件式脚本模型。JVM 支持的任何语言(Groovy,Bean shell,Clojure)都可以被添加进去。

另一个偏爱 Ruby 的原因是可以创建 DSL。而且还计划(仍在萌芽阶段)添加基于关键字的测试

我们非常乐于看到社区能贡献出针对其他语言的支持。

看到 Marathon 的屏幕截图,感觉界面类似于 Eclipse,其中有什么联系吗?

我们正准备发布一个基于 Eclipse 的商业版本(暂定名 MarathonITE——Marathon 集成测试环境)。Eclipse 是我们的开发平台,这是 UI 类似 Eclipse 的一个原因。当我们需要实现一个功能的时候——我们通常会看看 eclipse 是如何实现的。

没有计划把 Marathon(开源版本)集成到某 IDE。

使用 JRuby(或者 Jython)测试是把动态语言偷偷用在传统开发环境的一个好机会。

你又是如何创建 UI 测试的呢?

查看英文原文: Java GUI Testing With JRuby

2008-10-31 23:071660
用户头像

发布了 501 篇内容, 共 264.7 次阅读, 收获喜欢 61 次。

关注

评论

发布
暂无评论
发现更多内容

国产数据库“同城两中心”容灾方案对比,TiDB表现优秀

TiDB 社区干货传送门

数据库架构选型 数据库架构设计

TiDB 组件 GC 原理及常见问题

TiDB 社区干货传送门

监控 性能调优 集群管理 故障排查/诊断 性能测评

西安有哪些值得去的互联网公司?最新版

王磊

4个为数据程序员量身打造的PyCharm插件

伤感汤姆布利柏

简历秀软技能:轻松吸引HR的注意!

测吧(北京)科技有限公司

测试

TiDB MVCC 版本堆积相关原理及排查手段

TiDB 社区干货传送门

性能调优 管理与运维 故障排查/诊断 性能测评

TiDB 在企查查数据中台的应用及 v7.1 版本升级体验

TiDB 社区干货传送门

7.x 实践

等保测评师工资怎么样?有前途吗?

行云管家

等保 等级保护 等保测评师

怎样利用 AI 大模型,辅助研发管理与效能提升?

思码逸研发效能

查看 DB 和 RG 级别的监控指标--新特性 record-db-label

TiDB 社区干货传送门

实践案例 管理与运维 新版本/特性解读 7.x 实践

春节期间消费行业收入大涨:企业如何抓住私域运营优化机会?

极客天地

一文搞懂TiDB的闪回(FlashBack)能力

TiDB 社区干货传送门

实践案例 7.x 实践

如何实现零基础转行做测试开发,入职3个月后涨薪30%

霍格沃兹测试开发学社

2024年漳州本地有正规等保测评机构吗?在哪里?

行云管家

等保 等保测评 等保测评机构 漳州

TDengine 签约福州城建,助力智慧水务数据管理革新!

TDengine

tdengine 时序数据库

除了代码行数、工时,我们还有什么更科学的方式度量研发工作量?

思码逸研发效能

数据抽取在tidb中的应用总结

TiDB 社区干货传送门

实践案例 大数据场景实践 OLTP 场景实践 OLAP 场景实践

测试人生 | 零基础转行做测试开发,入职3个月后涨薪30%

测吧(北京)科技有限公司

测试

一个好运维的自我修养:做好企业 IT 运维工作

伤感汤姆布利柏

直播回顾 | 哈啰一站式业产研协同平台的建设与实践

思码逸研发效能

让 K8s 更简单!8款你不得不知的 AI 工具-Part 2

SEAL安全

人工智能 开源 AI Kubernetes

使用JRuby测试Java GUI_Java_Mirko Stocker_InfoQ精选文章