软件开发中测试驱动开发的运用

(整期优先)网络出版时间:2018-12-22
/ 2

软件开发中测试驱动开发的运用

马凡王艳刘兴兴

(陕西黄河集团有限公司陕西西安710043)

摘要:目前,我国的科技发展十分迅速,测试驱动开发是软件开发中一种新的开发模式,它的核心思想是通过不断的测试来驱动软件开发的进程,是极限编程中极具特色的开发方法,学习和应用测试驱动开发可以大幅度提高开发效率。本文从它的基本原理、分析对传统软件设计的影响和本身存在的问题这三个方面来系统的解说。

关键词:测试驱动开发;软件开发;极限编程

引言

测试驱动开发(Test—DrivenDevelopment,TDD)是一种开发方式,是由KentBeck提出的极限编程(eX-tremeProgramming,XP)的核心部分。TDD能最大限度的提高软件开发的速度,同时保证了软件的质量,并大大减少了运行期间的维护工作量。TDD讲究测试先行,先编写测试,然后再编写让这些测试通过的代码。在编写代码的时候,有可能会出现代码结构不合理的地方,如重复代码,类之间通讯不当,类的尺寸过长,过分短小的类,方法过长,类之问关联太复杂等,需要对这些不合理的地方重构,重构的方法有提取类,提取接口,提取方法等。TDD开发过程可比做交通灯,我们首先根据需求分析编写一个测试,这时候被测试的类和方法还没有定义,编译器会报告错误,这就是我们的黄灯;当定义了被测试的类和方法之后,还没有定义其内容的时候,编译器不会报错,但是测试通不过,这就是红灯;然后我们定义类和方法的内容,直到测试通过,这就是我们的绿灯。最后,我们需要消除我们在使测试通过的时候引入的一些结构不合理的代码。在此过程中,每完成一次小的修改之后都重新编译并运行测试,这样做怎么强调都不为过。因为在每次小的改动之后,测试通过,可以给我们信心和保证。让我们有勇气继续下一步的工作,每次一小步一小步的推进。在任何时候如果测试失败了,我们都会准确的知道就是最近的一次修改导致了测试的失败。撤消这次修改,测试会再次通过。我们就可以重新尝试修改。通过这种反复的迭代,我们的代码会越来越漂亮。在开发过程中,我们使用程序员测试,它和我们经常提到的单元测试非常类似,但是它们的目的不同,单元测试的目的是为了测试你编写的代码能否工作,而程序员测试是为了定义代码的含义。TDD的基本原则就是在没有测试之前,不要编写任何代码,也就是说,当我们的代码编写完成之前,我们相应的测试已经存在了,这样就保证了一套详尽的程序员测试集。在编写测试的时候,不要一次把所有的测试全部写完,而是要先编写少量的测试,再根据测试的需要编写代码,待测试通过,代码结构合理后,继续编写下一个测试和相应的代码,做到步步为营。

1测试驱动开发的相关环节

1.1原理和过程

测试驱动开发的原理就是应该在明确要开发某个功能后,进行构思并决定如何设计测试代码的过程,从而根据用户的需求编写出功能代码满足这些测试用例。接下来可以循环的进行添加其他功能,最后能够完成全部功能的开发。其中的基本过程包括:明确当前需要完成的功能;需要在保证速度的前提下编写测试用例;编写对应的功能代码;保证测试能够通过的方法就是重构代码。我们通常在运用了测试框架的前提下,进行组织所有的测试用例,从而保证了整个测试过程的高效和便捷。

1.2原则要求

在测试驱动开发的过程中,应根据实际测试要求,保证在检测过程中分清所需要检测的各类代码,并根据不同代码测试设定相互的间隔,进而有效避免在测试的过程中忽视一些细节性问题,同时避免了增加测试的复杂度。另外,在实际操作中,应对所出现的功能点进行测试,尤其是在需要添加功能需求的情况下,应将其添加到测试列表中,严格遵循着测试全面性、准确性的原则,规避因测试不全面而埋下不必要的风险。另外,测试驱动开发过程中应不断完成相关的测试实例、功能代码、重构等,避免出现疏漏,同时也应避免干扰到当前正在进行的工作。例如,在编写测试代码的过程中,应充分考虑到该如何使用和测试,然后再进行合理的设计和编码,将其写入功能代码判断用句的过程中,应合理写入对应的辅助语句,才能保证测试驱动开发的有效性、合理性,同时也规避了一些因编写不合理而产生不必要的麻烦。

1.3测试技术

如果我们采用传统的检测方式,这无疑会在我们的软件开发中造成开发速度缓慢等缺点,而我们需要认清的一点就是测试驱动开发中的测试并不是作为一种负担,而是一种为了帮助我们减轻繁重工作量的有效方法。在针对如何选择一个合适的时间来停止编写测试用例的问题上,我们应该根据往常的工作经验来进行,例如说针对一些功能复杂并且具有核心功能的代码来说应该编写更细致、全面的测试用例。静态的标准也不适用于测试驱动开发的测试范围,在实际情况下是能够随着时间的改变而改变。

2软件开发中测试驱动开发的运用分析

2.1创新软件开发的形式

从对以往软件开发的分析中发现,传统软件开发过程中,由于受到传统观念以及落后的技术影响,使得传统软件开发效果不佳,甚至会导致所开发出来的软件埋藏诸多漏洞,进而影响到软件的正常使用。在将测试驱动开发运用到软件开发中,创新了软件开发的形式,对提升软件开发的效率有着极大的作用[4]。当然,在新时期发展中,软件的开发都是建立在人的使用需求基础上,而测试驱动开发中所贯彻的以人为本的思想,则更是以人类活动为基础,满足其使用需求而进行开发的,从某种意义上分析,测试驱动开发的运用不仅仅是对软件开发形式的创新,更是将人的观念与软件开发进行有效结合,进而保证所开发出来的软件更符合人们的使用需求。

2.2改善设计方式

测试驱动开发在实现设计方面有着很大的优势。它体现出来的没计思想与传统软件工程大相径庭,它摒弃了传统方法中对设计近乎苛求的原则,弱化了全面细致的设计。不要求对需求做出非常详细的设计,而是遵循简单的原则,对现有的需求做出简单的设计。不需要为以后考虑,因为你永远不知道将来会增加哪些需求。这样看似对设计的简化,削弱了开发的依据,但其实它的思想却是进一步明确了软件开发的时候应该更注重眼前的问题,全力去考虑当前的需求,满足客户当前的需要,而不要为以后的需要费时费力,只有这样,才能使做出的软件符合客户的需求。测试驱动开发的特点之一就是先写测试再写代码。而此时,测试用例编写的意义就非同一般了。

2.3革新传统的软件开发

以人为本的思想是测试驱动开发的方法。人类活动都秉持着高度的目的性,建立一个心里的标准并竭尽全力去达成这个标准会具有重要的心理作用。例如在我们平时的测试过程中,有着不同目的的测试软件开发将会带来不一样的操作结果。比如说将证明程序中没有我们需要查找的错误作为我们的最终目的,那大脑中的潜意识里就会指导着我们朝这个思路去做,所以在编写测试的过程中,我们就潜意识地选择了一些不会使整个软件程序出错的实验数据;相反,如果我们逆向思维去选择那些容易发现程序错误的测试数据去证明程序中的漏洞,那结果一定就会不同了。对比之下,我们在以寻找错误为最终目的的前提下做出的程序检测质量远远高过以不找错误为最终目的的思维方式。

3结语

由于其独特的软件开发思维方式和良好的设计方法,测试驱动开发的技术越来越受到开发人员的追逐,通过循环进行不可运行-可运行-重构,将代码结构简化到最佳状态,从而大幅提高代码的质量,测试驱动开发正在逐渐走向成熟,相信它是软件设计中的一次伟大的变革。

参考文献:

[1]陈迪舸.刍议测试驱动开发在软件开发中的作用[J].电子技术与软件工程,2016(7):60.

[2]陈希,徐明昆.测试驱动开发在软件开发中的研究与实践[J].软件,2012,33(12):177-181.