maven笔记
生成一个web的maven项目:
mvn archetype:create -DgroupId=com -DartifactId=simple-web -DarchetypeArtifactId=maven-archetype-webapp -DarchetypeCatalog=local
-DarchetypeCatalog表示使用本地缓存的catalog,不用每次生成的时候都去查询。
上面可以出现the defined artifact is not an archetype的错误,这个错误可以通过1、删除本地库,2、删除其它的mirror,只使用maven的库。重新生成即可。
使用对应的profile来构建:
mvn install -PprofileName
调试测试用例:
mvn -Dmaven.surefire.debug test
RESTService,webservice jax-rs的实现,里面包含了deploy方法。
surefire plugin运行测试用例失败时候打印Stack trace:
mvn test -Dsurefire.useFile=false
forkMode可以让第个Test使用不同的ClassLoader,这样可以使得一些依赖于系统属性的常量值在不同的Test中得到不同的设置
forkMode 可设置值有 “never”, “once”, “always” 和 “pertest”
-DinteractiveMode=false 非交互模式
surefire测试指定类
>mvn test -Dtest=[ClassName] 运行测试类中指定的方法:(这个需要maven-surefire-plugin:2.7.3以上版本才能支持) >mvn test -Dtest=[ClassName]#[MethodName] //[MethodName]为要运行的方法名,支持*通配符,范例: >mvn test -Dtest=MyClassTest#test1 >mvn test -Dtest=MyClassTest#*test*
以离线模式运行,这样子maven就不会去尝试更新/检查本地库了,在私服没有启动等情况下可以节省网络访问上消耗的时间:
maven clean install --offline
简单地用 dependency:tree往往并不能查看到所有的传递依赖。不过如果你真的想要看所有的,必须得加一个 -Dverbose参数,这时就必定是最全的了。
今天修改了一下子module的依赖时候,构建项目的时出现dependencies.dependency.version for xxx is missing, transitive dependencies will be ignore。导致另一下工程打包时候相关的依赖没有打进来,(even though the dependency is already declared in its parent's pom file's dependency management section)即使parent pom已经含有相关<dependency>的version,但貌似没有生效,后面在stackoverflow查找到了相关问题,发现parent pom没有安装到本地库引起的。
2017-10-24: 今天在技术交流群里面看到一个maven解决依赖版本冲突的问题,特地复习了一下maven解决版本冲突的方式:
maven解决版本冲突主要是两个原则。
- 路径最短原则:如上图E1的路径是“项目-A-E1”,E2的路径是“项目-B-F-E2”,因为E1路径比E2短,所以最终会选择E1而不用E2。
- 优先声明原则:当出现路径长短相同的时候,谁先声明就用谁。如F1和F2的路径距离相同,但是由于F1比F2先声明(B比C先声明),所以最终使用F1。