1.
每日构建(
Daily Build
)
在项目中使用每日构建(
Daily Build
)是为了实现“持续集成”。传统构建只发生在项目发布前夕很短的一段时间,压力和风险不小。每日构建一定程度上缓解了这种压力,削平了曲线。好东西!但每日构建也需项目组的投入,学习和使用
Ant
(或
Nant
)就是一个不错的办法。
2.
单元测试(
Unit Test
)
在项目中使用单元测试(
Unit Test
)和每日构建在思想上有相似之处,在实践中又交相呼应。单元测试可以确保每个软件项目最小逻辑部件的正确性。在耦合始终存在的情况下,单元测试的作用其实也被放大了,对某个逻辑部件的测试自然也包括了对所引用其他部件的测试(虽然这并不是单元测试的初衷)。单元测试不是最重要的,但的确是非常重要的和必须的。单元测试也需要项目组的投入,编写单元测试用例是起码的,学习和使用
JUnit
(或
Nunit
)能帮上不小的忙。
3.
结合起来(
Do Them All
)
单元测试的最佳实施者是每个开发人员自己,也可以采用同行测试(
Buddy Test
)。他们阅读设计文档,编写单元测试用例、编写逻辑部件,然后把逻辑部件放到测试用例中测试,测试通过就继续往前走。单元测试的发起者是项目组中单个的开发者时,会使得单元测试此起彼伏,但问题是有些单元测试有很多都是无效的。原因很简单,因为不同开发者编写的逻辑部件之间的耦合只要存在,这样的单元测试就是无效的。参考《软件配置管理模式》一书中关于“活动开发线”模式的讲述:当在项目的一条码线(
Code Line
)上,测试与开发在时间上同存时,测试都是无效的,单元测试也不例外。
也许在开发者自行单元测试的同时,我们还应该定时的让所有的开发者都停下来,提交他们的代码,然后一起来进行单元测试。其实这不难,每天下班的时候他们都会自动的停下来,如果项目的配置管理还算可以的话,他们也都会在下班前提交代码,然后让我们来运行单元测试吧。
我们用
Ant
来进行每日构建。同样,我们也可以让
Ant+JUnit
帮助我们进行每日单元测试(
Daily Test
?)。每次听微软的讲师讲
MSF
,都要讲他们的开发是深夜
12:00
开始的,也就是“自动构建
+
自动测试”,第二天早上,开发组的人拿到自动生成的报告,该
code
的就
code
,该
debug
的就
debug
。(其实,这也就是一种测试驱动开发:
Test-Driven Development
,又一个很多人争议的软件方法。)这不难,是看公司要不要这么做。
4.
实践(
Practice
)
关于使用
Ant
实现每日构建的请看陋文:“一个轻巧的每日构建解决方案”。
在此基础上,在
Ant
的“
build.xml
”中加入单元测试任务即可,同时也可以生成单元测试报告。甚至可以将单元测试结果报告通过
email
发送给开发组成员。
先请出国内外的几篇好文:
“让编译和测试过程自动化”
“利用
Ant
和
JUnit
进行增量开发”
“每日创建之自动测试”
到今天(
2004-08-20
)为止,在
Google
上面以“
ant+junit
”可以搜出
127000
条记录,大家都做得很好。但上面
3
篇的确已经足够帮助还未实作的人快速的实现“每日构建
+
单元测试”了。
关于实践他们都说得很清楚,我也是在看了这些文档后完成实践的。我在自己的
Blog
上加点自己的东西吧,也就是在实现“每日构建
+
单元测试”时的小贴士。
1)
环境配置之<mail>
:
“让编译和测试过程自动化”一文的作者
Erik Hatcher
也是
Ant
的开发者之一。但此文有些早了,文中所提到的
Ant
的<mimemail>
已经合并到<mail>
中,<mimemail>
已经废置不用了。<mail>
任务依赖于
JavaMail
和
JAF
,如果没有用过的话,请到
SUN
公司的网站上下载,并在下载后完成以下配置(以我的目录结构为例):
CLASSPATH
:
C:\javamail-1.3.2ea\mail.jar;
C:\javamail-1.3.2ea\lib\mailapi.jar;
C:\javamail-1.3.2ea\lib\pop3.jar;
C:\javamail-1.3.2ea\lib\smtp.jar;
C:\jaf-1.0.2\activation.jar;
这样才能保证
Ant
以
email
发送构建和测试报告时的正确。
2)
环境配置之<junit><junitreport>
:
如果项目组在白天用的是
JBuilder
,其中集成了
JUnit
和
Ant
。(建议下载单独的
Ant
和
JUnit
)但当晚上
Ant
调用
JUnit
执行测试任务时,必须保证
,<junit><junitreport>
能被
Ant
所识别。所以,你要将
JUnit
所属的
3
个
*.jar
文件:
src.jar ,junit.jar,junitmail.jar
拷贝到
Ant
的库所在目录(以我的目录结构为例):
C:\ant\lib
这样才能保证,
Ant+JUnit
会为你生成漂亮的
html
格式的测试报告,并发送到你指定的
email
中。
5.
总结(Summary)
讨论了每日构建和单元测试的作用和结合起来使用的理由。配合软件开发配置管理模式提出了供参考的结合方法,并通过实践验证该方案的可行性和简单性。最后和
java
不太熟练的朋友分享了少量经验。