2018-06-20 11:36:41 +02:00
# transportRequestCreate
## Description
2018-11-06 14:50:09 +02:00
2018-09-28 10:00:59 +02:00
Creates
* a Transport Request for a Change Document on the Solution Manager (type `SOLMAN` ) or
* a Transport Request inside an ABAP system (type`CTS`)
2018-06-20 11:36:41 +02:00
## Prerequisites
2018-11-06 14:50:09 +02:00
2018-06-20 11:36:41 +02:00
* **[Change Management Client 2.0.0 or compatible version](http://central.maven.org/maven2/com/sap/devops/cmclient/dist.cli/)** - available for download on Maven Central.
## Parameters
2018-11-06 14:50:09 +02:00
2018-06-20 11:36:41 +02:00
| parameter | mandatory | default | possible values |
| -----------------|-----------|--------------------------------------------------------|--------------------|
| `script` | yes | | |
2018-09-28 10:00:59 +02:00
| `changeDocumentId` | for `SOLMAN` | | |
| `transportType` | for `CTS` | no | |
| `targetSystem` | for `CTS` | no | |
| `description` | for `CTS` | no | |
2018-07-17 09:21:56 +02:00
| `changeManagement/credentialsId` | yes | | |
| `changeManagement/endpoint` | yes | | |
| `changeManagement/clientOpts` | no | | |
| `changeManagement/git/from` | no | `origin/master` | |
| `changeManagement/git/to` | no | `HEAD` | |
| `changeManagement/changeDocumentLabel` | no | `ChangeDocument\s?:` | regex pattern |
| `changeManagement/git/format` | no | `%b` | see `git log --help` |
2018-09-28 10:00:59 +02:00
| `changeManagement/type` | no | `SOLMAN` | `SOLMAN` , `CTS` |
2018-06-20 11:36:41 +02:00
* `script` - The common script environment of the Jenkinsfile running. Typically the reference to the script calling the pipeline step is provided with the `this` parameter, as in `script: this` . This allows the function to access the [`commonPipelineEnvironment` ](commonPipelineEnvironment.md ) for retrieving, for example, configuration parameters.
2018-09-28 10:00:59 +02:00
* `changeDocumentId` - for `SOLMAN` only. 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.
* `changeManagement/type` Where/how the transport request is created (via SAP Solution Manager, ABAP).
* `changeManagement/credentialsId` - The credentials to connect to the service endpoint (Solution Manager, ABAP System).
* `changeManagement/endpoint` - The service endpoint (Solution Manager, ABAP System).
2018-07-17 09:21:56 +02:00
* `changeManagement/clientOpts` - Options forwarded to JVM used by the CM client, like `JAVA_OPTS`
* `changeManagement/git/from` - The starting point for retrieving the change document id
* `changeManagement/git/to` - The end point for retrieving the change document id
2018-09-28 10:00:59 +02:00
* `changeManagement/changeDocumentLabel` - For type `SOLMAN` only. A pattern used for identifying lines holding the change document id.
2018-07-17 09:21:56 +02:00
* `changeManagement/git/format` - Specifies what part of the commit is scanned. By default the body of the commit message is scanned.
2018-09-28 10:00:59 +02:00
* `description` - for `CTS` only. The description of the transport request.
* `targetSystem` - for `CTS` only. The system receiving the transport request.
* `transportType` - for type `CTS` only. Typically `W` (workbench) or `C` customizing.
2018-06-20 11:36:41 +02:00
## Step configuration
2018-11-06 14:50:09 +02:00
2018-07-17 09:21:56 +02:00
The step is configured using a customer configuration file provided as
resource in an custom shared library.
2018-06-20 11:36:41 +02:00
2018-11-06 14:50:09 +02:00
```groovy
2018-07-17 09:21:56 +02:00
@Library ('piper-library-os@master') _
// the shared lib containing the additional configuration
// needs to be configured in Jenkins
2018-11-06 14:50:09 +02:00
@Library ('foo@master') __
2018-07-17 09:21:56 +02:00
// inside the shared lib denoted by 'foo' the additional configuration file
// needs to be located under 'resources' ('resoures/myConfig.yml')
prepareDefaultValues script: this,
customDefaults: 'myConfig.yml'
```
2018-11-06 14:50:09 +02:00
Example content of `'resources/myConfig.yml'` in branch `'master'` of the repository denoted by
`'foo'` :
2018-07-17 09:21:56 +02:00
2018-11-06 14:50:09 +02:00
```yaml
2018-07-17 09:21:56 +02:00
general:
changeManagement:
changeDocumentLabel: 'ChangeDocument\s?:'
cmClientOpts: '-Djavax.net.ssl.trustStore=< path to truststore > '
credentialsId: 'CM'
2018-09-28 10:00:59 +02:00
type: 'SOLMAN'
2018-07-17 09:21:56 +02:00
endpoint: 'https://example.org/cm'
git:
from: 'HEAD~1'
to: 'HEAD'
format: '%b'
```
The properties configured in section `'general/changeManagement'` are shared between
all change managment related steps.
The properties can also be configured on a per-step basis:
2018-11-06 14:50:09 +02:00
```yaml
2018-07-17 09:21:56 +02:00
[...]
steps:
transportRequestCreate:
changeManagement:
2018-09-28 10:00:59 +02:00
type: 'SOLMAN'
2018-07-17 09:21:56 +02:00
endpoint: 'https://example.org/cm'
[...]
```
The parameters can also be provided when the step is invoked. For examples see below.
2018-06-20 11:36:41 +02:00
## Return value
2018-11-06 14:50:09 +02:00
2018-06-20 11:36:41 +02:00
The id of the Transport Request that has been created.
## Exceptions
2018-11-06 14:50:09 +02:00
2018-06-20 11:36:41 +02:00
* `AbortException` :
2018-11-06 14:50:09 +02:00
* If the creation of the transport request fails.
2018-07-17 09:21:56 +02:00
* `IllegalStateException` :
2018-11-06 14:50:09 +02:00
* If the change id is not provided.
2018-06-20 11:36:41 +02:00
## Example
2018-11-06 14:50:09 +02:00
2018-06-20 11:36:41 +02:00
```groovy
2018-09-28 10:00:59 +02:00
// SOLMAN
2018-07-17 09:21:56 +02:00
def transportRequestId = transportRequestCreate script:this,
changeDocumentId: '001,'
changeManagement: [
2018-09-28 10:00:59 +02:00
type: 'SOLMAN'
endpoint: 'https://example.org/cm'
]
// CTS
def transportRequestId = transportRequestCreate script:this,
transportType: 'W',
targetSystem: 'XYZ',
description: 'the description',
changeManagement: [
type: 'CTS'
2018-07-17 09:21:56 +02:00
endpoint: 'https://example.org/cm'
]
2018-06-20 11:36:41 +02:00
```