测试设计有两类方法:黑箱(Black Box)和白箱(White Box)。这是每个接触过软件测试的人都会给出的答案,但这只是整个软件测试的入门知识。所谓黑箱/白箱,是指软件测试设计的方法,不是软件测试的方法!注意"设计"二字。
黑箱:指的是在设计测试的过程中,把软件系统当作一个"黑箱",无法了解或使用系统的内部结构及知识。一个更准确的说法是行为测试设计(Be-havioralTest Design),即从软件的行为,而不是从内部结构出发来设计测试。
白箱:指的是在设计测试的过程中,设计者可以"看到"软件系统的内部结构,并使用软件的内部结构和知识来选择测试数据及具体的测试方法。
"白箱"并不是一个精确的说法,因为把箱子涂成白色,同样也看不见箱子里的东西。有人建议用"玻璃箱"来表示。在实际工作中,我们不应画地为牢,严格只用某一种测试设计方法。我们对系统的了解当然是越多越好。所谓"灰箱"的提法,正反映了这一点。有些测试专家甚至希望我们忘记全部的"箱子"及其颜色。进一步说,我们并不是要禁止懂得程序内部结构的人员来进行黑箱测试设计,只不过是在设计时有意不考虑软件的内部结构。例如,在测试程序内部基本模块时(单元测试),通常要求由对程序结构非常了解的程序员来设计,这是因为内部模块的"行为"和程序的外部功能并没有直接的关系,而且对内部基本模块的"行为"通常没有明确的定义。另一个例子是软件的"易用性测试",在设计此类测试时,没必要纠缠于程序的内部结构,而是应着重于软件的界面和行为。但是软件易用性测试也需要很多专业知识。这也从一个侧面表明"黑箱"和"白箱"没有简单的难度高低之分。测试用例写出来之后,大家可以忘了它们是从哪种颜色的箱子里出来的,使用就行了。
问:有人说"黑箱",有人说"黑盒",到底是"箱子"还是"盒子"?
答:在网上搜索了一下,"黑箱测试"有超过100万个记录,"黑盒测试"只有70多万。所以"箱子"赢了。
问:但是我听小飞说他刚进公司实习时只能做"黑箱测试",这是什么意思?
小飞:我刚进公司实习的时候,两眼一摸黑,看到啥都是"黑箱",即使测试用例是由懂得程序结构的开发人员写出来的,我也还是只会机械地运行。我是知其然,不知其所以然,箱子当然是黑的。后来看得多了,学了一些东西,了解了程序的结构和算法,箱子的颜色就变浅了,好像能看到箱子里的东西一样。
渭南市网站建设_网站建设公司_Bootstrap_seo优化