下载本文示例代码
到此为止,我们只有两个对Array和内建函数sizeof()的测试。当我们开始测试大量的array_*()函数时,每个都需要一个测试。我们可以每个都从头写起。但是,更好的方法是一次性写好一个测试基础构架,以后就只用写每个测试不同的部分。PHPUnit就是这样一个基础构架。 例5展示了如何用PHPUnit重写例4中的两个测试。 例5. 用PHPUnit测试 Array和sizeof().
<?php require_once 'PHPUnit2/Framework/TestCase.php'; class ArrayTest extends PHPUnit2_Framework_TestCase { public function testNewArrayIsEmpty( ) { // 创建数组fixture。 $fixture = Array( ); // 断言数组fixture的大小是0。 $this->assertEquals(0, sizeof($fixture)); } public function testArrayContainsAnElement( ) { // 创建数组fixture。 $fixture = Array( ); // 为数组fixture增加一个成员。 $fixture[] = 'Element'; //断言数组fixture的大小是1。 $this->assertEquals(1, sizeof($fixture)); } }?> 例5告诉我们用PHPUnit来写测试的基本步骤是: 1.类Class的测试类是ClassTest。 2.ClassTest一般继承PHPUnit2_ Framework_TestCase。 3.测试是公有方法,没有参数,名字是test*。 4.在测试方法中,断言函数,如assertEquals()(见表6)用于断言实际值是否匹配期望值。 一个如PHPUnit的框架需要解决一系列问题,有些看起来互相冲突。测试必须同时满足以下条件: 易学 测试必须容易学,否则,开发人员不会去学 易开发 测试必须容易开发,否则,开发人员不会去开发 易读 测试代码必须没有外部关系,这样测试本身不会在杂乱无章中迷失。 容易执行 测试应该很容易执行,执行的结果以一种清楚和明确的格式表达出来。 快速执行 测试应该执行的很快,这样每天才能执行上千次。 代码隔离 测试之间不能互相影响,测试顺序的改变不应该影响结果。 可组合的 我们应该可以以任何组合来运行测试,这是代码隔离的一个必然结果。 这些约束条件有两个主要的冲突: 易学vs易开发 测试通常不需要应用到编程全部的灵活性。很多测试工具提供了它们自己的测试脚本语言,这些语言只有书写测试所需特性的最小集,因为没有噪声来干扰你的测试内容,写出来的测试易读易写。但是学一种新的编织邮件和一套工具还是不方便的,容易混淆视听。 代码隔离vs快速执行 如果你想要一个测试的结果不影响另一个,每个测试在开始运行的阶段,都需要创建测试的全专题,返回后又要恢复运行之前的状态。可是,设置状态需要的时间很长(如,连接到数据库,用真实数据初始化到一个已知状态) PHPUnit解决这个问题的办法是采用PHP作为测试语言。有时,全功能的PHP对于书写短小的,直接的测试是过于强大了,不过,我们利用的程序员已经有使用PHP的全部经验。因为我们需要说服勉强的测试人员,降低书写这些初始测试的门槛是及其重要的。
到此为止,我们只有两个对Array和内建函数sizeof()的测试。当我们开始测试大量的array_*()函数时,每个都需要一个测试。我们可以每个都从头写起。但是,更好的方法是一次性写好一个测试基础构架,以后就只用写每个测试不同的部分。PHPUnit就是这样一个基础构架。 例5展示了如何用PHPUnit重写例4中的两个测试。 例5. 用PHPUnit测试 Array和sizeof().
<?php require_once 'PHPUnit2/Framework/TestCase.php'; class ArrayTest extends PHPUnit2_Framework_TestCase { public function testNewArrayIsEmpty( ) { // 创建数组fixture。 $fixture = Array( ); // 断言数组fixture的大小是0。 $this->assertEquals(0, sizeof($fixture)); } public function testArrayContainsAnElement( ) { // 创建数组fixture。 $fixture = Array( ); // 为数组fixture增加一个成员。 $fixture[] = 'Element'; //断言数组fixture的大小是1。 $this->assertEquals(1, sizeof($fixture)); } }?> 例5告诉我们用PHPUnit来写测试的基本步骤是: 1.类Class的测试类是ClassTest。 2.ClassTest一般继承PHPUnit2_ Framework_TestCase。 3.测试是公有方法,没有参数,名字是test*。 4.在测试方法中,断言函数,如assertEquals()(见表6)用于断言实际值是否匹配期望值。 一个如PHPUnit的框架需要解决一系列问题,有些看起来互相冲突。测试必须同时满足以下条件: 易学 测试必须容易学,否则,开发人员不会去学 易开发 测试必须容易开发,否则,开发人员不会去开发 易读 测试代码必须没有外部关系,这样测试本身不会在杂乱无章中迷失。 容易执行 测试应该很容易执行,执行的结果以一种清楚和明确的格式表达出来。 快速执行 测试应该执行的很快,这样每天才能执行上千次。 代码隔离 测试之间不能互相影响,测试顺序的改变不应该影响结果。 可组合的 我们应该可以以任何组合来运行测试,这是代码隔离的一个必然结果。 这些约束条件有两个主要的冲突: 易学vs易开发 测试通常不需要应用到编程全部的灵活性。很多测试工具提供了它们自己的测试脚本语言,这些语言只有书写测试所需特性的最小集,因为没有噪声来干扰你的测试内容,写出来的测试易读易写。但是学一种新的编织邮件和一套工具还是不方便的,容易混淆视听。 代码隔离vs快速执行 如果你想要一个测试的结果不影响另一个,每个测试在开始运行的阶段,都需要创建测试的全专题,返回后又要恢复运行之前的状态。可是,设置状态需要的时间很长(如,连接到数据库,用真实数据初始化到一个已知状态) PHPUnit解决这个问题的办法是采用PHP作为测试语言。有时,全功能的PHP对于书写短小的,直接的测试是过于强大了,不过,我们利用的程序员已经有使用PHP的全部经验。因为我们需要说服勉强的测试人员,降低书写这些初始测试的门槛是及其重要的。
下载本文示例代码
PHPUnit袖珍指南之PHPUnit的目的PHPUnit袖珍指南之PHPUnit的目的PHPUnit袖珍指南之PHPUnit的目的PHPUnit袖珍指南之PHPUnit的目的PHPUnit袖珍指南之PHPUnit的目的PHPUnit袖珍指南之PHPUnit的目的PHPUnit袖珍指南之PHPUnit的目的PHPUnit袖珍指南之PHPUnit的目的PHPUnit袖珍指南之PHPUnit的目的PHPUnit袖珍指南之PHPUnit的目的PHPUnit袖珍指南之PHPUnit的目的PHPUnit袖珍指南之PHPUnit的目的PHPUnit袖珍指南之PHPUnit的目的PHPUnit袖珍指南之PHPUnit的目的PHPUnit袖珍指南之PHPUnit的目的