mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-18 05:18:24 +02:00
8a019f5b86
read yaml rule is a very frequently used rule. But having the rule in the common rules means we cannot register text or files to that rule, which makes it less handy to work with yaml files in the tests.
176 lines
5.9 KiB
Groovy
176 lines
5.9 KiB
Groovy
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
|
|
import util.JenkinsCredentialsRule
|
|
import util.JenkinsReadYamlRule
|
|
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)
|
|
.around(new JenkinsReadYamlRule(this))
|
|
.around(thrown)
|
|
.around(jsr)
|
|
.around(new JenkinsCredentialsRule(this)
|
|
.withCredentials('CM', 'anonymous', '********'))
|
|
|
|
@After
|
|
public void tearDown() {
|
|
cmUtilReceivedParams.clear()
|
|
}
|
|
|
|
private Map cmUtilReceivedParams = [:]
|
|
|
|
@Test
|
|
public void changeIsInStatusDevelopmentTest() {
|
|
|
|
ChangeManagement cm = getChangeManagementUtils(true)
|
|
boolean inDevelopment = jsr.step.checkChangeInDevelopment(
|
|
cmUtils: cm,
|
|
changeManagement: [endpoint: 'https://example.org/cm'])
|
|
|
|
assert inDevelopment
|
|
assert cmUtilReceivedParams == [
|
|
changeId: '001',
|
|
endpoint: 'https://example.org/cm',
|
|
credentialsId: 'CM',
|
|
cmclientOpts: ''
|
|
]
|
|
}
|
|
|
|
@Test
|
|
public void changeIsNotInStatusDevelopmentTest() {
|
|
|
|
thrown.expect(AbortException)
|
|
thrown.expectMessage("Change '001' is not in status 'in development'")
|
|
|
|
ChangeManagement cm = getChangeManagementUtils(false)
|
|
jsr.step.checkChangeInDevelopment(
|
|
cmUtils: cm,
|
|
changeManagement: [endpoint: 'https://example.org/cm'])
|
|
}
|
|
|
|
@Test
|
|
public void changeIsNotInStatusDevelopmentButWeWouldLikeToSkipFailureTest() {
|
|
|
|
ChangeManagement cm = getChangeManagementUtils(false)
|
|
boolean inDevelopment = jsr.step.checkChangeInDevelopment(
|
|
cmUtils: cm,
|
|
changeManagement: [endpoint: 'https://example.org/cm'],
|
|
failIfStatusIsNotInDevelopment: false)
|
|
assert !inDevelopment
|
|
}
|
|
|
|
@Test
|
|
public void ifChangeIdPresentAsParameterAndFromCommitsChangeIdFromParameterIsUsedTest() {
|
|
ChangeManagement cm = getChangeManagementUtils(true, '0815')
|
|
|
|
jsr.step.checkChangeInDevelopment(
|
|
changeDocumentId: '42',
|
|
cmUtils: cm,
|
|
changeManagement: [endpoint: 'https://example.org/cm'])
|
|
|
|
assert cmUtilReceivedParams.changeId == '42'
|
|
}
|
|
|
|
@Test
|
|
public void ifChangeIdNotPresentAsParameterButFromCommitsChangeIdFromCommitsIsUsedTest() {
|
|
ChangeManagement cm = getChangeManagementUtils(true, '0815')
|
|
|
|
jsr.step.checkChangeInDevelopment(
|
|
cmUtils: cm,
|
|
changeManagement : [endpoint: 'https://example.org/cm'])
|
|
|
|
assert cmUtilReceivedParams.changeId == '0815'
|
|
}
|
|
|
|
@Test
|
|
public void changeDocumentIdRetrievalFailsTest() {
|
|
|
|
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].")
|
|
|
|
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(
|
|
cmUtils: cm,
|
|
changeManagement: [endpoint: 'https://example.org/cm'])
|
|
}
|
|
|
|
@Test
|
|
public void nullChangeDocumentIdTest() {
|
|
|
|
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].")
|
|
|
|
ChangeManagement cm = getChangeManagementUtils(false, null)
|
|
jsr.step.checkChangeInDevelopment(
|
|
cmUtils: cm,
|
|
changeManagement: [endpoint: 'https://example.org/cm'])
|
|
}
|
|
|
|
@Test
|
|
public void emptyChangeDocumentIdTest() {
|
|
|
|
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].")
|
|
|
|
ChangeManagement cm = getChangeManagementUtils(false, '')
|
|
jsr.step.checkChangeInDevelopment(
|
|
cmUtils: cm,
|
|
changeManagement: [endpoint: 'https://example.org/cm'])
|
|
}
|
|
|
|
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
|
|
}
|
|
|
|
boolean isChangeInDevelopment(String changeId, String endpoint, String credentialsId, String cmclientOpts) {
|
|
cmUtilReceivedParams.changeId = changeId
|
|
cmUtilReceivedParams.endpoint = endpoint
|
|
cmUtilReceivedParams.credentialsId = credentialsId
|
|
cmUtilReceivedParams.cmclientOpts = cmclientOpts
|
|
|
|
return inDevelopment
|
|
}
|
|
}
|
|
}
|
|
}
|