Skip to content
springside edited this page Dec 12, 2012 · 18 revisions

Maven已经进入成熟期,没什么大的变化了。风头会慢慢被Gradle之类的盖过去,但目前仍然是首选。

1.Sonatype

Maven被Sonatype主管后,中央仓库用Nexus管起来了。 用http://search.maven.org 就可以方便的找到jar。另外和Sun,Hibernate几家Repository的关系也好了,所有的jar都可以在中央库找到,不需要再同时指向多个Repository。

2.代理服务器与私服

如果机器不能直接上网,需要设定代理服务器,在maven目录的conf/settings.xml中,修改<proxies>小节。

如果中央服务器很慢,建议搭建一台私服,将下载后的包缓存起来供其他同事使用,私服选Nexus就很好。搭完私服后,可以在pom.xml里的<repositories>和<pluginRepositories>中增加私服定义。(参见springside-parent),也可以直接修改Maven的settings.xml的 <mirrors>小节。

3.测试

###3.1 区分单元测试与集成测试###

原本Maven一直没有很好的区分单元测试和集成测试的用例。因为集成用例依赖可能很多,执行又慢,很多时候我们都要Skip掉它们只运行单元测试。

后来Maven在原来的surefire插件继续负责在test阶段测试Test.java的单元测试用例, 新增了failsafe插件负责在integration-test阶段(package阶段之后)执行IT.java的集成测试。

但SpringSide在SpringSide4.0 RC2不再使用这个插件,首先因为springside是使用嵌入式Jetty,Out-Of-Container的执行功能测试用例的,所以在集成测试阶段之前的Package阶段打war包是白做的。其次继续把*IT.java用例继续放在test/java里,使得在Eclipse没有办法单独执行所有的单元测试。(因为Eclipse没有办法执行某个子目录及其子子目录下的所有用例)

所以SpringSide的综合解决办法是,用codehaus的build-helper-maven-plugin插件新开一个Functional Test Source 目录test/functional,将所有功能测试用例放到这里,然后文件名采用FT.java后缀,然后建不同的Profile,执行Test.java 或*FT.java.

在两个Examples项目的pom.xml中都有完整的示例,采用build-helper-maven-plugin新开目录的原因,是它可以让eclipse:eclipse生成的项目文件里,也包含新开的functional源码目录。

###3.2 Skip Test###

mvn install -Dmaven.test.skip=true 最狠的,连测试用例的编译都省掉了。

###3.3 分组执行###

TestNG的皇牌功能,可以将用例分成几组,比如超慢的Nightly组放到半夜才运行。 Junit4后来的新版也支持一个@Category的定义,但是,必须在一个TestSuite维护所有Case,或者使用一个叫ClassPathSuite的项目。

在Maven的测试插件里没这个麻烦,它会自行读取@Category标签来过滤。

pom.xml

    <plugin>
      <artifactId>maven-surefire-plugin</artifactId>
      <version>2.12</version>
      <configuration>
        <groups>com.mycompany.FastTests</groups>
      </configuration>
      <dependencies>
        <dependency>
	  <groupId>org.apache.maven.surefire</groupId>
	  <artifactId>surefire-junit47</artifactId>
	  <version>2.12</version>
	</dependency>
      </dependencies>
    </plugin>

TestCase中的testSlow()将不会被执行。

    public class AppTest {
      @Test
      @Category(SlowTests.class)
      public void testSlow() {
        System.out.println("slow");
      }

      @Test
      @Category(FastTests.class)
      public void testFast() {
        System.out.println("fast");
      }
    }

###3.4 透传命令行的参数到测试插件 测试插件是自己Fork一个JVM出来的,所以启动Maven时的系统参数不会直接透传到测试中,比如我想在命令行控制selenium.driver,需要这样配置

<plugin>
	<groupId>org.apache.maven.plugins</groupId>
	<artifactId>maven-failsafe-plugin</artifactId>
	<configuration>
		<systemPropertyVariables>
			<selenium.driver>${selenium.driver}</selenium.driver>
		</systemPropertyVariables>
	</configuration>
</plugin>

##4.脚本?脚本!! 虽然Maven的理想很丰满,什么都是插件,什么都是阶段,但实际项目还是有很多需要脚本干点小事情的时候,比如springside里更新本地测试数据库。这时候有几种选择,一种是用ant脚本,需要依赖包的时候用ant的maven插件,另一种是maven里用antrun插件。

因为Ant的maven插件老是被忘记下,所以springside里选择了用maven的antrun插件,另外也不搞什么阶段了,定义出独立的profile,直接运行goal: mvn antrun:run -Prefresh-db

另外,exec:java来运行Java命令也不错。

##5. Enforcer插件 maven的魅力与麻烦之一就是依赖和依赖的依赖,有时候一不小心就会因为隐性依赖一些不想依赖的库,比如common-loggings, 比如2.x版或3.0.x版的spring,比如aspectj的groupId已经改了, enforcer插件可以提醒你这些隐性依赖,在quickstart的pom.xml里做了定义。

另外,未免意外惊喜不断,quickstart里还用enforcer插件硬性规定了JDK6的版本和Maven 3.0.3的小版本。

##6. Maven与Eclipse SpringSide喜欢用mvn eclipse:eclipse -Declipse.workspace=C:\Users\myname\workspace, 这里用参数指明了eclipse的workspace,这样子如果发现依赖包也在workspace里就会进行项目依赖而不是jar包依赖。

Eclipse插件文档介绍了很多参数可以让生成的项目文件符合你的特殊需求,如支持SpringIDE,又比如生成一个规定项目encoding的配置文件

<additionalConfig>
	<file>
		<name>.settings/org.eclipse.core.resources.prefs</name>
		<content>
<![CDATA[eclipse.preferences.version=1${line.separator}encoding/<project>=${project.build.sourceEncoding}${line.separator}]]>
		</content>
	</file>
</additionalConfig>

另外sonatype还提供了m2eclipse插件,但不想太依赖插件,而且这插件也不是总是灵光。所以只是用这个插件来看pom.xml文件中的依赖关系。

##7. Archetype插件生成项目 详见基于SpringSide创建项目

##8. 插件更新通知 看邮件列表: http://mail-archives.apache.org/mod_mbox/maven-announce/

资料

返回参考手册

Clone this wiki locally