2018-06-20 11:36:41 +02:00
|
|
|
import org.junit.Before
|
|
|
|
import org.junit.Rule
|
|
|
|
import org.junit.Test
|
|
|
|
import org.junit.rules.ExpectedException
|
|
|
|
import org.junit.rules.RuleChain
|
|
|
|
|
2018-09-25 09:12:07 +02:00
|
|
|
import com.sap.piper.cm.BackendType
|
2018-06-29 09:34:46 +02:00
|
|
|
import com.sap.piper.cm.ChangeManagement
|
|
|
|
import com.sap.piper.cm.ChangeManagementException
|
|
|
|
|
2018-06-20 11:36:41 +02:00
|
|
|
import util.BasePiperTest
|
2018-07-13 13:27:21 +02:00
|
|
|
import util.JenkinsCredentialsRule
|
2018-06-20 11:36:41 +02:00
|
|
|
import util.JenkinsStepRule
|
|
|
|
import util.JenkinsLoggingRule
|
2018-08-31 10:22:43 +02:00
|
|
|
import util.JenkinsReadYamlRule
|
2018-06-20 11:36:41 +02:00
|
|
|
import util.Rules
|
|
|
|
|
|
|
|
import hudson.AbortException
|
|
|
|
|
|
|
|
public class TransportRequestCreateTest extends BasePiperTest {
|
|
|
|
|
|
|
|
private ExpectedException thrown = new ExpectedException()
|
|
|
|
private JenkinsStepRule jsr = new JenkinsStepRule(this)
|
|
|
|
private JenkinsLoggingRule jlr = new JenkinsLoggingRule(this)
|
|
|
|
|
|
|
|
@Rule
|
|
|
|
public RuleChain ruleChain = Rules.getCommonRules(this)
|
2018-08-31 10:22:43 +02:00
|
|
|
.around(new JenkinsReadYamlRule(this))
|
2018-06-20 11:36:41 +02:00
|
|
|
.around(thrown)
|
|
|
|
.around(jsr)
|
|
|
|
.around(jlr)
|
2018-07-13 13:27:21 +02:00
|
|
|
.around(new JenkinsCredentialsRule(this)
|
|
|
|
.withCredentials('CM', 'anonymous', '********'))
|
2018-06-20 11:36:41 +02:00
|
|
|
|
|
|
|
@Before
|
|
|
|
public void setup() {
|
|
|
|
|
|
|
|
|
2018-07-17 09:21:56 +02:00
|
|
|
nullScript.commonPipelineEnvironment.configuration = [general:
|
|
|
|
[changeManagement:
|
2018-07-16 15:41:46 +02:00
|
|
|
|
2018-06-20 11:36:41 +02:00
|
|
|
[
|
2018-06-28 16:24:14 +02:00
|
|
|
credentialsId: 'CM',
|
2018-09-28 14:06:06 +02:00
|
|
|
type: 'SOLMAN',
|
2018-06-29 13:38:41 +02:00
|
|
|
endpoint: 'https://example.org/cm',
|
2018-07-17 09:21:56 +02:00
|
|
|
clientOpts: '-DmyProp=myVal',
|
|
|
|
changeDocumentLabel: 'ChangeId\\s?:',
|
|
|
|
git: [from: 'origin/master',
|
|
|
|
to: 'HEAD',
|
|
|
|
format: '%b']
|
2018-06-20 11:36:41 +02:00
|
|
|
]
|
|
|
|
]
|
|
|
|
]
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void changeIdNotProvidedTest() {
|
|
|
|
|
2018-07-12 08:54:04 +02:00
|
|
|
thrown.expect(IllegalArgumentException)
|
2018-07-13 09:28:41 +02:00
|
|
|
thrown.expectMessage("Change document id not provided (parameter: 'changeDocumentId' or via commit history).")
|
2018-07-10 14:43:15 +02:00
|
|
|
ChangeManagement cm = new ChangeManagement(nullScript) {
|
|
|
|
String getChangeDocumentId(
|
|
|
|
String from,
|
|
|
|
String to,
|
|
|
|
String label,
|
|
|
|
String format
|
|
|
|
) {
|
|
|
|
throw new ChangeManagementException('Cannot retrieve changeId from git commits.')
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-07 12:45:38 +02:00
|
|
|
jsr.step.transportRequestCreate(script: nullScript, developmentSystemId: '001', cmUtils: cm)
|
2018-06-20 11:36:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void developmentSystemIdNotProvidedTest() {
|
|
|
|
|
2018-07-12 08:54:04 +02:00
|
|
|
thrown.expect(IllegalArgumentException)
|
|
|
|
thrown.expectMessage("ERROR - NO VALUE AVAILABLE FOR developmentSystemId")
|
2018-06-20 11:36:41 +02:00
|
|
|
|
2018-11-07 12:45:38 +02:00
|
|
|
jsr.step.transportRequestCreate(script: nullScript, changeDocumentId: '001')
|
2018-06-20 11:36:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void createTransportRequestFailureTest() {
|
|
|
|
|
2018-06-29 09:34:46 +02:00
|
|
|
ChangeManagement cm = new ChangeManagement(nullScript) {
|
|
|
|
|
2018-09-25 09:12:07 +02:00
|
|
|
String createTransportRequestSOLMAN(
|
|
|
|
String changeId,
|
2018-06-29 09:34:46 +02:00
|
|
|
String developmentSystemId,
|
|
|
|
String cmEndpoint,
|
2018-07-16 15:41:46 +02:00
|
|
|
String credentialId,
|
2018-06-29 13:38:41 +02:00
|
|
|
String clientOpts) {
|
2018-06-29 09:34:46 +02:00
|
|
|
|
|
|
|
throw new ChangeManagementException('Exception message.')
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-06-20 11:36:41 +02:00
|
|
|
|
|
|
|
thrown.expect(AbortException)
|
2018-06-29 09:34:46 +02:00
|
|
|
thrown.expectMessage("Exception message.")
|
2018-06-20 11:36:41 +02:00
|
|
|
|
2018-11-07 12:45:38 +02:00
|
|
|
jsr.step.transportRequestCreate(script: nullScript, changeDocumentId: '001', developmentSystemId: '001', cmUtils: cm)
|
2018-06-20 11:36:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
2018-09-25 09:12:07 +02:00
|
|
|
public void createTransportRequestSuccessSOLMANTest() {
|
2018-06-20 11:36:41 +02:00
|
|
|
|
2018-06-29 09:34:46 +02:00
|
|
|
def result = [:]
|
|
|
|
|
|
|
|
ChangeManagement cm = new ChangeManagement(nullScript) {
|
|
|
|
|
2018-09-25 09:12:07 +02:00
|
|
|
String createTransportRequestSOLMAN(
|
|
|
|
String changeId,
|
2018-06-29 09:34:46 +02:00
|
|
|
String developmentSystemId,
|
|
|
|
String cmEndpoint,
|
2018-07-16 15:41:46 +02:00
|
|
|
String credentialId,
|
2018-06-29 13:38:41 +02:00
|
|
|
String clientOpts) {
|
2018-06-29 09:34:46 +02:00
|
|
|
|
|
|
|
result.changeId = changeId
|
|
|
|
result.developmentSystemId = developmentSystemId
|
|
|
|
result.cmEndpoint = cmEndpoint
|
2018-07-16 15:41:46 +02:00
|
|
|
result.credentialId = credentialId
|
2018-06-29 13:38:41 +02:00
|
|
|
result.clientOpts = clientOpts
|
2018-06-29 09:34:46 +02:00
|
|
|
return '001'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-07 12:45:38 +02:00
|
|
|
def transportId = jsr.step.transportRequestCreate(script: nullScript, changeDocumentId: '001', developmentSystemId: '001', cmUtils: cm)
|
2018-06-20 11:36:41 +02:00
|
|
|
|
2018-06-29 09:34:46 +02:00
|
|
|
assert transportId == '001'
|
|
|
|
assert result == [changeId: '001',
|
|
|
|
developmentSystemId: '001',
|
|
|
|
cmEndpoint: 'https://example.org/cm',
|
2018-07-16 15:41:46 +02:00
|
|
|
credentialId: 'CM',
|
2018-06-29 13:38:41 +02:00
|
|
|
clientOpts: '-DmyProp=myVal'
|
2018-06-29 09:34:46 +02:00
|
|
|
]
|
2018-06-20 11:36:41 +02:00
|
|
|
|
|
|
|
assert jlr.log.contains("[INFO] Creating transport request for change document '001' and development system '001'.")
|
|
|
|
assert jlr.log.contains("[INFO] Transport Request '001' has been successfully created.")
|
|
|
|
}
|
2018-09-25 09:12:07 +02:00
|
|
|
|
|
|
|
@Test
|
|
|
|
public void createTransportRequestSuccessCTSTest() {
|
|
|
|
|
|
|
|
def result = [:]
|
|
|
|
|
|
|
|
ChangeManagement cm = new ChangeManagement(nullScript) {
|
|
|
|
|
|
|
|
String createTransportRequestCTS(
|
|
|
|
String transportType,
|
|
|
|
String targetSystemId,
|
|
|
|
String description,
|
|
|
|
String endpoint,
|
|
|
|
String credentialsId,
|
|
|
|
String clientOpts
|
|
|
|
) {
|
|
|
|
result.transportType = transportType
|
|
|
|
result.targetSystemId = targetSystemId
|
|
|
|
result.description = description
|
|
|
|
result.endpoint = endpoint
|
|
|
|
result.credentialsId = credentialsId
|
|
|
|
result.clientOpts = clientOpts
|
|
|
|
return '001'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-07 12:45:38 +02:00
|
|
|
def transportId = jsr.step.transportRequestCreate(script: nullScript,
|
2018-09-25 09:12:07 +02:00
|
|
|
transportType: 'W',
|
|
|
|
targetSystem: 'XYZ',
|
|
|
|
description: 'desc',
|
|
|
|
changeManagement: [type: 'CTS'],
|
|
|
|
cmUtils: cm)
|
|
|
|
|
|
|
|
assert transportId == '001'
|
|
|
|
assert result == [transportType: 'W',
|
|
|
|
targetSystemId: 'XYZ',
|
|
|
|
description: 'desc',
|
|
|
|
endpoint: 'https://example.org/cm',
|
|
|
|
credentialsId: 'CM',
|
|
|
|
clientOpts: '-DmyProp=myVal'
|
|
|
|
]
|
|
|
|
|
|
|
|
assert jlr.log.contains("[INFO] Creating transport request.")
|
|
|
|
assert jlr.log.contains("[INFO] Transport Request '001' has been successfully created.")
|
|
|
|
}
|
|
|
|
|
2018-09-28 13:45:26 +02:00
|
|
|
@Test
|
|
|
|
public void cmIntegrationSwichtedOffTest() {
|
|
|
|
|
|
|
|
jlr.expect('[INFO] Change management integration intentionally switched off.')
|
|
|
|
|
2018-11-07 12:45:38 +02:00
|
|
|
jsr.step.transportRequestCreate(script: nullScript,
|
2018-09-28 13:45:26 +02:00
|
|
|
changeManagement: [type: 'NONE'])
|
|
|
|
}
|
2018-06-20 11:36:41 +02:00
|
|
|
}
|