在这篇新文章中,ThoughtWorks 首席顾问 Ian Robinson 讨论了以“服务故事”及在服务开发线之间的交换的单元测试为形式的“消费者驱动的契约(consumer-driven contracts)”何以能够增强面向服务开发的生命周期。跟从提供者角度定义的契约不同,消费者驱动的契约是通过组合所有已知服务消费者的要求得到 的。
Ian 介绍了消费者驱动的契约及其与提供者契约、消费者契约的关系:
- 提供者契约(Provider contracts)——提供者契约是我们最为熟悉 的一种的服务契约,参考 WSDL +XML Schema+WS-Policy。顾名思义,提供者契约是以提供者为中心的。提供者规定了它要提供什么;然后,各消费者便将自己绑定到这个一成不变的契 约上。不论消费者实际需要多少功能,消费者接受了提供者契约,就将自己与该提供者的全体功能耦合起来了。
- 消费者契约(Consumer contracts)——另一方面,消费者契约是对一个消费者的需求更为精确的描述。消费者契约描述了提供者功能里消费者在一个具体交互的场合下所需的特定部分。消费者契约可被用来标注一个现有的提供者契约,另外消费者契约也有助于发现一个现今尚未规定的提供者契约。
- 消费者驱动的契约(Consumer-driven contracts)—— 消费者驱动的契约描述的是服务提供者向其所有当前消费者承诺遵守的约束。各消费者通过创建消费者驱动的契约,把自己的具体期望告知提供者。在提供者方面创 建的约束,确定了一个消费者驱动的契约。若提供者接受了一个消费者驱动的契约,那么它只需保证已有约束仍能得到满足,即可自行改进与修改其服务。
接着,作者探讨了如何能够在面向服务开发的生命周期(启动阶段,构建阶段,运营阶段)里使用消费者驱动的契约。
Ian 总结道:
消费者驱动的契约支持面向服务系统的开发与测试,而且支持负责服务生命周期的各方之间的协作。
更多信息,请阅读全文:用消费者驱动的契约进行面向服务开发 。
评论