因为在容器以外测试 JSF 组件有所限制,所以大家一直认为对于 JSF 应用进行单元测试是困难的。多数 web 层的测试框架遵循黑盒测试方式,开发者用 web 组件编写测试类来验证渲染的 HTML 输出是否符合预期。 HtmlUnit , HttpUnit ,Canoo WebTest 和 Selenium 等框架都属于这个类型。这些框架的局限在于它们仅仅只能测试 web 应用的客户端。
但是这种现象已经随着近来发布的 JSFUnit 和其它一些 JSF 测试框架,如 Shale Test 和 JSF Extensions 而改变了。这些测试框架支持对 web 应用的客户端和服务器端组件的白盒测试。并且,一些项目,如 Eclipse Web Tools Platform (WTP) 和 JXInsight 已开始协助 JSF 应用的开发和测试了。
与其它的单元测试框架一样,一个典型的 JSF 测试框架需要具备以下特性:
- 可测试完整的 HTTP 请求-响应生命周期。
测试框架还需支持 JSF 的特定需求,如:
- 在测试方法中调用 JSF API,而不是检查 HTML 输出或客户端 DOM 对象。
- 通过验证用户在表单上的输入和访问正确的页面视图来导航测试。
- 验证 action 是否按预期执行,以及错误情况是否显示预期的错误消息。
- 即使 rendered 属性被设置为假(组件不在 web 浏览器上渲染但仍在服务器端保存状态)时依然可以验证 JSF 组件。
- 验证 XML 配置文件 (faces-config.xml 等) 是否被正确加载。
测试框架
JSFUnit 构建在 HttpUnit 和 Apache Cactus 之上,允许 JSF 应用和 JSF AJAX 组件的综合测试和调试。它可以在同一个测试类里测试 JSF 产品的客户端和服务器端。有了 JSFUnit API,测试类方法可以提交表单数据,并且验证管理的 bean 是否被正确更新。
JSFUnit 包括一个 JSF 静态分析测试套件用来验证 JSF 配置文件,以确保在运行时产生问题之前就能识别出任何与配置相关的问题。它还提供了 JSFTimer 组件来执行 JSF 生命周期的性能分析。它可被应用于跟踪 JSF 生命周期的每个阶段对于一个指定的 web 请求的响应时间,并断言该响应时间在 SLA 限定之内。
JSFUnit 支持 RichFaces 和 Ajax4jsf 组件。此框架的 Beta 1 版本在上月发布,第二 Beta 版本计划在下个月末发布。
Shale 测试框架作为一个 Apache 项目,提供了对 Servlet 和 JSF 组件的 mock 对象实现。这些基础的测试类可应用于测试 Shale 框架类以及构建于该框架之上的 JSF 应用组件。Shale 测试可用于编写独立的单元测试来运行 ViewController 接口暴露的方法。因为为一个 ViewController 组件搭建运行环境很复杂,所以 Shale 测试是很有用的。以下是 Shale 测试框架的主要类:
- AbstractJsfTestCase :这是对 web 应用的 Servlet 和 JSF 组件进行单元测试的基础测试类
- AbstractViewControllerTestCase : 这个类作为 AbstractJsfTestCase 的扩展,提供了对使用 Viewcontroller 实现类的常用场景进行测试所需的有效方法。
- 还有其它 JSF web 组件的 mock 实现,叫做为 MockApplication , MockExternalContext 和 MockFacesContext 。
Shale 测试还与 Spring 框架进行了集成,允许 JSF 组件被绑定为管理 bean 或 Spring bean。
JSF Extensions 项目是一个无 UI 组件的集合,它扩展了基于 JSF 1.2 的 web 应用的功能。它使用 JUnit ,HTMLUnit 和 Cactus 进行自动测试。框架的 Test-Time 模块为 JSF 1.2 提供 mock 对象。Design-Time 模块具有 JSF 热部署功能,能停止和重启应用而无需经历构建和重部署周期。这个基于 JSF PhaseListener 接口的特性会使得所有的配置文件和类被重载。这些使得开发者能在编写 JSF 应用时遵循一种测试驱动迭代 JSF 开发方式。
工具
还有一些开发工具也辅助 JSF 应用的开发和性能检测。 JInspired 组的 JXInsight 提供了 JSF 跟踪和性能检测特性,该特性基于 PhaseListener 接口。在 JSF 应用中使用这个跟踪监听器,开发者和 web 管理员可以对于一个 JSF 请求收集到例如跟踪栈、java 调用栈和运行时 UIComponent 的层次关系等信息。
Eclipse WTP 项目里的 JSF 工具的子项目还提供了支持开发和部署基于 JSF 的 web 应用的工具,如 Visual JSF Page Editor 和 Faces Config Editor。
查看英文原文: JSF Testing Tools
评论