模仿 Web Services

阅读数:304 2008 年 5 月 20 日

话题:SOA测试最佳实践架构

InfoQ 以前的一篇新闻已经涵盖了 Web service 的一些测试方法。最近,这些方法通过 Web Service 模仿(Web Services mocking)的使用得到了扩展。

对象模仿是一种非常流行和通用的单元测试方式。根据Wikipedia所说

模仿对象行为是指仿真对象以一种受控的方式效仿真实对象的行为……模仿对象可以模拟复杂、真实对象的行为,因此当真实对象难以甚至不可能包含到单元测试中时,模仿就非常有用。如果一个对象有任何如下特征,那么在它的位置使用模仿对象可能会很有用:
  • 非确定性结果(例如,当前的时间或者当前的温度);
  • 具有难以创建或者重现的状态(例如,一个网络故障);
  • 很慢(例如,一个完整的数据库,测试之前必须初始化它);
  • 尚不存在或者行为可能会被改变;
  • 包含一些测试专用的信息和方法(这些信息和方法对它的真正任务没有用)

Web Service 引入了一些额外的场景,非常适于使用模仿方式:

  • 必须书写依赖某个或者某些远程 Web service 的程序,但是这些服务正运行在生产服务器上,在测试服务器上还没有准备好;亦或第三方服务运行在客户防火墙之后,无法测试;
  • 离线开发(例如在家里或者在路上)可能会需要一组完整的、能够工作的离线 Web Service 才可能测试一个实现;
  • 在远程 Web Service 可能无法访问或者无法始终保持运行的情况下进行离线演示。确保演示在以上各种情况下都能顺利进行是很有必要的。

Upul Godage 写的一个新的教程描述了如何使用 Apache Synapse 来为开发和测试模仿 web services。Apache Synapse 是一个简单、轻量级、高性能的企业服务总线(ESB)。Apache Synapse 可以用来过滤、转换、路由、操作和检测那些可以通过 HTTP、HTTPS、Java™ 消息服务(JMS)、简单邮件传输协议(SMTP)、第 3 版邮局协议(POP3)、FTP、文件系统以及很多其它传输媒介传输的 SOAP、二进制、XML 以及普通文本格式的消息。

教程描述了如何使用 Synapse 来定义那些固定或受控的服务响应,步骤涉及使用简单的 XML 配置文件,定义转换,为一个(组)给定请求构建响应。它还描述了使用相同的基于配置的方式模仿仲裁(mediator)的方法。

另一个模仿 Web Services 的途径是使用 Crosscheck Networks 最新发布的SOAPSimulator。它的功能与 Synapse 提供的相似,但还包含如下的额外功能:

  • SOAP 和 XML 模拟过程的图形化。
  • 详尽的 WSDL 和 XSD 模式支持。
  • 从模拟实例动态地检索 WSDL 和模式。
  • 实时仿真事务监测。
  • 根据企业最佳实践进行度量的 WSDL 和 XSD 报告卡片。
  • 可定制的运行时消息掌控分析规则。
  • 多并发服务模拟。
  • 包含运行时变量状态机的复杂业务逻辑模拟。
  • 支持 WS-Security 和 WS-Identity 可扩展性。
  • 支持数据库和 API 插件可扩展性。

Crosscheck Networks 还提供了一个关于产品使用的详细教程

正如其白皮书——《使用服务仿真加速你的 SOA 项目》——中定义的那样:

在满足所提出的业务目标的过程中,构建和部署服务的紧密时间压力给 SOA 项目留下了很小的犯错空间。在 IT 预算面临持续压力,紧张的最后期限,以及在商业伙伴的内部及之间集成系统的驱动下,SOA 项目需要在它们的环境中引入服务模拟。服务模拟解耦了消费者和生产者之间的依赖,使它们能够相互独立地实现。Web Service 模仿解决方案为开发者提供了一个“盒装参考系统”,并消除了那些为了构建一个完整规模的生产系统的副本所需的开销,这能使开发者受益。
查看英文原文Mocking Web Services