使用 GWT 更轻松地测试异步应用程序
简介: 您可能从编写 Ajax 应用程序中获得了极大乐趣,但是对它们执行单 元测试却着实让人头痛。 在本文中,Andrew Glover 着手解决 Ajax 的弱点( 其中之一),即应对异步 Web 应用程序执行单元测试的固有挑战。幸运的是, 他发现在 Google Web Toolkit 的帮助下,解决这个特殊的代码质量问题要比预 想的容易。
Ajax 在近期无疑是 Web 开发界最时髦的字眼之一 —— 与 Ajax 相关的工具、框架、书籍以及 Web 站点的剧增就是该技术流行的最好证明。此 外,Ajax 应用程序也相当灵巧,不是吗?不过,像任何一个开发过 Ajax 应用 程序的人证实的一样,对 Ajax 执行测试真的很不方便。事实上,Ajax 的出现 已经从根本上使得许多测试框架和工具失效,因为它们并没有针对异步 Web 应 用程序测试进行设计!
有趣的是,某个支持 Ajax 的框架的开发人员注 意到了这个限制,并为此做了一些非常新颖的设计:内置的可测试性。除此之外 ,由于该框架简化了使用 Java 代码(而不是 JavaScript)创建 Ajax 应用程序,它的起点甚高,并且充分利用了 Java 平台上无可置疑的标准测试框 架:JUnit。
我所论及的框架当然是非常流行的 Google Web Toolkit, 也就是 GWT。在本文中,我将向您展示 GWT 如何实际地利用 Java 兼容性,使 Ajax 应用程序的每个部分都能像与之对应的同步应用程序一样进行测试。
JUnit 和 GWTTestCase
因为与 GWT 有关的 Ajax 应用程序采用 Java 代码编写,所以非常适合开发人员使用 JUnit 进行测试。事实上,GWT 开 发小组还为此创建了一个帮助器类 GWTTestCase,扩展自 JUnit 的 3.8.1 TestCase。该基类添加了一些功能,可测试 GWT 代码并处理某些基础实现从而 启动并运行 GWT 组件。
需要提醒的是:GWTTestCase 并非用来测试与 UI 相关的代码 —— 它是为了便于测试那些由 UI 交互触发 的异步 问题。对 GWTTestCase 用途的误解使许多刚接触 GWT 的开发人员备受挫折,因 为他们期望能够用它方便地模拟用户界面,但最终发现这是徒劳的。
Ajax 组件有两个基本组成:体验和功能,这些都被设计成异步方式。图 1 演示了一个模拟 Web 表单的简单 Ajax 组件。由于该组件支持 Ajax,表单的 提交是异步执行的(即:无需重新载入与传统表单提交关联的页面)。
图 1. 一个支持 Ajax 的简单 Web 表单