mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-18 05:18:24 +02:00
7feaa36868
* Add new config mtarName for mtaBuild step * Remove unnecessary whitespace changes in unit test * Sort new config & avoid file operation when this config provided * Modify the test to take the custom name without extension * Update new config documentation Co-Authored-By: Christopher Fenner <26137398+CCFenner@users.noreply.github.com> * custom mta name should be given with mtar extension * Updated the config documentation
181 lines
7.5 KiB
Groovy
181 lines
7.5 KiB
Groovy
import static com.sap.piper.Prerequisites.checkScript
|
|
|
|
import com.sap.piper.GenerateDocumentation
|
|
import com.sap.piper.ConfigurationHelper
|
|
import com.sap.piper.MtaUtils
|
|
import com.sap.piper.Utils
|
|
import groovy.transform.Field
|
|
|
|
import static com.sap.piper.Utils.downloadSettingsFromUrl
|
|
|
|
@Field def STEP_NAME = getClass().getName()
|
|
|
|
@Field Set GENERAL_CONFIG_KEYS = []
|
|
@Field Set STEP_CONFIG_KEYS = [
|
|
/** The name of the application which is being built. If the parameter has been provided and no `mta.yaml` exists, the `mta.yaml` will be automatically generated using this parameter and the information (`name` and `version`) from `package.json` before the actual build starts.*/
|
|
'applicationName',
|
|
/**
|
|
* mtaBuildTool classic only: The target platform to which the mtar can be deployed.
|
|
* @possibleValues 'CF', 'NEO', 'XSA'
|
|
*/
|
|
'buildTarget',
|
|
/**
|
|
* Tool to use when building the MTA
|
|
* @possibleValues 'classic', 'cloudMbt'
|
|
*/
|
|
'mtaBuildTool',
|
|
/** @see dockerExecute */
|
|
'dockerImage',
|
|
/** @see dockerExecute */
|
|
'dockerEnvVars',
|
|
/** @see dockerExecute */
|
|
'dockerOptions',
|
|
/** @see dockerExecute */
|
|
'dockerWorkspace',
|
|
/** The path to the extension descriptor file.*/
|
|
'extension',
|
|
/**
|
|
* The location of the SAP Multitarget Application Archive Builder jar file, including file name and extension.
|
|
* If you run on Docker, this must match the location of the jar file in the container as well.
|
|
*/
|
|
'mtaJarLocation',
|
|
/** Path or url to the mvn settings file that should be used as global settings file.*/
|
|
'globalSettingsFile',
|
|
/** The name of the generated mtar file including its extension. */
|
|
'mtarName',
|
|
/**
|
|
* mtaBuildTool cloudMbt only: The target platform to which the mtar can be deployed.
|
|
* @possibleValues 'CF', 'NEO', 'XSA'
|
|
*/
|
|
'platform',
|
|
/** Path or url to the mvn settings file that should be used as project settings file.*/
|
|
'projectSettingsFile'
|
|
]
|
|
@Field Set PARAMETER_KEYS = STEP_CONFIG_KEYS.plus([
|
|
/** Url to the npm registry that should be used for installing npm dependencies.*/
|
|
'defaultNpmRegistry'
|
|
])
|
|
|
|
/**
|
|
* Executes the SAP Multitarget Application Archive Builder to create an mtar archive of the application.
|
|
*/
|
|
@GenerateDocumentation
|
|
void call(Map parameters = [:]) {
|
|
handlePipelineStepErrors(stepName: STEP_NAME, stepParameters: parameters) {
|
|
|
|
final script = checkScript(this, parameters) ?: this
|
|
|
|
// load default & individual configuration
|
|
Map configuration = ConfigurationHelper.newInstance(this)
|
|
.loadStepDefaults()
|
|
.mixinGeneralConfig(script.commonPipelineEnvironment, GENERAL_CONFIG_KEYS)
|
|
.mixinStepConfig(script.commonPipelineEnvironment, STEP_CONFIG_KEYS)
|
|
.mixinStageConfig(script.commonPipelineEnvironment, parameters.stageName ?: env.STAGE_NAME, STEP_CONFIG_KEYS)
|
|
.mixin(parameters, PARAMETER_KEYS)
|
|
.dependingOn('mtaBuildTool').mixin('dockerImage')
|
|
.use()
|
|
|
|
new Utils().pushToSWA([
|
|
step: STEP_NAME,
|
|
stepParamKey1: 'scriptMissing',
|
|
stepParam1: parameters?.script == null
|
|
], configuration)
|
|
|
|
dockerExecute(
|
|
script: script,
|
|
dockerImage: configuration.dockerImage,
|
|
dockerEnvVars: configuration.dockerEnvVars,
|
|
dockerOptions: configuration.dockerOptions,
|
|
dockerWorkspace: configuration.dockerWorkspace
|
|
) {
|
|
|
|
String projectSettingsFile = configuration.projectSettingsFile?.trim()
|
|
if (projectSettingsFile) {
|
|
if (projectSettingsFile.startsWith("http")) {
|
|
projectSettingsFile = downloadSettingsFromUrl(this, projectSettingsFile, 'project-settings.xml')
|
|
}
|
|
sh 'mkdir -p $HOME/.m2'
|
|
sh "cp ${projectSettingsFile} \$HOME/.m2/settings.xml"
|
|
}
|
|
|
|
String globalSettingsFile = configuration.globalSettingsFile?.trim()
|
|
if (globalSettingsFile) {
|
|
if (globalSettingsFile.startsWith("http")) {
|
|
globalSettingsFile = downloadSettingsFromUrl(this, globalSettingsFile, 'global-settings.xml')
|
|
}
|
|
sh "cp ${globalSettingsFile} \$M2_HOME/conf/settings.xml"
|
|
}
|
|
|
|
String defaultNpmRegistry = configuration.defaultNpmRegistry?.trim()
|
|
if (defaultNpmRegistry) {
|
|
sh "npm config set registry $defaultNpmRegistry"
|
|
}
|
|
|
|
def mtaYamlName = "mta.yaml"
|
|
def applicationName = configuration.applicationName
|
|
|
|
if (!fileExists(mtaYamlName)) {
|
|
if (!applicationName) {
|
|
error "'${mtaYamlName}' not found in project sources and 'applicationName' not provided as parameter - cannot generate '${mtaYamlName}' file."
|
|
} else {
|
|
echo "[INFO] '${mtaYamlName}' file not found in project sources, but application name provided as parameter - generating '${mtaYamlName}' file."
|
|
MtaUtils mtaUtils = new MtaUtils(this)
|
|
mtaUtils.generateMtaDescriptorFromPackageJson("package.json", mtaYamlName, applicationName)
|
|
}
|
|
} else {
|
|
echo "[INFO] '${mtaYamlName}' file found in project sources."
|
|
}
|
|
|
|
//[Q]: Why not yaml.dump()? [A]: This reformats the whole file.
|
|
sh "sed -ie \"s/\\\${timestamp}/`date +%Y%m%d%H%M%S`/g\" \"${mtaYamlName}\""
|
|
|
|
def mtaCall
|
|
def options = []
|
|
|
|
String mtarName = configuration.mtarName?.trim()
|
|
if (!mtarName) {
|
|
def mtaId = getMtaId(mtaYamlName)
|
|
mtarName = "${mtaId}.mtar"
|
|
}
|
|
options.push("--mtar ${mtarName}")
|
|
|
|
switch(configuration.mtaBuildTool) {
|
|
case 'classic':
|
|
// If it is not configured, it is expected on the PATH
|
|
def mtaJar = configuration.mtaJarLocation ?: 'mta.jar'
|
|
options.push("--build-target=${configuration.buildTarget}")
|
|
if (configuration.extension) options.push("--extension=${configuration.extension}")
|
|
mtaCall = "java -jar ${mtaJar} ${options.join(' ')} build"
|
|
break
|
|
case 'cloudMbt':
|
|
options.push("--platform ${configuration.platform}")
|
|
options.push("--target ./")
|
|
if (configuration.extension) options.push("--extensions=${configuration.extension}")
|
|
mtaCall = "mbt build ${options.join(' ')}"
|
|
break
|
|
default:
|
|
error "[ERROR][${STEP_NAME}] MTA build tool '${configuration.mtaBuildTool}' not supported!"
|
|
}
|
|
|
|
echo "[INFO] Executing mta build call: '${mtaCall}'."
|
|
|
|
//[Q]: Why extending the path? [A]: To be sure e.g. grunt can be found
|
|
//[Q]: Why escaping \$PATH ? [A]: We want to extend the PATH variable in e.g. the container and not substituting it with the Jenkins environment when using ${PATH}
|
|
sh """#!/bin/bash
|
|
export PATH=./node_modules/.bin:\$PATH
|
|
$mtaCall
|
|
"""
|
|
|
|
script?.commonPipelineEnvironment?.setMtarFilePath("${mtarName}")
|
|
}
|
|
}
|
|
}
|
|
|
|
def String getMtaId(String fileName){
|
|
def mtaYaml = readYaml file: fileName
|
|
if (!mtaYaml.ID) {
|
|
error "Property 'ID' not found in ${fileName} file."
|
|
}
|
|
return mtaYaml.ID
|
|
}
|