使用 Maven/Hudson/Mercurial 进行发布

Posted

技术标签:

【中文标题】使用 Maven/Hudson/Mercurial 进行发布【英文标题】:Doing Releases with Maven/Hudson/Mercurial 【发布时间】:2012-01-24 16:26:02 【问题描述】:

我正在尝试通过 Maven 发布插件进行发布,但 SCM 配置存在问题。我正在使用安装了 m2eclipse 的 Eclipse。我们使用 Mercurial,在我的机器(Win7)上安装了 TortoiseHg。我有一个创建 jar 的测试项目。我们为我们的项目使用了一个超级 pom,所以测试项目 pom 也是如此。我已经在超级 pom 中设置了这个:

<build>
    <plugins>
        ....
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-scm-plugin
            <version>1.6</version>
            <configuration>
                <connectionType>connection</connectionType>
            </configuration>
        </plugin>
    </plugins>
</build>

我的测试项目 pom 如下所示:

<project xmlns="http://maven.apache.org/POM/4.0.0" 
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
        xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
        http://maven.apache.org/xsd/maven-4.0.0.xsd">

    <modelVersion>4.0.0</modelVersion>
    <groupId>my.group</groupId>
    <artifactId>TestJar
    <version>1.0-SNAPSHOT</version>
    <parent>       
        <groupId>my.group</groupId>
        <artifactId>super-pom</artifactId>
        <version>1.0</version>
    </parent>
    <scm>
        <connection>
            scm:hg:ssh://our.scm.server:22//path/to/TestJarProject
        </connection>
        <developerConnection>
            scm:hg:ssh://our.scm.server:22//path/to/TestJarProject
        </developerConnection>
    </scm>
</project>

请注意,我们通过 ssh 连接到我们的 SCM 服务器。我怀疑我遇到的一些问题与此有关。我只能找到使用 http 的示例。

在我的 settings.xml 文件中,我添加了这个:

<servers>
    ...
    <server>
        <id>our.scm.server</id>
        <username>username</username>
        <password>password</password>
    </server>
</servers>

当我运行 release:prepare release:perform 时,会弹出一个 TortoisePlink 对话框,提示我输入密码。对话框询问“@our.scm.server 的密码”。

它似乎没有使用 settings.xml 文件中的用户名或密码,这是我通过向其中添加服务器元素所期望的。应该是吗?我也尝试将我的用户名添加到连接 url:

<connection>
    scm:hg:ssh://username@our.scm.server:22//path/to/TestJarProject
</connection>

但仍提示输入空的用户名密码。

问题一

有没有人在进行 Maven 发布时成功使用 ssh 连接到 Mercurial?

由于我最终想在 Hudson 中进行构建,因此我设置了一个 Hudson 作业来进行发布,但它失败并出现以下错误:

[INFO] o.h.m.e.h.MavenExecutionResultHandler - Build failed with exception(s)
[INFO] o.h.m.e.h.MavenExecutionResultHandler - [1] org.apache.maven.lifecycle.\
   LifecycleExecutionException: Failed to execute goal org.apache.maven.plugins:\
   maven-release-plugin:2.0:prepare (default-cli) on project TestJar: Cannot \
   prepare the release because you have local modifications : 
[.maven/repo/ca/shaw/eng/nms/nms-super-pom/1.0/_maven.repositories:unknown]
[.maven/repo/ca/shaw/eng/nms/nms-super-pom/1.0/nms-super-pom-1.0.pom:unknown]
[.maven/repo/ca/shaw/eng/nms/nms-super-pom/1.0/nms-super-pom-1.0.pom.sha1:unknown]
... many, many more lines of this nature .....

问题二

Maven 遇到了哪些本地修改?

由于项目是从 repo 中提取的,我能想到的唯一更改是更新 pom 文件(从版本中删除 SNAPSHOT)。但是 Maven 不应该抱怨这一点,因为它自己做出了改变,不是吗?

更新

根据 khmarbaise 的建议,我已将此添加到我的父 POM:

<pluginManagement>
    <plugins>
        <plugin>
            <artifactId>maven-release-plugin</artifactId>
            <version>2.2.2</version>
        </plugin>
    </plugins>
</pluginManagement>

【问题讨论】:

首先在你的父母中做一个 pluginManagement 部分并配置一个新版本的 maven-release-plugin 因为你使用的是 2.0,它有点过时了......你使用哪个 Maven 版本?哈德森是最新的吗?使用 Hudson 的发布插件? 我们使用的是 Hudson 2.1.2 和 Maven 3(与 Hudson 捆绑) 您是否先检查过是否可以在没有 Hudson 的情况下在命令行上进行发布? (添加了 pluginManagement 部分?) 在我本地的 Win7 机器上,是的,我尝试使用 mvn -B release:prepare release:perform 进行命令行发布。 TortoisePlink 密码对话框在字符串中显示了我的用户名两次 它提示我输入我的密码 (usernam@our.scm.server's password),然后再次提示我输入密码 (@our.scm.server's password),它不能接受 (没有用户名)在我取消构建之前,我处于无限循环中。 【参考方案1】:

问题一

有没有人在进行 Maven 发布时成功使用 ssh 连接到 Mercurial?

答案似乎是 Maven 发布插件仅适用于 https。通常按照此页面上的说明,我们能够让 https 在我们的 Mercurial 服务器上运行:

https://www.mercurial-scm.org/wiki/HgWebDirStepByStep

问题二

Maven 遇到了哪些本地修改?

本地修改是在构建期间创建的.maven 目录。通过将.maven/* 添加到我的.hgignore 文件中,我能够完成构建。

【讨论】:

【参考方案2】:

我现在无法重现这一点,但根据之前的经验,我记得 ssh 连接适用于基于密钥的身份验证,而不适用于用户名和密码。这不一定特定于发布插件和/或其 Mercurial 支持。

编辑:我今天尝试使用 Mercurial 和发布插件版本 2.4.1 进行基于密钥的 ssh 访问,并且效果很好。一种可能的问题来源是 SCM URL 格式。在我的情况下是:

scm:hg:ssh://user@hostname.com/path

所以你的问题一的答案是:是的,但不是用户名/密码身份验证。我没有遇到任何“本地修改”问题,但我的 .hgignore 中有目标,所以可能就是这样。

【讨论】:

以上是关于使用 Maven/Hudson/Mercurial 进行发布的主要内容,如果未能解决你的问题,请参考以下文章

第一篇 用于测试使用

在使用加载数据流步骤的猪中,使用(使用 PigStorage)和不使用它有啥区别?

今目标使用教程 今目标任务使用篇

Qt静态编译时使用OpenSSL有三种方式(不使用,动态使用,静态使用,默认是动态使用)

MySQL db 在按日期排序时使用“使用位置;使用临时;使用文件排序”

使用“使用严格”作为“使用强”的备份