job-dsl生成的Jenkins作业没有获取默认的Maven设置

时间:2017-02-23 16:16:27

标签: jenkins maven-3 jenkins-job-dsl

我在Windows Server 2012上运行Jenkins 2.25服务器。目前我们正在使用Maven Integration Plugin 2.12.1和Job DSL Plugin 1.57。

我已在我们的服务器上为大约200个现有作业编写了DSL脚本。

对于任何使用Maven的作业,无论是作为构建步骤还是作为实际的Maven,我都有一个非常令人沮丧的问题。当我运行生成的作业时,它们会失败并显示以下输出。

12:17:12 [ERROR] Failed to execute goal com.googlecode.maven-download-    plugin:download-maven-plugin:1.3.0:wget (default) on project myprojecy: The     parameters 'url' for goal com.googlecode.maven-download-plugin:download-maven-plugin:1.3.0:wget are missing or invalid -> [Help 1]
12:17:12 [ERROR] 
12:17:12 [ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
12:17:12 [ERROR] Re-run Maven using the -X switch to enable full debug logging.
12:17:12 [ERROR] 
12:17:12 [ERROR] For more information about the errors and possible solutions, please read the following articles:
12:17:12 [ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/PluginParameterException

最初我们认为我们发现这个问题是因为我们错过了XML片段,甚至认为这些设置看起来就像它们应该在UI中一样。

<settings class="jenkins.mvn.DefaultSettingsProvider"/> 
<globalSettings class="jenkins.mvn.DefaultGlobalSettingsProvider"/> 
<injectBuildVariables>false</injectBuildVariables>

因此将其添加到脚本中:

configure { node ->
node / settings (class: 'jenkins.mvn.DefaultSettingsProvider') {
}
node / globalSettings (class: 'jenkins.mvn.DefaultGlobalSettingsProvider') {
}
node / injectBuildVariables ('false') {
}
}

但是当我尝试运行它们时,作业仍然失败,即使XML现在包含了预期的片段。

现在我能解决的两件非常离奇的事情显而易见。首先,在作业失败后,如果我手动选择&#34;配置&#34;为了工作,然后保存它(即不做任何实际的改变),工作永远运行良好(直到种子工作我们运行然后它再次失败)。

其次,在运行种子作业后的作业配置历史记录中,我看到种子作业在系统用户下运行时所做的更改。但是,在几秒钟内,每次都会在我的用户名下记录另一个配置更改,尽管事实上我没有对作业配置进行任何更改 - 顺便说一句,这与我保存作业无关,它立即发生。

我应该补充一点,进一步的检查告诉我,Maven有一些默认设置没有应用于我生成的DSL作业。将-X开关添加到Maven目标时,我可以看到有关这些作业失败的更多信息。输出是:

 15:06:31 [DEBUG] Goal:          com.googlecode.maven-download-plugin:download-maven-plugin:1.3.0:wget (default) 
 15:06:31 [DEBUG] Style:         Regular 
 15:06:31 [DEBUG] Configuration: <?xml version="1.0" encoding="UTF-8"?> 
 15:06:31 <configuration> 
 15:06:31   <cacheDirectory>${download.cache.directory}</cacheDirectory> 
 15:06:31   <checkSignature default-value="false">${checkSignature}</checkSignature> 
 15:06:31   <failOnError default-value="true"/> 
 15:06:31   <outputDirectory default-value="${project.build.directory}">D:\data\jenkins\workspace\project\target</outputDirectory> 
 15:06:31   <outputFileName>${jarsigner.keystore.filename}</outputFileName> 
 15:06:31   <overwrite>${download.overwrite}</overwrite> 
 15:06:31   <readTimeOut default-value="0"/> 
 15:06:31   <retries default-value="2"/> 
 15:06:31   <session>${session}</session> 
 15:06:31   <skip default-value="false">${download.plugin.skip}</skip> 
 15:06:31   <skipCache default-value="false"/> 
 15:06:31   <unpack default-value="false">false</unpack> 
 15:06:31   <url>${jarsigner.keystore.url}</url> 
 15:06:31 </configuration>

在成功运行作业(发布虚假配置更改)的情况下,其中一些字段已满,例如密钥库的URL。这显然是个问题,但我不知道该怎么做。我可以告诉你这应该通过在groovy中包含上面的配置块来解决,但不知何故我的工作缺少这个(但他们在再次保存作业后没有更改)。

谁能看到我在这里做错了什么?

1 个答案:

答案 0 :(得分:2)

问题是XML中的代码是自动生成的:

<jvmOptions></jvmOptions>

似乎尽管是空的,但这会覆盖任何默认的Maven选项,但是当作业再次保存时,它会被取出,因为它是空的。通过将其添加到groovy脚本解决:

configure({
            it.remove(it / 'jvmOptions')
        })

这似乎是DSL中的一个错误,但令我惊讶的是我的同事和我一直无法找到任何提及。无论如何,以上解决了这个问题。