2018-06-22 13:56:33 +02:00
|
|
|
import org.junit.After
|
|
|
|
import org.junit.Rule
|
|
|
|
import org.junit.Test
|
|
|
|
import org.junit.rules.ExpectedException
|
|
|
|
import org.junit.rules.RuleChain
|
|
|
|
|
|
|
|
import com.sap.piper.GitUtils
|
|
|
|
import com.sap.piper.cm.ChangeManagement
|
|
|
|
import com.sap.piper.cm.ChangeManagementException
|
|
|
|
|
|
|
|
import hudson.AbortException
|
|
|
|
import util.BasePiperTest
|
2018-07-13 13:27:21 +02:00
|
|
|
import util.JenkinsCredentialsRule
|
2018-08-31 10:22:43 +02:00
|
|
|
import util.JenkinsReadYamlRule
|
2018-06-22 13:56:33 +02:00
|
|
|
import util.JenkinsStepRule
|
|
|
|
import util.Rules
|
|
|
|
|
|
|
|
class CheckChangeInDevelopmentTest extends BasePiperTest {
|
|
|
|
|
|
|
|
private ExpectedException thrown = ExpectedException.none()
|
|
|
|
private JenkinsStepRule jsr = new JenkinsStepRule(this)
|
|
|
|
|
|
|
|
@Rule
|
|
|
|
public RuleChain ruleChain = Rules
|
|
|
|
.getCommonRules(this)
|
2018-08-31 10:22:43 +02:00
|
|
|
.around(new JenkinsReadYamlRule(this))
|
2018-06-22 13:56:33 +02:00
|
|
|
.around(thrown)
|
|
|
|
.around(jsr)
|
2018-07-13 13:27:21 +02:00
|
|
|
.around(new JenkinsCredentialsRule(this)
|
2018-07-16 15:41:46 +02:00
|
|
|
.withCredentials('CM', 'anonymous', '********'))
|
2018-06-22 13:56:33 +02:00
|
|
|
|
|
|
|
@After
|
|
|
|
public void tearDown() {
|
|
|
|
cmUtilReceivedParams.clear()
|
|
|
|
}
|
|
|
|
|
|
|
|
private Map cmUtilReceivedParams = [:]
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void changeIsInStatusDevelopmentTest() {
|
|
|
|
|
|
|
|
ChangeManagement cm = getChangeManagementUtils(true)
|
|
|
|
boolean inDevelopment = jsr.step.checkChangeInDevelopment(
|
2018-09-21 16:55:31 +02:00
|
|
|
script: nullScript,
|
2018-06-22 13:56:33 +02:00
|
|
|
cmUtils: cm,
|
2018-07-17 09:21:56 +02:00
|
|
|
changeManagement: [endpoint: 'https://example.org/cm'])
|
2018-06-22 13:56:33 +02:00
|
|
|
|
|
|
|
assert inDevelopment
|
|
|
|
assert cmUtilReceivedParams == [
|
|
|
|
changeId: '001',
|
|
|
|
endpoint: 'https://example.org/cm',
|
2018-07-16 15:41:46 +02:00
|
|
|
credentialsId: 'CM',
|
2018-07-17 09:21:56 +02:00
|
|
|
cmclientOpts: ''
|
2018-06-22 13:56:33 +02:00
|
|
|
]
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void changeIsNotInStatusDevelopmentTest() {
|
|
|
|
|
|
|
|
thrown.expect(AbortException)
|
|
|
|
thrown.expectMessage("Change '001' is not in status 'in development'")
|
|
|
|
|
|
|
|
ChangeManagement cm = getChangeManagementUtils(false)
|
|
|
|
jsr.step.checkChangeInDevelopment(
|
2018-09-21 16:55:31 +02:00
|
|
|
script: nullScript,
|
2018-06-22 13:56:33 +02:00
|
|
|
cmUtils: cm,
|
2018-07-17 09:21:56 +02:00
|
|
|
changeManagement: [endpoint: 'https://example.org/cm'])
|
2018-06-22 13:56:33 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void changeIsNotInStatusDevelopmentButWeWouldLikeToSkipFailureTest() {
|
|
|
|
|
|
|
|
ChangeManagement cm = getChangeManagementUtils(false)
|
|
|
|
boolean inDevelopment = jsr.step.checkChangeInDevelopment(
|
2018-09-21 16:55:31 +02:00
|
|
|
script: nullScript,
|
2018-06-22 13:56:33 +02:00
|
|
|
cmUtils: cm,
|
2018-07-17 09:21:56 +02:00
|
|
|
changeManagement: [endpoint: 'https://example.org/cm'],
|
2018-06-22 13:56:33 +02:00
|
|
|
failIfStatusIsNotInDevelopment: false)
|
|
|
|
assert !inDevelopment
|
|
|
|
}
|
|
|
|
|
2018-07-10 11:09:20 +02:00
|
|
|
@Test
|
|
|
|
public void ifChangeIdPresentAsParameterAndFromCommitsChangeIdFromParameterIsUsedTest() {
|
|
|
|
ChangeManagement cm = getChangeManagementUtils(true, '0815')
|
|
|
|
|
|
|
|
jsr.step.checkChangeInDevelopment(
|
2018-09-21 16:55:31 +02:00
|
|
|
script: nullScript,
|
2018-07-10 11:09:20 +02:00
|
|
|
changeDocumentId: '42',
|
|
|
|
cmUtils: cm,
|
2018-07-17 09:21:56 +02:00
|
|
|
changeManagement: [endpoint: 'https://example.org/cm'])
|
2018-07-10 11:09:20 +02:00
|
|
|
|
|
|
|
assert cmUtilReceivedParams.changeId == '42'
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void ifChangeIdNotPresentAsParameterButFromCommitsChangeIdFromCommitsIsUsedTest() {
|
|
|
|
ChangeManagement cm = getChangeManagementUtils(true, '0815')
|
|
|
|
|
|
|
|
jsr.step.checkChangeInDevelopment(
|
2018-09-21 16:55:31 +02:00
|
|
|
script: nullScript,
|
2018-07-10 11:09:20 +02:00
|
|
|
cmUtils: cm,
|
2018-07-17 09:21:56 +02:00
|
|
|
changeManagement : [endpoint: 'https://example.org/cm'])
|
2018-07-10 11:09:20 +02:00
|
|
|
|
|
|
|
assert cmUtilReceivedParams.changeId == '0815'
|
|
|
|
}
|
|
|
|
|
2018-06-22 13:56:33 +02:00
|
|
|
@Test
|
|
|
|
public void changeDocumentIdRetrievalFailsTest() {
|
|
|
|
|
2018-07-19 10:26:34 +02:00
|
|
|
thrown.expect(IllegalArgumentException)
|
|
|
|
thrown.expectMessage("No changeDocumentId provided. Neither via parameter 'changeDocumentId' nor via " +
|
|
|
|
"label 'ChangeDocument\\s?:' in commit range [from: origin/master, to: HEAD].")
|
2018-06-22 13:56:33 +02:00
|
|
|
|
|
|
|
ChangeManagement cm = new ChangeManagement(nullScript, null) {
|
|
|
|
|
|
|
|
String getChangeDocumentId(
|
|
|
|
String filter,
|
|
|
|
String from,
|
|
|
|
String to,
|
|
|
|
String format) {
|
|
|
|
throw new ChangeManagementException('Something went wrong')
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
jsr.step.checkChangeInDevelopment(
|
2018-09-21 16:55:31 +02:00
|
|
|
script: nullScript,
|
2018-06-22 13:56:33 +02:00
|
|
|
cmUtils: cm,
|
2018-07-17 09:21:56 +02:00
|
|
|
changeManagement: [endpoint: 'https://example.org/cm'])
|
2018-06-22 13:56:33 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void nullChangeDocumentIdTest() {
|
|
|
|
|
2018-07-12 08:54:04 +02:00
|
|
|
thrown.expect(IllegalArgumentException)
|
|
|
|
thrown.expectMessage("No changeDocumentId provided. Neither via parameter 'changeDocumentId' " +
|
2018-07-17 10:08:47 +02:00
|
|
|
"nor via label 'ChangeDocument\\s?:' in commit range " +
|
2018-07-12 08:54:04 +02:00
|
|
|
"[from: origin/master, to: HEAD].")
|
2018-06-22 13:56:33 +02:00
|
|
|
|
|
|
|
ChangeManagement cm = getChangeManagementUtils(false, null)
|
|
|
|
jsr.step.checkChangeInDevelopment(
|
2018-09-21 16:55:31 +02:00
|
|
|
script: nullScript,
|
2018-06-22 13:56:33 +02:00
|
|
|
cmUtils: cm,
|
2018-07-17 09:21:56 +02:00
|
|
|
changeManagement: [endpoint: 'https://example.org/cm'])
|
2018-06-22 13:56:33 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void emptyChangeDocumentIdTest() {
|
|
|
|
|
2018-07-12 08:54:04 +02:00
|
|
|
thrown.expect(IllegalArgumentException)
|
|
|
|
thrown.expectMessage("No changeDocumentId provided. Neither via parameter 'changeDocumentId' " +
|
2018-07-17 10:08:47 +02:00
|
|
|
"nor via label 'ChangeDocument\\s?:' in commit range " +
|
2018-07-12 08:54:04 +02:00
|
|
|
"[from: origin/master, to: HEAD].")
|
2018-06-22 13:56:33 +02:00
|
|
|
|
|
|
|
ChangeManagement cm = getChangeManagementUtils(false, '')
|
|
|
|
jsr.step.checkChangeInDevelopment(
|
2018-09-21 16:55:31 +02:00
|
|
|
script: nullScript,
|
2018-06-22 13:56:33 +02:00
|
|
|
cmUtils: cm,
|
2018-07-17 09:21:56 +02:00
|
|
|
changeManagement: [endpoint: 'https://example.org/cm'])
|
2018-06-22 13:56:33 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
private ChangeManagement getChangeManagementUtils(boolean inDevelopment, String changeDocumentId = '001') {
|
|
|
|
|
|
|
|
return new ChangeManagement(nullScript, null) {
|
|
|
|
|
|
|
|
String getChangeDocumentId(
|
|
|
|
String filter,
|
|
|
|
String from,
|
|
|
|
String to,
|
|
|
|
String format) {
|
|
|
|
return changeDocumentId
|
|
|
|
}
|
|
|
|
|
2018-07-16 15:41:46 +02:00
|
|
|
boolean isChangeInDevelopment(String changeId, String endpoint, String credentialsId, String cmclientOpts) {
|
2018-06-22 13:56:33 +02:00
|
|
|
cmUtilReceivedParams.changeId = changeId
|
|
|
|
cmUtilReceivedParams.endpoint = endpoint
|
2018-07-16 15:41:46 +02:00
|
|
|
cmUtilReceivedParams.credentialsId = credentialsId
|
2018-06-25 12:37:33 +02:00
|
|
|
cmUtilReceivedParams.cmclientOpts = cmclientOpts
|
2018-06-22 13:56:33 +02:00
|
|
|
|
|
|
|
return inDevelopment
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|