mirror of
https://github.com/SAP/jenkins-library.git
synced 2024-12-14 11:03:09 +02:00
127 lines
3.8 KiB
Groovy
127 lines
3.8 KiB
Groovy
|
#!groovy
|
||
|
import org.jenkinsci.plugins.workflow.steps.FlowInterruptedException
|
||
|
import org.junit.Rule
|
||
|
import org.junit.Test
|
||
|
import org.junit.rules.RuleChain
|
||
|
import util.*
|
||
|
|
||
|
import static org.hamcrest.CoreMatchers.containsString
|
||
|
import static org.hamcrest.CoreMatchers.is
|
||
|
import static org.junit.Assert.assertThat
|
||
|
|
||
|
class PipelineRestartStepsTest extends BasePiperTest {
|
||
|
|
||
|
private JenkinsErrorRule jer = new JenkinsErrorRule(this)
|
||
|
private JenkinsLoggingRule jlr = new JenkinsLoggingRule(this)
|
||
|
private JenkinsStepRule jsr = new JenkinsStepRule(this)
|
||
|
|
||
|
@Rule
|
||
|
public RuleChain chain = Rules.getCommonRules(this)
|
||
|
.around(new JenkinsReadYamlRule(this))
|
||
|
.around(jer)
|
||
|
.around(jlr)
|
||
|
.around(jsr)
|
||
|
|
||
|
@Test
|
||
|
void testError() throws Exception {
|
||
|
|
||
|
def mailBuildResult = ''
|
||
|
helper.registerAllowedMethod('mailSendNotification', [Map.class], { m ->
|
||
|
mailBuildResult = m.buildResult
|
||
|
return null
|
||
|
})
|
||
|
|
||
|
helper.registerAllowedMethod('timeout', [Map.class, Closure.class], { m, closure ->
|
||
|
assertThat(m.time, is(1))
|
||
|
assertThat(m.unit, is('SECONDS'))
|
||
|
return closure()
|
||
|
})
|
||
|
|
||
|
def iterations = 0
|
||
|
helper.registerAllowedMethod('input', [Map.class], { m ->
|
||
|
iterations ++
|
||
|
assertThat(m.message, is('Do you want to restart?'))
|
||
|
assertThat(m.ok, is('Restart'))
|
||
|
if (iterations > 1) {
|
||
|
throw new FlowInterruptedException()
|
||
|
} else {
|
||
|
return null
|
||
|
}
|
||
|
})
|
||
|
|
||
|
try {
|
||
|
jsr.step.pipelineRestartSteps ([
|
||
|
script: nullScript,
|
||
|
jenkinsUtilsStub: jenkinsUtils,
|
||
|
sendMail: true,
|
||
|
timeoutInSeconds: 1
|
||
|
|
||
|
]) {
|
||
|
throw new hudson.AbortException('I just created an error')
|
||
|
}
|
||
|
} catch(err) {
|
||
|
assertThat(jlr.log, containsString('ERROR occured: hudson.AbortException: I just created an error'))
|
||
|
assertThat(mailBuildResult, is('UNSTABLE'))
|
||
|
}
|
||
|
}
|
||
|
|
||
|
@Test
|
||
|
void testErrorNoMail() throws Exception {
|
||
|
|
||
|
def mailBuildResult = ''
|
||
|
helper.registerAllowedMethod('mailSendNotification', [Map.class], { m ->
|
||
|
mailBuildResult = m.buildResult
|
||
|
return null
|
||
|
})
|
||
|
|
||
|
helper.registerAllowedMethod('timeout', [Map.class, Closure.class], { m, closure ->
|
||
|
assertThat(m.time, is(1))
|
||
|
assertThat(m.unit, is('SECONDS'))
|
||
|
return closure()
|
||
|
})
|
||
|
|
||
|
def iterations = 0
|
||
|
helper.registerAllowedMethod('input', [Map.class], { m ->
|
||
|
iterations ++
|
||
|
assertThat(m.message, is('Do you want to restart?'))
|
||
|
assertThat(m.ok, is('Restart'))
|
||
|
if (iterations > 1) {
|
||
|
throw new FlowInterruptedException()
|
||
|
} else {
|
||
|
return null
|
||
|
}
|
||
|
})
|
||
|
|
||
|
try {
|
||
|
jsr.step.pipelineRestartSteps ([
|
||
|
script: nullScript,
|
||
|
jenkinsUtilsStub: jenkinsUtils,
|
||
|
sendMail: false,
|
||
|
timeoutInSeconds: 1
|
||
|
|
||
|
]) {
|
||
|
throw new hudson.AbortException('I just created an error')
|
||
|
}
|
||
|
} catch(err) {
|
||
|
assertThat(jlr.log, containsString('ERROR occured: hudson.AbortException: I just created an error'))
|
||
|
assertThat(mailBuildResult, is(''))
|
||
|
}
|
||
|
}
|
||
|
|
||
|
@Test
|
||
|
void testSuccess() throws Exception {
|
||
|
|
||
|
jsr.step.pipelineRestartSteps ([
|
||
|
script: nullScript,
|
||
|
jenkinsUtilsStub: jenkinsUtils,
|
||
|
sendMail: false,
|
||
|
timeoutInSeconds: 1
|
||
|
|
||
|
]) {
|
||
|
nullScript.echo 'This is a test'
|
||
|
}
|
||
|
|
||
|
assertThat(jlr.log, containsString('This is a test'))
|
||
|
}
|
||
|
}
|