mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-06 04:13:55 +02:00
fd568c9174
* do not swallow exception triggered inside SWA handling --> write it to the log The real change is in src/com/sap/piper/Utils.groovy All the changes in the tests are dealing with mocking the echo method used in the Utils class mentioned above.
213 lines
7.0 KiB
Groovy
213 lines
7.0 KiB
Groovy
import org.junit.Before
|
|
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.cm.BackendType
|
|
import com.sap.piper.cm.ChangeManagement
|
|
import com.sap.piper.cm.ChangeManagementException
|
|
import com.sap.piper.Utils
|
|
|
|
import hudson.AbortException
|
|
import util.BasePiperTest
|
|
import util.JenkinsCredentialsRule
|
|
import util.JenkinsLoggingRule
|
|
import util.JenkinsReadYamlRule
|
|
import util.JenkinsStepRule
|
|
import util.Rules
|
|
|
|
class CheckChangeInDevelopmentTest extends BasePiperTest {
|
|
|
|
private ExpectedException thrown = ExpectedException.none()
|
|
private JenkinsStepRule stepRule = new JenkinsStepRule(this)
|
|
private JenkinsLoggingRule loggingRule = new JenkinsLoggingRule(this)
|
|
|
|
@Rule
|
|
public RuleChain ruleChain = Rules
|
|
.getCommonRules(this)
|
|
.around(new JenkinsReadYamlRule(this))
|
|
.around(thrown)
|
|
.around(stepRule)
|
|
.around(loggingRule)
|
|
.around(new JenkinsCredentialsRule(this)
|
|
.withCredentials('CM', 'anonymous', '********'))
|
|
|
|
@Before
|
|
public void setup() {
|
|
Utils.metaClass.echo = { def m -> }
|
|
}
|
|
|
|
@After
|
|
public void tearDown() {
|
|
cmUtilReceivedParams.clear()
|
|
Utils.metaClass = null
|
|
}
|
|
|
|
private Map cmUtilReceivedParams = [:]
|
|
|
|
@Test
|
|
public void changeIsInStatusDevelopmentTest() {
|
|
|
|
ChangeManagement cm = getChangeManagementUtils(true)
|
|
stepRule.step.checkChangeInDevelopment(
|
|
script: nullScript,
|
|
cmUtils: cm,
|
|
changeManagement: [
|
|
type: 'SOLMAN',
|
|
endpoint: 'https://example.org/cm'],
|
|
failIfStatusIsNotInDevelopment: true)
|
|
|
|
assert cmUtilReceivedParams == [
|
|
docker: [
|
|
image: 'ppiper/cm-client',
|
|
options:[],
|
|
envVars:[:],
|
|
pullImage:true,
|
|
],
|
|
changeId: '001',
|
|
endpoint: 'https://example.org/cm',
|
|
credentialsId: 'CM',
|
|
cmclientOpts: ''
|
|
]
|
|
|
|
// no exception in thrown, so the change is in status 'in development'.
|
|
}
|
|
|
|
@Test
|
|
public void changeIsNotInStatusDevelopmentTest() {
|
|
|
|
thrown.expect(AbortException)
|
|
thrown.expectMessage("Change '001' is not in status 'in development'")
|
|
|
|
ChangeManagement cm = getChangeManagementUtils(false)
|
|
stepRule.step.checkChangeInDevelopment(
|
|
script: nullScript,
|
|
cmUtils: cm,
|
|
changeManagement: [type: 'SOLMAN',
|
|
endpoint: 'https://example.org/cm'])
|
|
}
|
|
|
|
@Test
|
|
public void changeIsNotInStatusDevelopmentButWeWouldLikeToSkipFailureTest() {
|
|
|
|
ChangeManagement cm = getChangeManagementUtils(false)
|
|
boolean inDevelopment = stepRule.step.checkChangeInDevelopment(
|
|
script: nullScript,
|
|
cmUtils: cm,
|
|
changeManagement: [endpoint: 'https://example.org/cm'],
|
|
failIfStatusIsNotInDevelopment: false)
|
|
assert !inDevelopment
|
|
}
|
|
|
|
@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')
|
|
}
|
|
}
|
|
|
|
stepRule.step.checkChangeInDevelopment(
|
|
script: nullScript,
|
|
cmUtils: cm,
|
|
changeManagement: [type: 'SOLMAN',
|
|
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)
|
|
stepRule.step.checkChangeInDevelopment(
|
|
script: nullScript,
|
|
cmUtils: cm,
|
|
changeManagement: [endpoint: 'https://example.org/cm',
|
|
type: 'SOLMAN'])
|
|
}
|
|
|
|
@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, '')
|
|
stepRule.step.checkChangeInDevelopment(
|
|
script: nullScript,
|
|
cmUtils: cm,
|
|
changeManagement: [type: 'SOLMAN',
|
|
endpoint: 'https://example.org/cm'])
|
|
}
|
|
|
|
@Test
|
|
public void cmIntegrationSwichtedOffTest() {
|
|
|
|
loggingRule.expect('[INFO] Change management integration intentionally switched off.')
|
|
|
|
stepRule.step.checkChangeInDevelopment(
|
|
script: nullScript,
|
|
changeManagement: [type: 'NONE'])
|
|
|
|
}
|
|
|
|
@Test
|
|
public void stageConfigIsNotConsideredWithParamKeysTest() {
|
|
|
|
nullScript.commonPipelineEnvironment.configuration = [stages:[foo:[changeDocumentId:'12345']]]
|
|
ChangeManagement cm = getChangeManagementUtils(true, '')
|
|
|
|
thrown.expect(IllegalArgumentException)
|
|
thrown.expectMessage('No changeDocumentId provided.')
|
|
|
|
stepRule.step.checkChangeInDevelopment(
|
|
script: nullScript,
|
|
cmUtils: cm,
|
|
changeManagement: [type: BackendType.SOLMAN,
|
|
endpoint: 'https://example.org/cm'],
|
|
stageName: 'foo')
|
|
}
|
|
|
|
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(Map docker, String changeId, String endpoint, String credentialsId, String cmclientOpts) {
|
|
cmUtilReceivedParams.docker = docker
|
|
cmUtilReceivedParams.changeId = changeId
|
|
cmUtilReceivedParams.endpoint = endpoint
|
|
cmUtilReceivedParams.credentialsId = credentialsId
|
|
cmUtilReceivedParams.cmclientOpts = cmclientOpts
|
|
|
|
return inDevelopment
|
|
}
|
|
}
|
|
}
|
|
}
|