在淘宝干了这么长时间的高性能web服务器测试及其相关Web服务测试之后,心里总会想,Web服务测试与传统软件测试有什么不同吗?Web测试的难点在哪里呢?对于这些难点有啥解决技术不?在查阅相关资料之后,做个总结吧。

  介绍:

  Web服务与传统软件的不同点:

  1、Web服务的应用环境与其开发环境存在较大的不同:

  Web服务的应用环境存在极大的不确定性,如访问的用户类型、并发用户数量、Web服务调用的装载模式和访问方式等;

  对传统软件相对来说,其应用环境更可控一些;

  2、自动化测试方法应用程度:

  Web服务测试主要基于服务接口进行设计和实现,因此可以更多的采用自动化测试方法;

  而传统软件则更加依赖于大量人工干预;

  3、对性能和可扩展性的要求程度:

  Web服务测试需要面对大量用户通过不同环境进行访问的场景,因此对性能和可扩展性的要求非常高;

  而传统软件,特别是单机版的软件如:Office、Adobe Reader等,对性能的要求没有那么高了;

  4、不确定及不可见因素的差别:

  对于Web服务的发布、展现和绑定都是动态完成的,具有很高的不确定性和不可见性;

  而传统软件可以将这些逻辑固定化,降低不少风险;

  5、安全隐患:

  对于Web服务来说,每发布一个访问的接口或方法都会提高一份被攻击的机会。特别是对于那些所调用的分散和异构的外部Web服务的安全隐患更大;

  而传统软件由于不具备太多的分布访问的特点,可以降低相应的安全隐患;

  Web服务测试的主要难点:

  由于上文提到的Web服务与传统软件的不同点及现在普遍采用的一些不同于传统软件的Web服务开发方式所印出来的各种测试难题。

  如:

  对于相对独立的各个环节,如何规范和管理测试过程(如缺陷跟踪过程)?

  在多方并行参与的结构下,如何组织测试并统一和度量测试结果?

  在分布式的环境中,如何测试远程的服务?

  在用户环境不确定的情况下,如何定义并检验服务的质量?

  在服务软件演化的过程中,如何进行回归测试?等等。

  可将这些问题归结为以下几个方面:

  1、Web服务的基本功能测试;

  2、Web服务协议的测试;

  3、面向服务体系结构的发布、查找和绑定的能力测试;

  4、Web服务的集成能力测试;

  5、Web服务的服务质量测试;

  6、Web服务的性能与负载测试;

  7、Web服务的安全性测试;

  解决上述测试难点的一些技术介绍:

  想要解决以上的测试问题,需要有相关的技术支持,如:

  1、能够建立Web服务测试过程模型,以便在分布式的环境下,有效地、系统地组织各个相对独立的测试环节;

  2、能够有效验证各种协议及各层之间通信信息的正确性、完整性和一致性;

  3、测试自动化技术,包括基于规格说明的测试用例自动生成技术、测试脚本技术、远程测试执行、分布式环境下测试的调度和规划、测试结果的分析和度量;

  4、Web服务用户使用模式的捕捉、分析和预测,这是测试模拟的基础。尤其是对于性能测试,需要模拟典型的用户行为,以及高峰期的用户数、数据量和并发链接数;

  5、CASE工具的研发,以支持Web服务测试的管理、自动化、调度和监控;

  结论:

  Web服务测试之路任重而道远,与大家共勉,一起努力。

  OK,Web服务测试与传统软件测试的对比分析及技术介绍介绍完毕,欢迎拍砖。