写在前面
距离上一篇博客已经过去一年多的时间了,前两篇博客涉及的内容是图像分类和简单的特征分类,有兴趣的读者可以点进去看看。
然后我在想,作为一名非科班的学生,只搞这种貌似高精尖的东西,可能以后吃饭都成问题,因此这段时间呢,我也在巩固计算机四大课的基础知识。也因为学业的原因开始了第一份实习工作吧,实习的内容也和这次文章要讲的东西有关,如题目所言,是进行测试的。
测试的目的
可能有同学会问:欸,你这代码能跑能运行不就行了嘛,要测试干嘛?
实际上,很多时候,我们的代码并不仅仅是给自己用的。我们知道自己的代码有这样或者那样的问题,因此只要有意避免错误的使用方式就可以正常地满足需求了。
但使用代码的人却也不只是你自己,他们不知道代码存在这样或者那样的问题,以至于代码执行时导致崩溃。
举个例子
在使用python编写一些自动化脚本的时候,我们可能会使用os库来进行文件夹的创建操作:
import os
os.mkdir("文件夹")
这段代码的作用是在当前目录下创建一个名为"文件夹"的文件夹,
但是如果再次执行它的话就会报错:
FileExistsError: [WinError 183]
当文件已存在时,无法创建该文件。: '文件夹'
因为上一次代码执行的时候已经创建了一个名为"文件夹"的文件夹,
因此这个时候就会报错。
我们自己使用它可能会觉得:这东西删了再执行不就好了!
但用户并不会考虑到这一点,他们会认为这段代码是有问题的,并不能够符合需求。
实际上,前面我们就进行了一次测试的工作。第一次执行代码,我们发现代码可以满足需求,但如果匆匆忙忙交付,那用户如果执行两次代码,这段代码就不能满足原来的需求。
因为第二次执行的代码并没有新建一个"文件夹"。
这也是测试所做的事情:把自己当作用户,尝试所有可能发生的事情,排查错误,然后改进优化代码。
那么我们希望多次执行发生什么呢?
代码编写与测试
目标的明确
在撰写一段代码之前,首先要明确:
作为一个用户,这段程序要用来做什么?
还是前文中的例子,作为一个用户,我希望这段代码执行时可以新建一个"文件夹"文件夹,不管执行几次都只有那一个,而且不希望看到那堆红红的我看不懂的东西,也不要有其他东西,执行速度越快越好!
测试用例
既然明确了需求,那么我们就可以开始测试用例的撰写了。
测试用例是为某个特殊目标而编制的一组测试输入、执行条件以及预期结果,以便测试某个程序路径或核实是否满足某个特定需求。
那么也就有
行为 | 结果 |
---|---|
执行一次代码 | 生成文件夹 |
执行多次代码 | 不报错,没有多余文件夹 |
当然这样的测试用例编写并不规范,但也表达出了大致的意思,具体的测试用例需要根据实际需求和业务场景来改变。
既然有了目的,那就可以对代码进行改进了
改进后的代码
为了第一次生成文件夹,之后都不生成,那很容易想到用python的try
import os
try:
os.mkdir("文件夹")
except:
print("文件夹已存在")
这样在第一次执行就会创建文件夹,而之后的多次执行也只会跳出提示:
文件夹已存在
合格的测试用例(以腾讯QQ为例)
拿腾讯QQ的登陆来举例吧,之前我也写了测试用例模板:
总之呢,测试的目的在于模仿用户可能去做的事情,然后尽可能地完善代码。