[译]36 Days of Web Testing(三)

Day 14: Automate the tedious

Why ?

有些时候,web测试还是蛮单调乏味的,在开始测试前,你可能要必须跳转到一个特定的表单页面,或则为了得到一个特定的页面(或配置),你必须准备很多数据。

这种场景下,我发现通过selenium IDE进行UI测试的录制、回放,通过一些简单的SQL脚本来造数据,可以使测试准备工作特别有高效。

通过这些工具,可以很简单、快速的,来到你想测试的点(test point)

PS:这个感同身受啊,举个实际工作中的例子,比如我要测试退款业务(test point为退款),但在申请退款前,这笔订单必须已经支付、清算完成

How?

Selenium IDE是Firefox的一个插件,如何使用这个插件录制UI自动化脚本,可以查看官方的在线文档。

可以录制你在访问站点时所做的操作,页面跳转,后续如果需要,就可以回放这些步骤了。

举个例子,我需要测试多用户场景下的Cookies管理,这时候就需要以不同的用户不断的做“退出”和“登入”操作。

这种情况下,我写了个自动化脚本来实现,一个用户的“登出”和另一个用户的“登入”。

如果手动做的话,就需要重复的机械点鼠标。需要注意的是,我并没有用Selenium来测试,只是用selenium来做测试准备工作的自动化,和帮我点鼠标,Cookie管理的校验,我来test的。

建议

如果学会了如何在Selenium IDE里Debug自动化脚本,就可以更快的录制和回放脚本了。

有一点需要注意,如果你希望通过录制UI自动化脚本,并依靠这些来做回归测试,你要想清楚。大多数情况下,这是不靠谱的。

另外一点,你可以通过SQL脚本来做测试前的数据准备工作。

链接:


SQLYog Tool - http://www.webyog.com/en/downloads.php
SQL Learning at W3 Schools - http://www.w3schools.com/sql/default.asp
Selenium Debugging - http://seleniumhq.org/docs/02_selenium_ide.html#debugging
Selenium - http://seleniumhq.org/

Day 15: Soap Testing

Why ?

如果你的应用使用了Web services,那么它就可能正在使用SOAP协议

下面是维基百科对SOAP的定义:

简单对象访问协议SOAP,全写为Simple Object Access Protocol)是交换数据的一种协议规范,使用在计算机网络Web服务(web service)中,交换带结构信息。SOAP为了简化网页服务器(Web Server)从XML数据库中提取数据时,节省去格式化页面时间,以及不同应用程序之间按照HTTP通信协议,遵从XML格式执行资料互换,使其抽象于语言实现、平台和硬件

网上有很多关于SOPA封装,编码规则,但最基本的它如何传递消息的.

你可以只关注UI层面的测试,而忽略底层的SOAP交互, 但在UI下面,有更多值得你探究的东西.甚至, 测试时都可以不需要UI, 直接测试web services。

你可以直接和web servcice交互,测试所有的点。传递一个脏数据、损坏的数据(corrupt date),无效数据,传递很多数据,较少数据。你甚至可以写一个自动化脚本以你期望的方式整夜的绑定web services

How ?

测试SOAP服务最简单的方法就是使用一个SOAP UI工具,它的UI界面很整洁,有很多在线文档提供直观的帮助。

SOAP UI的具体指令可以查看它的官方文档,但最基本的包括,连接一个web service,查看这个web service提供的元素,接着你就可以想一些测试点了。

建议:

和Http services一样,SOAP UI也是RESTful的。

链接:

SOAP UI - http://www.soapui.org

Day 16: See the source 查看页面源代码

Why ?

页面源代码是发现bugs的好地方,可以对感兴趣的代码块进行深入探究,看有没有潜在的安全漏洞,或则信息泄露。

我所说的源码是指你所测试的页面的源代码。源码可以看出你的应用是如何和页面组合在一起的。

页面源码可能会包含注释、用户名和密码,通过蛛丝马迹可以看出所引用的方法,后台实现,从安全角度来看这些信息可能会有帮助。页面源码里还可能包含对公司、用户各种赞美、挖苦、讽刺的注释,设置有些注释里还会有一些笑话,或则提到一些部分实现的功能。

页面源码里还可能有安全URLs和证书等。

How ?

在浏览器里打开你的页面,点击工具栏的“查看”按钮,选择“查看页面源码”。

页面源码就会在浏览器窗口打开,简单浏览下,然后对你感兴趣的代码块进行深入阅读。

建议:

也可以在浏览器窗口,右击,选择“查看页面源码”。

链接:

Andréas Prins article on Hidden Treasures - http://www.thetestingplanet.com/2010/12/hidden-treasures-foreveryone/
Firefox Extension to visualise page source - https://addons.mozilla.org/en-US/firefox/addon/view-source-chart/

Day 17: Explore the competition  竞争对手研究

Why ?

看看规范手册、声明文档,研究下用户在使用你的系统前还用过那些系统,做下竞争对手研究,这些都可以帮着想出更多的测试点。

研究下竞争对手的产品和服务,这样的学习将有助于你的测试

在测试行业,有个话题一直讨论的很激烈:一个测试工程师对于所测试的站点,有没有必要提出改进性的意见或建议。

我的答案是,Yes ,绝对应该。

我认为,如果一个测试工程师依据自己的知识、见解可以提出使得产品变得更好的方案,如果他不提的话,这将会使他错失增长自己见解的机会。

测试并不是快乐的道路检查,贴着标记的盒子,不是预先确定好的路。在测试过程中,需要应用到你的判断、见解、经验和掌握的知识。

这些观点,见解,如果有助于提升产品,那么就应该提出来,相互沟通,交流。

如果有机会改进这个软件,使它更好用,在市场上更具竞争力,最终成为一个成功的产品,难道不就是增加了产品的价值吗

不要想着,已经有其他人在研究竞争对手了,也不要觉得之前的人已经考虑到了用户习惯。

通过比较产品得到的信息,将有助你想出新的测试点,想出改善产品功能的办法,想出使你的产品脱颖而出的办法。这是一个很好的,能够帮助你提升的测试技能。

如果单纯是模仿竞争对手,这并不是一个很好的商业策略。

你可以通过从他们产品信息中收集使用案例开始,并以新的思路来考虑自己的产品。

同时,这也能加深你对所从事领域的理解。

How ?

在网上可以很快地搜索到竞争对手的网站,你可以读读他们的marketing材料,注册下载试用版,对他们的产品和领域有更深入了解。

建议:

可能你会发现你的产品或站点在“二选一”站点的列表中,比如http://alternativeto.net/。这些站点会列出可供对比选择的产品,这是一个很好的途径来看你的竞争对手在做些什么?人们是怎么评价他们的产品的。 PS,在这网站还没有alipay的信息。输入paypal,可以看到国外第三方支付的公司列表。

链接:

www.alternativeto.net

Day 18 : 规范和声明

Why ?

在产品的发布流程中,通常会将产品的附属文档整合起来,这些文档会解释这产品有哪些功能?好在何处?

这些文档会包含关于产品功能、性能的声明,以及产品遵守了哪些行业规范的说明。

作为一名测试工程师,今早去发现这些文档声明了些什么,并将这些声明和规范说明罗列到你的用户故事,或测分文档里。虽然这些声明,规范的说明并不是产品团队起草的,但还是需要关注。

一旦你了解了这些声明,那么你就可以开始针对这些声明进行测试了。

举个例子来讲啊:

  • 产品遵守了X标准  <- 真的是这样吗
  • 我们的产品是市面上最快的? <-  真的吗? 如何证明? 数据是从哪来的?
  • 我的产品绝对安全 < – Really?

How ?

对着每一条声明和规范,记录下你头脑中闪现的问题。就这些问题,和产品/市场/管理团队进行沟通,也可以研究下相关的法律法规。

可能你所有的问题、疑虑都没有被采纳,这种情况下,你可以依据这些声明和规范来测试你的产品,找到证据来证明你的产品不符合这些声明。

将你的发现交给关心这些的人(法务会比较关心),但首先你要判断下,你在这些上面花费时间是不是最值得

建议:

如果你在测试这些标准,或法律声明时遇到了疑惑,你也可以一些论坛上提问,或则在一些社交媒体上求助,比如Twitter(Ps:国内可以试试“知乎”)

毋庸置疑,在这个领域有很多资深人士,他们的一些见解可能会帮助到你。

链接:

http://curioustester.blogspot.co.uk/2009/12/claims-testing.html
http://www.bettertesting.co.uk/content/?p=613

posted on 2013-07-21 01:29  matt_chen  阅读(451)  评论(0编辑  收藏  举报

导航