使用 Maven 发布插件时无法标记 SCM

Posted

技术标签:

【中文标题】使用 Maven 发布插件时无法标记 SCM【英文标题】:Unable to tag SCM when I using maven release plugin 【发布时间】:2012-10-09 10:42:22 【问题描述】:

我在使用maven发布插件的时候,遇到了一些问题,最常见的是tag scm failed,错误是: svn: “svn://192.168.5.222/show/test-show/trunk/show” 不在版本 0 中。

at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:213)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:153)
at org.apache.maven.lifecycle.internal.MojoExecutor.execute(MojoExecutor.java:145)
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:84)
at org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject(LifecycleModuleBuilder.java:59)
at org.apache.maven.lifecycle.internal.LifecycleStarter.singleThreadedBuild(LifecycleStarter.java:183)
at org.apache.maven.lifecycle.internal.LifecycleStarter.execute(LifecycleStarter.java:161)
at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:320)
at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:156)
at org.jvnet.hudson.maven3.launcher.Maven3Launcher.main(Maven3Launcher.java:79)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.codehaus.plexus.classworlds.launcher.Launcher.launchStandard(Launcher.java:329)
at org.codehaus.plexus.classworlds.launcher.Launcher.launch(Launcher.java:239)
at org.jvnet.hudson.maven3.agent.Maven3Main.launch(Maven3Main.java:158)
at hudson.maven.Maven3Builder.call(Maven3Builder.java:98)
at hudson.maven.Maven3Builder.call(Maven3Builder.java:64)
at hudson.remoting.UserRequest.perform(UserRequest.java:118)
at hudson.remoting.UserRequest.perform(UserRequest.java:48)
at hudson.remoting.Request$2.run(Request.java:326)
at hudson.remoting.InterceptingExecutorService$1.call(InterceptingExecutorService.java:72)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
at java.util.concurrent.FutureTask.run(FutureTask.java:138)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
at java.lang.Thread.run(Thread.java:662)

原因:org.apache.maven.plugin.MojoFailureException: Unable to tag SCM

然后我找到了我的日志:

[INFO] 执行中:/bin/sh -c cd /data/.hudson/jobs/hxbos/workspace && svn --username liulaixi --password '*' --no-auth -cache --non-interactive copy --file /tmp/maven-scm-49732292.commit --revision 0 svn://192.168.5.213/hxbos/hxecp-src/trunk/hxbos svn://192.168.5.213/ hxbos/hxecp-src/tags/hxbos/hxbos-all-test-1.5.0 [INFO] 工作目录:/data/.hudson/jobs/hxbos/workspace

为什么我的--revision 是0?谁能帮帮我?谢谢!

【问题讨论】:

你在 svn 中有 ../tags 文件夹吗? Maven pom.xml 中的 SCM url 是否正确? 感谢您的回复,我的svn中有tags文件夹,我不知道为什么svn copy命令使用修订版0。我当前的修订版是4865,但是根据日志,maven版本插件使用了修订版 0。这就是问题所在。日志: [INFO] 执行:/bin/sh -c cd /data/.hudson/jobs/hxbos/workspace && svn --username liulaixi --password '*' --no-auth-cache --非交互式复制 --file /tmp/maven-scm-49732292.commit --revision 0 svn://192.168.5.213/hxbos/hxecp-src/trunk/hxbos svn://192.168.5.213/hxbos/ hxecp-src/tags/hxbos/hxbos-all-test-1.5.0 [INFO] 工作目录:/data/.hudson/jobs/hxbos/workspace 【参考方案1】:

问题是你没有正确的 svn 版本。检查安装最新版本并针对您的环境进行设置。如果正确,mvn 将能够在上传 pom.xml 后读取此信息,并以此标记发布。

【讨论】:

【参考方案2】:

尝试将“tagBase”配置添加到您的 pom.xml:

<plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-release-plugin</artifactId>
                <version>2.2.2</version>
                <configuration>
                    <tagBase>https://svn.site.net.br/svn/SiteV6/Vitrine</tagBase>
                </configuration>
            </plugin>

【讨论】:

【参考方案3】:

我犯了一个错误,我只检查了 trunk(没有 tagsbranches)。

对我来说:svn-repository 存储在/svn/ 中。 Apache 有 DAV svn 支持 &lt;connection&gt; 标签(不确定我们是否需要 DAV)配置如下:

<Location /svn>
  DAV svn
  SVNPath /svn
</Location>

pom.xml 里面:

<scm>
    <url>http://www.myproject.com/svn/Project</url>
    <connection>scm:svn:http://www.myproject.com/Project</connection>
    <developerConnection>scm:svn:svn+ssh://root@www.myproject.com/Project</developerConnection>
</scm>

那我做

svn co file:///svn/Project
cd Project/trunk/
eval `ssh-agent -s`
ssh-add   ~/mykey-to-commit-new-tag.ossh
mvn package gpg:sign
svn commit
mvn clean release:prepare release:perform -Darguments="-DskipTests -Dmaven.javadoc.failOnError=false" -X

我真正要做的是检查整个项目。

【讨论】:

【参考方案4】:

您是否尝试忽略此错误并再次尝试 mvn release:prepare?对我来说它有效。不过不要问我为什么。

【讨论】:

以上是关于使用 Maven 发布插件时无法标记 SCM的主要内容,如果未能解决你的问题,请参考以下文章

Maven 发布插件。无法标记分支

无法使用发布插件标记问题

带有 git 存储库的 Maven 发布插件忽略 scm.user scm.password

如何在 Maven 发布插件中设置 SCM 标签?

maven的scm插件介绍及使用示例

Maven 版本/scm 标签/Plexus DirectoryScanner 中的无限递归错误?