2016-11-25 70 views
1

我有一个项目document-scanner-aggregator在Maven 3.1.1运行时本地运行,即~/apache-maven-3.1.1/bin/mvn clean install,但不是on travis-ci.org,它检测到Maven 3.2.5,它可疑是由travis-ci.org提供的版本。但是它不应该这样做,因为运行构建的Maven版本应该被强制执行,对吧?为什么在travis-ci.org上运行3.1.1时,maven-enforcer-plugin会检测Maven 3.2.5?

故障是

[WARNING] Rule 0: org.apache.maven.plugins.enforcer.RequireMavenVersion failed with message: 
Detected Maven Version: 3.2.5 is not in the allowed range (,3.2). 
... 
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-enforcer-plugin:1.4:enforce (enforce-versions) on project javaocr-parent: Some Enforcer rules have failed. Look above for specific messages explaining why the rule failed. -> [Help 1] 

和配置是

<plugin> 
    <groupId>org.apache.maven.plugins</groupId> 
    <artifactId>maven-enforcer-plugin</artifactId> 
    <version>1.4</version> 
    <executions> 
     <execution> 
      <id>enforce-versions</id> 
      <goals> 
       <goal>enforce</goal> 
      </goals> 
      <configuration> 
       <rules> 
        <requireMavenVersion> 
         <!--different rules for different issues--> 
         <!--3.3.x causes `java.lang.NoClassDefFoundError: org/eclipse/aether/spi/connector/Transfer$State` which is caused by certain maven versions, see https://cwiki.apache.org/confluence/display/MAVEN/AetherClassNotFound for details--> 
         <version>(,3.3)</version> 
         <!--3.2.x causes `No implementation for org.eclipse.aether.connector.wagon.WagonConfigurator was bound.`--> 
         <version>(,3.2)</version> 
        </requireMavenVersion> 
       </rules> 
      </configuration> 
     </execution> 
    </executions> 
</plugin> 
javaocr

.travis.yml

language: java 
install: 
- wget http://mirrors.ae-online.de/apache/maven/maven-3/3.1.1/binaries/apache-maven-3.1.1-bin.tar.gz && tar xf apache-maven-3.1.1-bin.tar.gz 
- apache-maven-3.1.1/bin/mvn clean install 

回答

2

你误解了Enforcer Plugin的作用:

的强制实施插件提供目标,以控制某些环境的制约,如Maven的版本,JDK版本和操作系统家族以及更多的标准规则和用户创建的规则。

它的目标不是魔术,以便配置的规则被验证,但是当其中一个规则未被验证时,它的构建失败。换句话说,它会检查已配置规则的列表,以便在其中一个未验证的情况下构建无法继续。原因是如果构建的先决条件之一未得到满足,最好尽早失败。

就你的情况而言,requireMavenVersion规则强制使用严格低于3.2的Maven版本进行构建。如果您使用Maven 3.2.5运行构建,则不会生成新的Maven实例,以便验证规则;应该使用哪个版本,以及它在哪里获得它?相反,它检测到构建是使用不允许的Maven版本完成的,并相应地失败。由于Travis构建is configured to use Maven 3.2.5,它预计会失败,并且您需要为Travis构建安装低于3.2的Maven版本。

要使用不同的Maven版本,如3.1.1,在特拉维斯CI,你可以在.travis.yml如下:

before_install: 
    - wget http://mirrors.ae-online.de/apache/maven/maven-3/3.1.1/binaries/apache-maven-3.1.1-bin.tar.gz 
    - tar xf apache-maven-3.1.1-bin.tar.gz 
    - export M2_HOME=$PWD/apache-maven-3.1.1 
    - export PATH=$M2_HOME/bin:$PATH 

install: /bin/true 

script: mvn clean install 

作为一个侧面说明,你的

当前配置
<requireMavenVersion> 
    <version>(,3.3)</version> 
    <version>(,3.2)</version> 
</requireMavenVersion> 

是完全等效于

<requireMavenVersion> 
    <version>(,3.2)</version> 
</requireMavenVersion> 

范围(,3.2)means它匹配的版本严格低于3.2。因此,要求它严格低于3.3是多余的(因为3.2在3.3之前)。

+0

太棒了! '.travis.yml'做到了。我建议编辑答案,以便更快地获得关键信息,因为我有一种感觉,我不会成为最后一个问题。 –

相关问题