简单的测试用例可以写在文件内部,继承于自动化的测试可能需要其它方式来为它提供测试数据。我们可以同过配置文件设计一个规范来完成我们的设想,在这之前,还有两种方式来帮助我们完成测试。
依赖测试
依赖测试中,一个测试的某个变量依赖于另外一个测试的结果来传递,并且这个传递是按照方法定义的先后顺序来完成的。
通过被依赖函数返回一个变量,依赖函数设置这个变量的参数即可,通过这种方式可以传递变量。在依赖函数的注释块内增加:@depends funcname 即可。
<?php class StackTest extends PHPUnit_Framework_TestCase { public function testEmpty() { $stack = array(); $this->assertEmpty($stack); return $stack; } /** * @depends testEmpty */ public function testPush(array $stack) { array_push($stack, 'foo'); $this->assertEquals('foo', $stack[count($stack)-1]); $this->assertNotEmpty($stack); return $stack; } /** * @depends testPush */ public function testPop(array $stack) { $this->assertEquals('foo', array_pop($stack)); $this->assertEmpty($stack); } } ?>
(以上示例来源:http://www.phpunit.de/manual/3.5/en/writing-tests-for-phpunit.html#writing-tests-for-phpunit.test-dependencies)
它可以实现变量的传递,如我们测试一个对象,我们不用每一个测试用例都去进行实例化这个类,转而对实例化后的类进行传递即可。另外,某些类可能依赖于前一次的操作,那么传递可以保证这种操作的顺序和准确性。
供源函数
这个函数很棒,它为一组测试提供一组测试数据。如下:
<?php class DataTest extends PHPUnit_Framework_TestCase { /** * @dataProvider provider */ public function testAdd($a, $b, $c) { $this->assertEquals($c, $a + $b); } public function provider() { return array( array(0, 0, 0), array(0, 1, 1), array(1, 0, 1), array(1, 1, 3) ); } } ?>
在注释区内标注:@dataProvider profunc 即可,在provider函数中返回测试的数据:数组,每条也是一个数组。测试函数通过参数来接收,并以此被调用。上面的例子中,testAdd将会被执行4次。
高级测试配置
其实这并不是什么高深的概念。它只是在供源函数的基础上增加一个配置文件,通过在供源函数中读取配置文件的配置,进行逻辑处理,然后格式化即可。
测试用例设计与实现
本文介绍了测试用例设计的几种方法,包括依赖测试、供源函数和高级测试配置,详细解释了每种方法的原理及应用案例。
3457

被折叠的 条评论
为什么被折叠?



