开放源代码测试框架 JUnit 和它的一些扩展(如 HtmlUnit)为 Web 应用程序测试带来了许多好处,特别是在极限编程(extreme programming,XP)环境中,并且用 WebSphere Studio 可以将它们很好的集成。
引言
HtmlUnit 是 JUnit 的扩展测试框架之一。HtmlUnit 将返回文档模拟成 HTML,这样您便可以直接处理这些文档了。HtmlUnit 使用例如 table、form 等标识符将测试文档作为 HTML 来处理。它同样需要遵循 JUnit 测试框架结构的 Java? 测试程序。
与 HttpUnit 相比较而言,HtmlUnit 并不直接基于 HTTP 请求/响应操作,但是需要您编写基于 HTML 概念(如链接、窗体和表单等)的测试案例。HtmlUnit 的 Java API 可以提供 Java 对象,它可以将 HTML 文档以 DOM 树的形式进行遍历。与 XMLUnit 对比,HtmlUnit 专门针对 HTML 文件使用,且将 HTML 当作 XML 处理。然而,您不能使用 HtmlUnit 来检查两份 XML 之间的差别,或是检查由 XSLT 转换而生成的 XML。HtmlUnit 还适合黑箱测试类型。它能为您带来更多的选择,以选取 Java 测试 API,并为 Web 应用程序测试维护您的测试案例和测试方式。如果应用程序 Web 页面以 XHTML 方式创建,那么您仍然可以使用 HtmlUnit ,因为 XHTML 拥有良好的格式化文档结构。
范例应用程序
为了示范 HtmlUnit 的使用,我们可以使用 ibm.com 网站上的雇员目录应用程序。WebSphere? J2EE 应用程序和 IBM? Web 页面遵循 XHTML web 标准。IBM 以外的人员可以搜索 IBM 雇员的联系信息,只要他们知道员工的姓和国家位置。
测试 IBM 雇员目录
clearcase/" target="_blank" >cccccc>//application home homePage = (HtmlPage)webClient.getPage(url); assertNotNull(homePage); |
//application link click HtmlAnchor anchor = homePage.getAnchorByHref(ApplicationURLs.APP_SEARCH_PAGE); assertNotNull(anchor); try { employeesSearchPage = (HtmlPage) anchor.click(); assertNotNull(employeesSearchPage); } catch (IOException ioe) { ioe.printStackTrace(); } |
//set the parameters for search List formList = (List) employeesSearchPage.getAllForms(); HtmlForm searchForm = (HtmlForm) formList.get(1); final HtmlSelect select = ( HtmlSelect )searchForm.getSelectsByName( "search_country" ).get( 0 ); select.setSelectedAttribute("ca", true); //select.setSelectedAttribute("all", true); final HtmlHiddenInput hiddenInput1 = (HtmlHiddenInput) searchForm.getInputByName("country"); hiddenInput1.setValueAttribute("us"); final HtmlHiddenInput hiddenInput2 = (HtmlHiddenInput) searchForm.getInputByName("language"); hiddenInput2.setValueAttribute("en"); final HtmlTextInput inputLastName = (HtmlTextInput)searchForm.getInputByName("lastname"); inputLastName.setValueAttribute("Shafi"); final HtmlTextInput inputFirstName = (HtmlTextInput)searchForm.getInputByName("firstname"); inputFirstName.setValueAttribute("Marie"); imageInput = (HtmlImageInput)searchForm.getInputByName("Submit"); try { searchResultPage = (HtmlPage)imageInput.click(); assertNotNull(searchResultPage); Document resultsPage = searchResultPage.getDocument(); //page content verification based on XML //It depends on html documentation structure its self, CommonTests.testResultsWhitespaceName(resultsPage, "Employee Directory results page", "Shafi", "Marie"); } catch (Exception e) { } |
用 WebSphere Studio 进行测试
WebSphere Studio V5 以及以后的版本都与 JUnit 测试框架紧密集成。为了让你的测试案例能在 WebSphere Studio 上运行,您需要遵循基本的 JUnit 测试案例编程 API。对于每个案例来说,您都需要从 TestCase 扩展您的测试类。然后实现 setUp() 、 testXXXX() 和 tearDown() 方法。为了能让你的测试案例在大型的项目中可维护并可重复使用,请遵循面向对象设计和其他标准实践。
在您开始测试之前,需要有一个最小化的 HtmlUnit 二进制 JAR 文件。在指定的目录中提取 lib。您可以从 SourceForge 下载稳定的 HtmlUnit 1.2.3 版本。
创建独立的范例 Java 项目
选择 File =>New =>Other 。在新的窗口中,选择 Java =>Java project 。
图 1. 范例 Java 项目。
为使用 HtmlUnit 配置 Java 构建类路径
在 new Java project 对话框中,选择 Libraries 选项卡并从 lib 目录添加外部 JAR 文件。对于 HtmlUnit 包,添加 JUnit.jar ,这在 WebSphere Studio plugin 目录中可以找到。
图 2. 测试案例构建类路径配置