如何阻止 Jenkins 中的 CI 构建意外发布到发布存储库?

use*_*061 3 maven-3 maven jenkins jenkins-plugins

有时,开发人员会不小心签入 POM 中没有“SNAPSHOT”的版本。这将构建 Maven 项目并将工件发布到发布存储库。我怎样才能避免这种情况呢?我只想发布构建工件以发布存储库,而不是 CI 构建。

我考虑了以下问题 - 但它们都不是一个简单的一步解决方案

  • 编写一个预提交挂钩来检查版本是否已由除允许进行发布构建的管理员之外的任何人在没有快照的情况下签入;
  • 修改Jenkins作业,查看构建是否是CI构建;然后 grep 查找版本,如果版本不是快照版本,则会出错。为此我需要修改数百个作业。

Tun*_*aki 5

解决这个问题的一个好的解决方案是利用Maven Enforcer 插件

更新至1.4.2

从版本 1.4.2 开始(尚未发布,请参阅增强请求MENFORCER-204),有一个新requireSnapshotVersion规则,强制正在构建的项目具有快照版本。

<plugin>
  <artifactId>maven-enforcer-plugin</artifactId>
  <version>1.4.2</version>
  <executions>
    <execution>
      <id>enforce-snapshot</id>
      <goals>
        <goal>enforce</goal>
      </goals>
      <configuration>
        <rules>
          <requireSnapshotVersion/>
        </rules>
        <fail>${fail.if.release}</fail>
      </configuration>
    </execution>
  </executions>
</plugin>
Run Code Online (Sandbox Code Playgroud)

编写自定义规则

直到1.4.1版本,如果当前项目是SNAPSHOT版本,没有内置的失败规则,但我们仍然可以使用该evaluateBeanshell规则。

这个想法是让构建失败,因为该版本默认不是快照版本。当当前项目处于发布状态时,禁用该规则。

为此,您可以在 POM 中包含以下内容:

<plugin>
  <artifactId>maven-enforcer-plugin</artifactId>
  <version>1.4.1</version>
  <executions>
    <execution>
      <id>enforce-beanshell</id>
      <goals>
        <goal>enforce</goal>
      </goals>
      <configuration>
        <rules>
          <evaluateBeanshell>
            <condition>"${project.version}".endsWith("-SNAPSHOT")</condition>
          </evaluateBeanshell>
        </rules>
        <fail>${fail.if.release}</fail>
      </configuration>
    </execution>
  </executions>
</plugin>
Run Code Online (Sandbox Code Playgroud)

它的作用是执行一个评估项目版本的BeanShell脚本。如果以 结束,-SNAPSHOT则规则通过,否则,规则失败并且构建结束。确定版本是否是快照。(快照版本的严格规则更加复杂,但这应该涵盖所有用例)。因此,这样的规则将验证正在构建的项目是否具有快照版本。


上面的两个配置都将 Maven 属性声明为

<property>
  <fail.if.release>true</fail.if.release>
</property>
Run Code Online (Sandbox Code Playgroud)

当在 SNAPSHOT 版本上运行时,它们将使您的构建失败mvn deploy,确保没有 SNAPSHOT 被意外部署到发布存储库。

然后,在执行发布时需要禁用该规则。为此,我们可以定义一个release配置文件来禁用已定义的规则:

<profile>
  <id>release</id>
  <properties>
    <fail.if.release>false</fail.if.release>
  </properties>
</profile>
Run Code Online (Sandbox Code Playgroud)

并在发布时激活该配置文件

mvn release:prepare release:perform -Darguments="-Prelease"
Run Code Online (Sandbox Code Playgroud)