1
0
mirror of https://github.com/SAP/jenkins-library.git synced 2025-01-04 04:07:16 +02:00
sap-jenkins-library/vars/transportRequestCreate.groovy

226 lines
8.7 KiB
Groovy
Raw Normal View History

import static com.sap.piper.Prerequisites.checkScript
import com.sap.piper.Utils
2018-06-20 11:36:41 +02:00
import groovy.transform.Field
2019-03-28 11:05:54 +02:00
import com.sap.piper.GenerateDocumentation
import com.sap.piper.ConfigurationHelper
2018-09-25 09:12:07 +02:00
import com.sap.piper.cm.BackendType
2018-06-20 11:36:41 +02:00
import com.sap.piper.cm.ChangeManagement
import com.sap.piper.cm.ChangeManagementException
import static com.sap.piper.cm.StepHelpers.getBackendTypeAndLogInfoIfCMIntegrationDisabled
2018-06-20 11:36:41 +02:00
import static com.sap.piper.cm.StepHelpers.getChangeDocumentId
import hudson.AbortException
2018-06-20 11:36:41 +02:00
@Field def STEP_NAME = getClass().getName()
2018-06-20 11:36:41 +02:00
@Field GENERAL_CONFIG_KEYS = STEP_CONFIG_KEYS
@Field Set STEP_CONFIG_KEYS = [
'changeManagement',
2019-03-28 11:05:54 +02:00
/**
* @see checkChangeInDevelopment
* @parentConfigKey changeManagement
*/
'changeDocumentLabel',
/**
* Defines where the transport request is created, e.g. SAP Solution Manager, ABAP System.
* @parentConfigKey changeManagement
* @possibleValues `SOLMAN`, `CTS`, `RFC`
*/
'type',
/**
* @see checkChangeInDevelopment
* @parentConfigKey changeManagement
*/
'clientOpts',
/**
* @see checkChangeInDevelopment
* @parentConfigKey changeManagement
*/
'credentialsId',
/**
* @see checkChangeInDevelopment
* @parentConfigKey changeManagement
*/
'endpoint',
/**
* @see checkChangeInDevelopment
* @parentConfigKey changeManagement
*/
'git/from',
/**
* @see checkChangeInDevelopment
* @parentConfigKey changeManagement
*/
'git/to',
/**
* @see checkChangeInDevelopment
* @parentConfigKey changeManagement
*/
'git/format',
/**
* AS ABAP instance number. Only for `RFC`.
* @parentConfigKey changeManagement
*/
'rfc/developmentInstance',
/**
* AS ABAP client number. Only for `RFC`.
* @parentConfigKey changeManagement
*/
'rfc/developmentClient',
/**
* The logical system id for which the transport request is created.
* The format is `<SID>~<TYPE>(/<CLIENT>)?`. For ABAP Systems the `developmentSystemId`
* looks like `DEV~ABAP/100`. For non-ABAP systems the `developmentSystemId` looks like
* e.g. `L21~EXT_SRV` or `J01~JAVA`. In case the system type is not known (in the examples
* provided here: `EXT_SRV` or `JAVA`) the information can be retrieved from the Solution Manager instance.
* Only for `SOLMAN`.
*/
'developmentSystemId',
/**
* The description of the transport request. Only for `CTS`.
*/
'description',
/**
* The system receiving the transport request. Only for `CTS`.
*/
'targetSystem',
/**
* Typically `W` (workbench) or `C` customizing. Only for `CTS`.
*/
'transportType',
/**
* Provides additional details. Only for `RFC`.
*/
'verbose'
]
@Field Set PARAMETER_KEYS = STEP_CONFIG_KEYS.plus([
/** The id of the change document to that the transport request is bound to.
* Typically this value is provided via commit message in the commit history.
* Only for `SOLMAN`.
*/
'changeDocumentId'
])
/**
* Creates
*
* * a Transport Request for a Change Document on the Solution Manager (type `SOLMAN`) or
* * a Transport Request inside an ABAP system (type`CTS`)
*
* The id of the transport request is availabe via [commonPipelineEnvironment.getTransportRequestId()](commonPipelineEnvironment.md)
*/
@GenerateDocumentation
void call(parameters = [:]) {
2018-06-20 11:36:41 +02:00
def transportRequestId
2018-06-20 11:36:41 +02:00
handlePipelineStepErrors (stepName: STEP_NAME, stepParameters: parameters) {
def script = checkScript(this, parameters) ?: this
2018-06-20 11:36:41 +02:00
ChangeManagement cm = parameters.cmUtils ?: new ChangeManagement(script)
2018-06-20 11:36:41 +02:00
ConfigurationHelper configHelper = ConfigurationHelper.newInstance(this)
2019-02-14 13:01:28 +02:00
.collectValidationFailures()
.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)
2018-06-20 11:36:41 +02:00
2018-09-28 13:45:26 +02:00
Map configuration = configHelper.use()
BackendType backendType = getBackendTypeAndLogInfoIfCMIntegrationDisabled(this, configuration)
if(backendType == BackendType.NONE) return
2018-09-28 13:45:26 +02:00
configHelper
.withMandatoryProperty('changeManagement/clientOpts')
.withMandatoryProperty('changeManagement/credentialsId')
.withMandatoryProperty('changeManagement/endpoint')
.withMandatoryProperty('changeManagement/git/from')
.withMandatoryProperty('changeManagement/git/to')
.withMandatoryProperty('changeManagement/git/format')
2018-09-28 13:45:26 +02:00
.withMandatoryProperty('transportType', null, { backendType == BackendType.CTS})
.withMandatoryProperty('targetSystem', null, { backendType == BackendType.CTS})
.withMandatoryProperty('description', null, { backendType == BackendType.CTS})
.withMandatoryProperty('changeManagement/rfc/developmentInstance', null, {backendType == BackendType.RFC})
.withMandatoryProperty('changeManagement/rfc/developmentClient', null, {backendType == BackendType.RFC})
.withMandatoryProperty('verbose', null, {backendType == BackendType.RFC})
2018-09-25 09:12:07 +02:00
def changeDocumentId = null
2018-06-20 11:36:41 +02:00
new Utils().pushToSWA([
step: STEP_NAME,
stepParamKey1: 'scriptMissing',
stepParam1: parameters?.script == null
], configuration)
2018-09-25 09:12:07 +02:00
if(backendType == BackendType.SOLMAN) {
changeDocumentId = getChangeDocumentId(cm, script, configuration)
2018-09-25 09:12:07 +02:00
configHelper.mixin([changeDocumentId: changeDocumentId?.trim() ?: null], ['changeDocumentId'] as Set)
.withMandatoryProperty('developmentSystemId')
.withMandatoryProperty('changeDocumentId',
"Change document id not provided (parameter: \'changeDocumentId\' or via commit history).")
}
2018-06-20 11:36:41 +02:00
2018-09-25 09:12:07 +02:00
configuration = configHelper.use()
2018-06-20 11:36:41 +02:00
2018-09-25 09:12:07 +02:00
def creatingMessage = ["[INFO] Creating transport request"]
if(backendType == BackendType.SOLMAN) {
creatingMessage << " for change document '${configuration.changeDocumentId}' and development system '${configuration.developmentSystemId}'"
}
creatingMessage << '.'
echo creatingMessage.join()
2018-06-20 11:36:41 +02:00
2019-02-14 13:01:28 +02:00
try {
2018-09-25 09:12:07 +02:00
if(backendType == BackendType.SOLMAN) {
transportRequestId = cm.createTransportRequestSOLMAN(
configuration.changeManagement.solman.docker,
configuration.changeDocumentId,
configuration.developmentSystemId,
configuration.changeManagement.endpoint,
configuration.changeManagement.credentialsId,
configuration.changeManagement.clientOpts
)
2018-09-25 09:12:07 +02:00
} else if(backendType == BackendType.CTS) {
transportRequestId = cm.createTransportRequestCTS(
configuration.changeManagement.cts.docker,
configuration.transportType,
configuration.targetSystem,
configuration.description,
configuration.changeManagement.endpoint,
configuration.changeManagement.credentialsId,
configuration.changeManagement.clientOpts
)
} else if (backendType == BackendType.RFC) {
2019-02-11 11:52:47 +02:00
transportRequestId = cm.createTransportRequestRFC(
configuration.changeManagement.rfc.docker,
configuration.changeManagement.endpoint,
configuration.changeManagement.rfc.developmentInstance,
configuration.changeManagement.rfc.developmentClient,
configuration.changeManagement.credentialsId,
configuration.description,
configuration.verbose
)
2018-09-25 09:12:07 +02:00
} else {
throw new IllegalArgumentException("Invalid backend type: '${backendType}'.")
}
2018-06-20 11:36:41 +02:00
} catch(ChangeManagementException ex) {
throw new AbortException(ex.getMessage())
}
2018-06-20 11:36:41 +02:00
echo "[INFO] Transport Request '$transportRequestId' has been successfully created."
script.commonPipelineEnvironment.setValue('transportRequestId', "${transportRequestId}")
2018-06-20 11:36:41 +02:00
}
}