标签:
原文地址:https://phphub.org/topics/25
Codeception 简单来说, 分为以下几种测试
接下来我们来一一介绍每一种测试的优缺点.
我们先设想这样一个场景:当技术人员开发完毕, 其客户, 产品经理, 或者是测试人员, 他们怎么确定产品的可用性? 一般情况下, 他们都是执行以下几个步骤进行测试:
这种测试方式我们称之为 手动测试
, 或 人工测试
, 与其相反的是 自动化测试
, Codeception 的 Acceptance Tests
会利用浏览器的编程接口, 做到以上的 人工测试
涉及到的步骤完全自动化, 大大节省了人工成本.
先贴代码
<?php $I = new AcceptanceTester($scenario); $I->amOnPage(‘/‘); $I->click(‘Sign Up‘); $I->submitForm(‘#signup‘, array(‘username‘ => ‘MilesDavis‘, ‘email‘ => ‘miles@davis.com‘)); $I->see(‘Thank you for Signing Up!‘);
Javascript
甚至是 ajax 请求;javascript
的运行, 有时候会有意想不到的情况发生.功能测试模拟一个 web 请求 (模拟 $_GET 和 $_POST 等变量), 发送给 App, 应用返回 HTML 结果, 在测试的过程中, 可以分析并进行 assert
判定返回的数据, 甚至可以检查数据是否正常的存储到数据库.
函数测试需要有一个测试环境, 几个有名的框架, 像 Laravel
就有现成的 Package
可以用来集成.
以下是一个简单的功能测试:
<?php $I = new FunctionalTester($scenario); $I->amOnPage(‘/‘); $I->click(‘Sign Up‘); $I->submitForm(‘#signup‘, array(‘username‘ => ‘MilesDavis‘, ‘email‘ => ‘miles@davis.com‘)); $I->see(‘Thank you for Signing Up!‘); $I->seeEmailSent(‘miles@davis.com‘, ‘Thank you for registration‘); $I->seeInDatabase(‘users‘, array(‘email‘ => ‘miles@davis.com‘));
可以看出跟 Acceptance Tests 验收测试
语法类似, 因为集成了测试环境, 允许检查 email 和 数据库.
Acceptance tests
类似, 但是少了打开浏览器来渲染, 速度快多了;单元测试(又称为模块测试, Unit Testing)是针对程序模块(软件设计的最小单位)来进行正确性检验的测试工作, 当 functional
或者 acceptance
测试都检查不到 最小单位
的逻辑时, 还能通过 单元测试
确认深藏在代码里面的某些功能仍然可用, 单元测试
能消除程序单元的不可靠性.
Codeception 的单元测试功能是基于 PHPUnit
之上的, 你可以照样写 PHPUnit
的测试代码, Codeception 一样能运行.
Codeception 在 PHPUnit
的基础上提供了一系列工具能让单元测试更加简单, 代码可读性更高. 单元测试是最复杂最繁琐的测试, 并且是会跟着业务逻辑代码的改变而改变, 在实际开发中技术人员会经常因为需求、业务的变更而修改单元测试, 提高其可读性和易用性可以帮助相关人员更加快速的跟上一切变化.
以下是一个简单的 integration test (集成测试)
<?php function testSavingUser() { $user = new User(); $user->setName(‘Miles‘); $user->setSurname(‘Davis‘); $user->save(); $this->assertEquals(‘Miles Davis‘, $user->getFullName()); $this->unitTester->seeInDatabase(‘users‘,array(‘name‘ => ‘Miles‘, ‘surname‘ => ‘Davis‘)); }
functional
或者 acceptance
所做不到的;标签:
原文地址:http://www.cnblogs.com/mafeifan/p/4297692.html