设为首页 收藏本站
查看: 1321|回复: 0

[经验分享] (PHP)使用Behat和Mink对Web应用做BDD(行为测试驱动开发)

[复制链接]

尚未签到

发表于 2015-8-25 13:45:39 | 显示全部楼层 |阅读模式
  首先,按我自己的理解,简单说一下TDD 和 BDD 有何区别?
首先是思路上的区别, 传统的 TDD 关注的是接口是否被正确地实现了, 所以通常每个接口有一个对应的单元测试类。而BDD是通过故事模板和场景,描述产品在用户操作时的具体功能表现,有点类似传统的Use Case。写BDD的测试时更像测试人员平常写的测试用例。由于BDD一般是使用自然语言来表达,所以就算不是开发人员也看得懂。以下就是一个BDD的例子:
DSC0000.png

Behat是PHP下的一个BDD框架,可以配合PHPUnit来使用。
更详细的介绍可以去behat的官方网站查看,http://behat.org/

在对Web应用做自动化测试时,碰到界面测试时,无论是使用TDD和BDD都会遇到一些麻烦。
通常有两种解决方案:
1. 绕过GUI的测试。由于大部分的Web开发都会使用MVC框架,根据MVC的原理,Controller只需将正确的数据传递给View就算完成任务了。因此,我们在做测试时只需只需验证Controller是否把正确的数据传递给指定的View就可以了,至于View能否正确展现数据,那就要靠集成测试来验证了。
2. 使用一些GUI测试框架或浏览器模拟器。今天我要讲的使用浏览器模拟器。
浏览器模拟器大概可以分为两种:

  • Headless browser emulators - browser emulators, that can be executed fully without GUI through console. Such emulators can do HTTP request and emulate browser applications on high level (HTTP stack), but on lower level (JS, CSS) they are totally limited. But they are much faster than real browsers, cuz you don’t need to parse CSS or execute JS in order to open pages or click links with them.

    • 简单说这种模拟器比真浏览器要快速,但无法处理CSS或JS。

  • In-browser emulators - this emulators works with real browsers, taking full controll of them and using them as zombies for their testing needs. This way, you’ll have standart fully-configured real browser, which you will be able to controll. CSS styling, JS and AJAX execution - all supported out of the box.

    • 这种模拟器更接近真实浏览器,可以处理CSS和JS,但是速度相对来说会比第一种慢。

但其实在真正做测试时,一般两种模拟器都需要用到。因为你不能全部都使用In-browser模拟器做测试,因为当测试比较多时,那速度是无法忍受的。但是当你需要测试类似Ajax请求时,你又不能使用Headless模拟器,必须使用In-browser模拟器。

由于这两种模拟器是很不同的,各自拥有不同的API,同时使用两套API来做测试是很麻烦的。
这时MINK的优势就出来了,MINK是一个浏览器模拟器抽象层,用同一套API同时支持In-browser和Headless模拟器。

下面就介绍如何使用Behat和MINK对WEB应用做BDD。
1. 安装Behat
$ pear channel-discover pear.symfony.com
$ pear channel-discover pear.behat.org
$ pear install behat/behat
2. 安装MINK
$ pear channel-discover pear.behat.org
$ pear install behat/mink-beta
3. 新建一个sosobaike目录,进入sosozhidao目录,执行behat --init命令   
$ mkdir sosobaike
$ cd sosobaike
$ behat --init
这时behat会帮你创建一个features目录和features/bootstrap/FeatureContext.php文件
FeatureContext.php是真正存放单元测试的方法的地方

4. 创建features/search.feature文件

但如果我们没有使用MINK,直接运行behat命令时,behat会建议你在features/boostrap/FeatureContext.php加上一些测试方法,你需要自己在这些测试方法使用累似Selenium之类的脚本进行断言。
DSC0001.png
5. 但如果你使用MINK的话,事情就简单多了,只需修改features/bootstrap/FeatureContext.php文件,
加入两行代码。
     a) require_once 'mink/autoload.php';
     b) 将FeatureContext的父类由BehatContext修改为Behat\Mink\Behat\Context\MinkContext
6. 执行behat -dl命令,如果一切正常的会,你将会看到累似以下的结果
DSC0002.png
以上其实就是MINK支持的一些API。
7.  执行命令behat features/search.feature,你将会看到以下累似的结果
DSC0003.png
到此,就算完成了一个BDD测试,整个过程做起来很简单,并不比写一个测试用例所耗费的时间长,并且获得测试用例所没有的功能 -- 可以自动执行去验证功能。

因此,个人觉得做测试的同学可以尝试使用此方法代替测试用例,可以节省不少时间。

对于开发的同学,我个人认为对Web应用做BDD或TDD时,应该使用绕过GUI的测试的方案,也就是只测试Controller的方案。
原因有以下几点:
1. 开发人员和测试人员对测试的运行速度要求是不一样的,测试人员对测试的运行速度没有太高的要求,他们可以把测试起起来,然后去做其他事情,一会回来看结果就好了。但是开发人员就不一样了,他们每修改一处代码都需要运行一次完整的测试,以确保自己的修改没有破坏其他功能。如果运行一次完整的测试很耗时间的话,那么就会有开发人员想做单元测试了。使用MINK虽然比在真正的浏览器里访问要快,但是由于始终是访问真正的产品代码,也就因为着很多测试会访问数据库,一旦测试很多的话,所有测试跑完是很耗费时间的。

2. 由于使用MINK是会访问真正的产品代码,那就意味者需要配置相关环境(依赖库,数据库等),甚至需要恢复数据库到初始状态。只要有任何一个配置环节出错,都有可能引起原来通过的单元测试会无法通过。这是无法达到一个好的单元测试的标准的。好的单元测试必须任何时候运行都必须保证运行结果是一致的。要达到这个效果,那就不能依赖外部条件(例如:数据库、网络),对于这些外部条件应该使用代码去尽量模拟。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-104079-1-1.html 上篇帖子: PHP基础之Autoload 下篇帖子: w3school的PHP教程提炼(一)PHP基础
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表