为什么在标记时mvn release:prepare失败?
使用我的多项目pom,在运行release:prepare时出现错误。项目设置和每个发行步骤运行正常之前,没有什么花哨的地方。
我得到的错误是:
[INFO] ------------------------------------------------------------------------ [ERROR] BUILD FAILURE [INFO] ------------------------------------------------------------------------ [INFO] Unable to tag SCM Provider message: The svn tag command failed. Command output: svn: Commit failed (details follow): svn: File '/repos/june/tags/foo-1.0.2/foo.bar.org/pom.xml' already exists
是否知道它来自何处以及如何解决?
(对不起,重复帖子先被关闭了,因为我没有将其表达为可以回答的问题。我希望现在可以。)
编辑
Maven发行插件负责版本处理本身。因此,当我检查Subversion存储库中的路径时,该路径尚不存在。
编辑2
@Ben:我不知道服务器版本,但是客户端也是1.5.2.
解决方案
据我所知,这是Subversion 1.5中的错误,与maven没有直接关系。但是,解决该问题的方法是更新本地svn存储库并再次运行release:prepare目标。
这是因为我们尚未增加Subversion存储库中已经存在的版本号1.0.2.
或者增加版本,或者就从仓库中删除/repos/june/tags/foo-1.0.2标签。
我花了很多时间与此作斗争。 SVN 1.5.1+的不同之处在于,它中断了直接从工作副本提交到标签的工作,这正是Maven所做的。关于谁负责解决此问题,仍然存在很多争议。
我们可以执行" svn更新"并重新运行release命令,但是如果我们正在执行release:branch,则这将导致release插件不将POM文件恢复为之前的状态。
我知道最好的解决方法是退回到Subversion 1.5.0。
罗兰(Roland),如果我们尚未看到此内容,请查看约翰·斯玛特(John Smart)关于此问题的博客文章。尽管他提出的脚本不雅致,但可以解决问题:
http://weblogs.java.net/blog/johnsmart/archive/2008/12/subversion_mave.html
另一种解决方案是使用Git。 (我==目前正在撰写有关Maven和Git的文章)
可能有用的链接:
http://weblogs.java.net/blog/johnsmart/archive/2008/12/subversion_mave.html(以前提到)
http://jira.codehaus.org/browse/MRELEASE-427(真正的错误?)
http://jira.codehaus.org/browse/SCM-406(相关错误)
http://olafsblog.sysbsb.de/?p=73(较新的,也许是更有用的文章)
最新版本的maven-release-plugin中解决了此问题。将此添加到POM中以将其插入。
<build> <pluginManagement> <plugins> <plugin> <artifactId>maven-release-plugin</artifactId> <version>2.0-beta-9</version> </plugin> </plugins> </pluginManagement> </build>
已解决的问题是MRELEASE-375.
最新的插件版本2.0-beta-9中已修复此问题。