端到端测试:隔离式服务器
上一篇 / 下一篇 2012-10-30 11:02:45 / 个人分类:杂谈
&|^q B] x0 Web 应用的测试经常需要进行从用户角度的系统性的功能测试,涉及到从用户请求到服务器响应的整个过程,也叫做端到端测试。在最近的GoogleTestBlog 上,我看到一篇文章,觉得是进行这种测试一个不错的思路,翻译如下,供大家参考。
#Q.A i W\d5K051Testing软件测试网8_&u/J,O!VDRjPm/T/d隔离式服务器51Testing软件测试网^"o(vL!Z6B Cv8d%n Th
51Testing软件测试网j2W^"l:v$Y1s6}让我们考虑一个复杂的 Web 应用程序。 实现它的可能是成堆的服务器,而且每台服务器都运行着不同的任务并相互通讯。 每个用户操作都会访问这个服务器集群,并经历一次从用户到数据存储再到用户的往返。 包括 GMail 和 Google+ 在内的很多 Google 的 Web 应用都是这样工作的。 那么我们如何为它们编写端到端的测试 (end-to-end test) 呢?51Testing软件测试网.Lk$}8KyX-Sqv ^
:E;R:flM7n0 “端到端”的测试51Testing软件测试网~2[h@*`.X`W
8t*a2\kV2j]2B\0 在 Google 测试世界里,端到端测试是指作用于从用户请求到响应的整个流程和全部服务器集群的测试。下面是一个简化的由端到端测试所涵盖的被测系统 (SUT) 的示意图。注意图中被测系统的的前端服务器连接到了一个第三方后台服务器,但是这个第三方服务器并不被图中特定的用户请求所使用。51Testing软件测试网8n&w~*I]7U*I*s9\O/s.IA
51Testing软件测试网p!P4ZE fv,f h S)r^H
为这样的系统编写一个快速而可靠的端到端测试所面临的一个挑战是要避免网络访问。涉及到网络访问的测试要比那些只访问本地资源的测试执行得慢,而且访问外部服务器可能由于外部服务器不可用或不稳定而带来怪异的结果。51Testing软件测试网 JKc1dqb#_4r8C
隔离式服务器
)A&P Pm be&KW0我们在 Google 设计端到端测试的一个技巧就是使用隔离式服务器(Hemetic Servers)。51Testing软件测试网;?+`R8d'RJ7\H
什么是隔离式服务器? 简短的定义就是“单机服务器”。 如果你能在一台单独的没有网络连接的机器上启动整个服务,并使其正常工作,它就是一台隔离式服务器! “隔离”的概念从更广义上来讲适用于所有隔离的系统而不一定是单台机器,但这里提到的是一个特例。
Q*Jq4}R_Vf;kt0为什么隔离式服务器很有用呢? 因为如果整个被测系统由隔离式服务器构成,它就能在一台单独的机器上启动来用于测试;根本不需要网络连接! 这台单机可以是物理机,也可以是虚拟机。51Testing软件测试网%J DYFP,Q~/p5z6h1E
设计隔离式服务器51Testing软件测试网R|$D;u5[)c(h
构建隔离式服务器的过程需要从新服务器设计阶段的前期就要开始。需要注意下面一些事情:51Testing软件测试网Tzv-c2[ n n
● 服务器中所有与其他服务器的连接都需要在运行时注入。这可以通过一种适合的依赖注入形式完成,例如命令行标志或者 Guice 。
vk$Pve+CK0● 所有必需的静态文件都要打入服务器的二进制包。
Q:iF~Z^WG0● 如果服务器需要访问数据库,则需要保证数据库能被数据文件或者内存数据库模拟。
:T|#pL${$K08G9`6f w)Mg-p0 满足上述要求保证了我们的服务器具有高度的可配置性,从而有条件成为隔离式服务器。但它目前还不能被用于测试,我们还需要完成下面一些事情:
e3^.L/l8uF6~ k"`)_F0