第一次用 PHPUnit 写测试就上手(上)

一、什么是测试?测试的重要性?

开发者在撰写程式的时候,程式不大可能会没有问题,所以通常就需要验证程式的执行是不是符合预期。测试程式能用来验证程式程式的运作是不是正常的,并发现程式中的错误,以增加软体品质。

下面是一个活动报名的系统:
第一次用 PHPUnit 写测试就上手(上)_第1张图片
这一个活动报名系统主要提供使用者报名活动,在报名活动内还有一些子功能,像是「限制活动报名人数」,如果是这一个子功能,该如何测试呢?

直觉想到可能就需要有 20 个以上的使用者,然后让这个些使用者分别来报名活动,如果没超过限制的人数,使用者就能继续报名,反之,超过了限制人数的话,使用者就无法继续报名了。说到这里,会觉得这是什么测试!

先分析一下,照上面的方法进行测试会有什么问题:

1.测试案例一多,会花太多时间
这时候,如果再增加报名截止日期的测试,这样又需要再对报名功能测试一次。

2.改了程式码之后,需要再做一次测试
日后维护时,会需要再次修改程式码,但是,改了程式码之后,该如何验证修改后的程式运作上是没问题的?所以,可能又要再次从头做一次测试。

3.与其他程式混在一起测试
要执行报名功能的程式码,要透过 view 的程式去呼叫。但是,这样做测试的时候,如果测试失败,就必须花时间去找出是报名的程式出问题,还是 view 程式。

那该如何解决这些问题呢?针对开发者来说,需要一个可以自动化、重复的、独立的测试。

二、单元测试

单元测试是分别对程式的单元,例如:函式 (function)、方法 (method),进行测试,测试时会判断单元的执行结果是不是有符合预期。
第一次用 PHPUnit 写测试就上手(上)_第2张图片
从上图可以看到,撰写了Event 类别提供了两个方法,reserve()、unreserve(),也就是目标程式。
接着透过 EventTest 的两个测试案例,testReserve() 与 testUnreserve() 分别来对 Event 类别中的两个类别方法执行测试,测试的结果会在测试案例中验证,如果验证通过,表示测试就成功了!

单元测试能协助开发者什么?

1.确保单元的执行结果
这一点蛮觉得就可以了解到,单元测试能协助验证目标程式的执行结果。

2.尽早发现程式中的错误
因为单元测试是在开发的时候就进行的,所以能发现程式中存在的问题。
没使用单元测试的时候,写好了一份程式,但是,这份程式码需要与其他程式码整合才有办法运作。所以就需要等整个程式开发的差不多的时候,才能对程式进行测试,在测试出现问题的时候,会花许多时间来厘清是那一份程式导致的问题。
如果使用单元测试,就能在写好了一份程式之后进行单元测试,而不用等到之后才对程式测试。

3.修改程式,更加有信心
程式写好了,需要维护、修 bug,如果修改了程式码后,能确定修改后的程式与之前的正常运作是一样的吗?单元测试能协助修改程式后,对程式执行测试,如果测试过了,表示程式的运作是正常的,测试失败的话,可能需要再回头修改程式。

4.测试即文件
在撰写测试的时候,会对单元所提供的功能进行验证,所以,除了能透过程式来了解单元的运作外,也能用所撰写的单元测试来知道,被测试的单元有哪些运作及功能。
在开发的时候,会撰写一些文件来作为软体的文件,在实际上,有时候那些文件并不一定会随着程式变更而修改,到后来会变成之前所做的文件跟程式是不同步的。
因为,单元测试的程式会对目标程式进行验证,所以,测试能避免掉传统文件所造成的程式与文件不同步的问题。

三、简介 PHPUnit

PHPUnit 是 PHP 程式语言中最常见的单元测试 (unit testing) 框架,PHPUnit 是参考 xUnit 架构利用 PHP 实作出来。

为什么要使用 PHPUnit 来测试呢?虽然,要做单元测试可以自己写程式来测试, 但是 PHPUnit 提供了一些测试时常用的 library 及解决测试时会遇到问题的方法,所以我们会使用 PHPUnit 来做单元测试。
(未完待续)

你可能感兴趣的:(测试工具)