日期:2014-05-16  浏览次数:20512 次

hudson+findbugs的配置方法及无数坑爹的陷阱

http://hi.baidu.com/dburu/blog/item/d34bb68b1fb03b609e2fb4b4.html

?

Hudson是一个简单而非常强大的集成测试工具,结合maven junit findbugs svn ant 等等数以百计的插件,可以大有作为,今天只说findbugs。

Hudson本身的安装与配置就不说了,非常简单,下载war包直接扔到tomcat即可。maven的基本操作也不说了,不行自己去看。

第一步:

首先进入Hudson?? 系统管理 ? 插件管理?? 可选插件

选中FindBugs Plug-in,点击最下面的安装即可,安装完成后需要重启tomcat,以便加载新插件。

说明:

1、如果你曾经安装过该插件,则在“可选插件”中是看不到的,在“已安装”插件中。

2、 点击“更新”页签,如果出现“Hudson :: Maven (legacy) :: Plugin”的更新,你最好乖乖的更新,否则你的job设置中的Build Settings选项下的Publish FindBugs analysis results和E-mail Notification选项,勾选之后点击保存,再次打开设置页面,居然为空,保存不成功!这是一个非常坑爹的BUG。

第二步:

准备工程

eclipse中新建个maven工程,要点是:

在依赖中添加

???<plugin>
????<groupId>org.codehaus.mojo</groupId>
????<artifactId>findbugs-maven-plugin</artifactId>
????<!-- <version>1.2</version> -->
????<configuration>
?????<findbugsXmlOutput>true</findbugsXmlOutput>
?????<findbugsXmlWithMessages>true</findbugsXmlWithMessages>
?????<xmlOutput>true</xmlOutput>
?????<!-- <findbugsXmlOutputDirectory>target/test-findbugs</findbugsXmlOutputDirectory>-->
????</configuration>
???</plugin>

注 意点:看到我注释掉的那句话了吗,这又是一个陷阱,假如放开注释,是可以执行成功的,但是你在Hudson中看不到结果,也就是在 target/test-findbugs下你可以看到findbugsXml.xml,里面也确实有东西,你在命令行执行>mvn clean install findbugs:findbugs或者>mvn clean install findbugs:gui都没有任何问题,但是一旦进入Hudson就是看不到FindBugs Warnings和FindBugs Result,这是因为FindBugs 的Hudson Plug-in是从target目录中取得report。又一个坑爹的陷阱。

手工运行一下mvn clean install findbugs:findbugs,可以看到报告的位置在target的根目录下,才是正确的。

第三步:

拷贝你的工程到\.hudson\jobs\你的job名\workspace\下。

没有workspace可以自己新建一个。

?

第四步:

Hudson ? 新建任务?? 构建一个Maven 2/3 (Legacy)项目

进入设置界面:

Source Code Management

自己看着办吧,从svn取或者自己拷贝到jobs/你的job名字/workspace中

Build

Root POM :填写相对于workspace的根pom的位置

Goals and options:填写诸如clean install findbugs:findbugs或compile ?findbugs:findbugs此类的

Build Settings:勾选Publish FindBugs analysis results,其他可以用默认值。

说明:

1、一定要注意,clean findbugs:findbugs install ,这种写法是错的,可以运行的,但是并不产生findbugs报告,再次坑爹。

2、当然你可以选择“构建一个自由风格的软件项目”,在下一步配置界面选择Invoke Maven 2 (Legacy)或Invoke Maven 3,这也是可以的,不过配置参数有所不同。

至此,全部完成,点击构建,不出意外的话,你可以看到结果页面。

注意:如果你看到的Plug-in Result是个红叉叉,请修改Hudson ? 系统管理 ? 插件管理 ? 系统设置

邮件通知中的Hudson URL为你的正确地址,注意使用ip地址,不要使用localhost,坑爹啊。

?

如果你用的所有包都是最新的,你很有可能会看到下面的错误,错误日志片段:

[java] java.text.ParseException: Unparseable date: "12/20/2011 09:17 PM EST"
[java]???? at java.text.DateFormat.parse(DateFormat.java:337)
[java]???? at edu.umd.cs.findbugs.Version.<clinit>(Version.java:175)
[java]???? at edu.umd.cs.findbugs.PluginLoader.init(PluginLoader.java:595)
[java]???? at edu.umd.cs.findbugs.PluginLoader.<init>(PluginLoader.java:280)
[java]???? at edu.umd.cs.findbugs.PluginLoader.loadCorePlugin(PluginLoader.java:1304)
[java]???? at edu.umd.cs.findbugs.PluginLoader.loadInitialPlugins(PluginLoader.java:1259)
[java]???? at edu.umd.cs.findbugs.PluginLoader.<clinit>(PluginLoader.java:146)
[j