Especially in company environments where you have your own artifact managers like Nexus or Artifactory for caching and storage you want to provide project based global and local settings.
To make this easier the execMaven
step provides autolookup based on
- ManagedFiles and the
- PatternMatching algorithm
This can of course be done by wrapping the sh
step inside a
configFileProvider
step and define all necessary managed files here
but this can be quite anoying and it makes it difficult to maintain the
scripts and configurations in a large CI environment.
This step removes some complexity from your scripty providing automatically
- global maven settings
- local maven settings
- NPM configuration
- Ruby Bundler configuration
It also takes care about the command line building by transforming the
given configuration into a sh
step call.
- Managed file auto lookup
- Examples
- Configuration options
- Related classes
The managed file auto lookup is the core functionality of the
execMaven
step. It reduces the amount of time that must be spend for
configuring maven builds in larger environments to a minimum.
If you provide a JSON file at this location
resources/managedfiles/maven/global-settings.json
in the format
described in ManagedFiles the step will
automatically try to lookup the global settings for the provided scm url
and use them
This step uses the best match by using the
PatternMatcher
so the ManagedFile
with the most matching characters will be used as
global setting.
When no global setting was found the command line parameter will be omitted.
Given a company with a GIT server at https://git.company.tld
, a global
maven setting with id company-global-maven-setting
stored inside
Jenkins as ManagedFile and we assume that all projects should use this
per default.
When you setup your own pipeline library which uses the pipeline-library
all you have to do is to create
resources/managedfiles/maven/global-settings.json
with this content:
[
{
"pattern": "git.company.tld",
"id": "company-global-maven-setting",
"name": "Company global maven settings",
"comment": "Global maven settings for nexus.company.tld"
}
]
When you now execute the execMaven
step with
execMaven(
scm : [ url: 'https://git.company.tld/group/project.git' ],
maven : [ goals: ['clean', 'install'] ]
)
Maven will be executed with this commandline: mvn clean install --global-settings '/path/to/temporary/managed-global-settings-file'
The local settings mechanism works the same way as the global maven settings but with an other json file containing the definitions.
Local Maven settings are useful when you have project specific credentials on your artifact server.
If you provide a JSON file at this location
resources/managedfiles/maven/settings.json
in the format
described in ManagedFiles the step will
automatically try to lookup the settings for the provided scm url
and use them
This step uses the best match by using the
PatternMatcher
so the ManagedFile
with the most matching characters will be used as
global setting.
When no local setting was found the command line parameter will be omitted.
Given a company with a GIT server at https://git.company.tld
, a local
maven setting with id group1-project1-local-maven-setting
stored
inside Jenkins as ManagedFile.
When you setup your own pipeline library which uses the pipeline-library
all you have to do is to create
resources/managedfiles/maven/settings.json
with this content:
[
{
"pattern": "git.company.tld/group1/project1",
"id": "group1-project1-local-maven-setting",
"name": "group1, project1 local maven msettings",
"comment": "Local maven settings to deploy group1/project1 artifacts to nexus.company.tld"
}
]
When you now execute the execMaven
Step with
execMaven(
scm : [ url: 'https://git.company.tld/group1/project1.git' ],
maven : [ goals: ['clean', 'install'] ]
)
Maven will be executed with this commandline: mvn clean install --settings '/path/to/temporary/managed-group1-project1-settings-file'
If you are using node.js/NPM to build frontend stuff within your maven
projects you can use the execMaven
step to automatically provide
- managed configuration file to
NPM_CONFIG_USER_CONFIG
environment variable - managed configuration file to
NPMRC
environment variable
Given a company with a GIT server at https://git.company.tld
, a npmrc
setting with id group1-project1-npmrc
and a npm config with id
group1-project1-npm-config
stored inside Jenkins as ManagedFile.
When you setup your own pipeline library which uses the pipeline-library
all you have to do is to create the file
resources/managedfiles/npm/npmrc.json
with this content:
[
{
"pattern": "git.company.tld/group1/project1",
"id": "group1-project1-npmrc",
"name": "group1, project1 npmrc",
"comment": "npmrc for group1/project1"
}
]
and a file resources/managedfiles/npm/npm-config-userconfig.json
with
this content:
[
{
"pattern": "git.company.tld/group1/project1",
"id": "group1-project1-npm-config",
"name": "group1, project1 npm config",
"comment": "npmrc for group1/project1"
}
]
When you now execute the execMaven
Step with
import static io.wcm.devops.jenkins.pipeline.utils.ConfigConstants.*
execMaven(
(SCM) : [ (SCM_URL) : 'https://git.company.tld/group1/project1.git' ],
(MAVEN) : [ (MAVEN_GOALS) : ['clean', 'install'] ]
)
Maven will be executed with this commandline: mvn clean install
and for the duration of the execution the managed files are
available in these environment variables
NPMRC
NPM_CONFIG_USER_CONFIG
The execMaven
is also able to provide npm bundler configuration as
environment variable BUNDLE_CONFIG
during the execution of maven.
Given a company with a GIT server at https://git.company.tld
and a ruby
bundler setting with id group1-project1-bundle-config
stored inside Jenkins as ManagedFile.
When you setup your own pipeline library which uses the pipeline-library
all you have to do is to create the file
resources/managedfiles/ruby/bundle-config.json
with this content:
[
{
"pattern": "git.company.tld/group1/project1",
"id": "group1-project1-bundle-config",
"name": "group1, project1 ruby bundler config",
"comment": "ruby bundler config for group1/project1"
}
]
When you now execute the execMaven
Step with
import static io.wcm.devops.jenkins.pipeline.utils.ConfigConstants.*
execMaven(
(SCM) : [ (SCM_URL) : 'https://git.company.tld/group1/project1.git' ],
(MAVEN) : [ (MAVEN_GOALS): ['clean', 'install'] ]
)
Maven will be executed with this commandline: mvn clean install
and for the duration of the execution the managed file is
available in this environment variable
BUNDLE_CONFIG
The UI version of the maven execution step supports the use of build parameters as defines.
The execMaven
also supports this functionality by simply enabling this functionality.
import static io.wcm.devops.jenkins.pipeline.utils.ConfigConstants.*
execMaven(
(MAVEN): [
(MAVEN_GOALS) : ["clean", "install"],
(MAVEN_DEFINES) : ["continuousIntegration": true, "flag": null],
(MAVEN_INJECT_PARAMS) : true,
(MAVEN_ARGUMENTS) : ["-B", "-U"]
]
)
Enabling MAVEN_INJECT_PARAMS
will add all existing builds parameters
from the global params
Map object to the maven defines.
import static io.wcm.devops.jenkins.pipeline.utils.ConfigConstants.*
execMaven(
(MAVEN): [
(MAVEN_POM) : "path/to/customPom1.xml",
(MAVEN_GOALS) : ["clean", "install"],
(MAVEN_DEFINES) : ["continuousIntegration": true, "flag": null],
(MAVEN_GLOBAL_SETTINGS) : "global-settings-id",
(MAVEN_SETTINGS) : "local-settings-id",
(MAVEN_ARGUMENTS) : ["-B", "-U"]
]
)
The resulting shell
command will look like:
mvn -f path/to/customPom1.xml clean install -B -U
-Dcontinuous-integration=true -Dflag --global-settings
/path/to/job@tmp/config4417403508849619324tmp --settings
/path/to/job@tmp/config838306283686660309tmp
💡 In this example the auto lookup for global and local maven
settings is omitted because globalSettings
and localSettings
were provided
import static io.wcm.devops.jenkins.pipeline.utils.ConfigConstants.*
execMaven(
(MAVEN) : [
(MAVEN_GOALS) : ["clean", "install"]
]
)
Assuming that no global and local settings were provided for auto lookup
mechanism The resulting shell
command will look like:
mvn clean install
import static io.wcm.devops.jenkins.pipeline.utils.ConfigConstants.*
execMaven(
(MAVEN) : [:]
)
Assuming that no global and local settings were provided for auto lookup
mechanism The resulting shell
command will look like:
mvn
import static io.wcm.devops.jenkins.pipeline.utils.ConfigConstants.*
execMaven(
(MAVEM): [
(MAVEN_ARGUMENTS) : ["--version"]
]
)
Assuming that no global and local settings were provided for auto lookup
mechanism The resulting shell
command will look like:
mvn --version
Complete list of all configuration options.
All configuration options must be inside the maven
(ConfigConstants.MAVEN
)
map element to be evaluated and used by the step.
import static io.wcm.devops.jenkins.pipeline.utils.ConfigConstants.*
execMaven(
(MAVEN) : [
(MAVEN_ARGUMENTS): [ "-B", "-U" ],
(MAVEN_DEFINES): ["name": "value", "flag": null],
(MAVEN_EXECUTABLE): "/path/to/maven/bin",
(MAVEN_GLOBAL_SETTINGS): "managed-file-id",
(MAVEN_GOALS): ["goal1", "goal2"],
(MAVEN_INJECT_PARAMS): false,
(MAVEN_POM): "/path/to/pom.xml",
(MAVEN_PROFILES): ["profile1", "profile2"],
(MAVEN_SETTINGS): "managed-file-id",
]
)
Constant | ConfigConstants.MAVEN_ARGUMENTS |
Type | List of String or String |
Default | null |
Additional arguments for maven. Can be a List of
String` like
[ "-B", "-U" ]
or a String
like:
"-B -U"
Constant | ConfigConstants.MAVEN_DEFINES |
Type | Map or String |
Default | null |
Defines for maven. Can be a Map
like
["name": "value", "flag": null]
or a String
like:
"-Dname=value -Dflag"
Constant | ConfigConstants.MAVEN_EXECUTABLE |
Type | String |
Default | mvn |
Defines the command for maven.
You can specify the path to a custom mavn installation with this option like
[ maven: [ executable: "/path/to/maven" ] ]
Constant | ConfigConstants.MAVEN_GLOBAL_SETTINGS |
Type | String |
Default | null |
When provided the auto lookup mechanism for global maven settings is omitted and the step tries to retrieve a managed file with the provided value.
Constant | ConfigConstants.MAVEN_GOALS |
Type | List of String , or String |
Default | null |
The maven goals. Can be a List of
String` like
[ "goal1", "goal2" ]
or a String
like:
"goal1 goal2"
Constant | ConfigConstants.MAVEN_INJECT_PARAMS |
Type | Boolean |
Default | false |
When set to true the current build parameters are injected as defines to the maven command line.
💡 The defines defined by MAVEN_DEFINES
will not be overwritten
when using MAVEN_INJECT_PARAMS
Constant | ConfigConstants.MAVEN_POM |
Type | String |
Default | null |
Path to maven pom. When configuration is provided maven will be executed
without a path to a pom, so maven will look for a pom.xml
in the
current working directory
Constant | ConfigConstants.MAVEN_PROFILES |
Type | String or List<String> |
Default | [] |
Maven profiles to use.
Constant | ConfigConstants.MAVEN_SETTINGS |
Type | String |
Default | null |
When provided the auto lookup mechanism for local maven settings is omitted and the step tries to retrieve a managed file with the provided value.