1
0
mirror of https://github.com/SAP/jenkins-library.git synced 2025-01-04 04:07:16 +02:00
sap-jenkins-library/test/groovy/MailSendNotificationTest.groovy
Marcus Holl fd568c9174
do not swallow exception triggered inside SWA handling (#1839)
* 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.
2020-09-24 13:47:20 +02:00

248 lines
9.5 KiB
Groovy

import org.junit.After
import org.junit.Before
import org.junit.Rule
import org.junit.Test
import org.junit.rules.RuleChain
import util.*
import com.sap.piper.Utils
import static org.hamcrest.Matchers.*
import static org.junit.Assert.assertThat
class MailSendNotificationTest extends BasePiperTest {
private JenkinsLoggingRule loggingRule = new JenkinsLoggingRule(this)
private JenkinsStepRule stepRule = new JenkinsStepRule(this)
private JenkinsShellCallRule shellRule = new JenkinsShellCallRule(this)
@Rule
public RuleChain ruleChain = Rules
.getCommonRules(this)
.around(new JenkinsReadYamlRule(this))
.around(loggingRule)
.around(shellRule)
.around(stepRule)
@Before
void init() throws Exception {
// register Jenkins commands with mock values
helper.registerAllowedMethod("deleteDir", [], null)
helper.registerAllowedMethod("sshagent", [Map.class, Closure.class], null)
nullScript.commonPipelineEnvironment.configuration = nullScript.commonPipelineEnvironment.configuration ?: [:]
nullScript.commonPipelineEnvironment.configuration['general'] = nullScript.commonPipelineEnvironment.configuration['general'] ?: [:]
nullScript.commonPipelineEnvironment.configuration['steps'] = nullScript.commonPipelineEnvironment.configuration['steps'] ?: [:]
nullScript.commonPipelineEnvironment.configuration['steps']['mailSendNotification'] = nullScript.commonPipelineEnvironment.configuration['steps']['mailSendNotification'] ?: [:]
helper.registerAllowedMethod('requestor', [], { -> return [$class: 'RequesterRecipientProvider']})
Utils.metaClass.echo = { def m -> }
}
@After
public void tearDown() {
Utils.metaClass = null
}
@Test
void testGetDistinctRecipients() throws Exception {
// git log -10 --pretty=format:"%ae %ce"
def input = '''user1@domain.com noreply+github@domain.com
user1@domain.com noreply+github@domain.com
user3@domain.com noreply+github@domain.com
user2@domain.com user1@domain.com
user1@noreply.domain.com
user1@domain.com noreply+github@domain.com
user3@domain.com noreply+github@domain.com
user3@domain.com noreply+github@domain.com
user3@domain.com noreply+github@domain.com
user3@domain.com noreply+github@domain.com
user3@domain.com noreply+github@domain.com'''
def result = stepRule.step.getDistinctRecipients(input)
// asserts
assertThat(result.split(' '), arrayWithSize(3))
assertThat(result, containsString('user1@domain.com'))
assertThat(result, containsString('user2@domain.com'))
assertThat(result, containsString('user3@domain.com'))
}
@Test
void testCulpritsFromGitCommit() throws Exception {
def gitCommand = "git log -2 --first-parent --pretty=format:'%ae %ce'"
def expected = "user2@domain.com user3@domain.com"
shellRule.setReturnValue("git log -2 --first-parent --pretty=format:'%ae %ce'", 'user2@domain.com user3@domain.com')
def result = stepRule.step.getCulprits(
[
gitSSHCredentialsId: '',
gitUrl: 'git@github.domain.com:IndustryCloudFoundation/pipeline-test-node.git',
gitCommitId: 'f0973368a35a2b973612acb86f932c61f2635f6e'
],
'master',
2)
// asserts
assertThat(result, containsString('user2@domain.com'))
assertThat(result, containsString('user3@domain.com'))
}
@Test
void testCulpritsWithEmptyGitCommit() throws Exception {
shellRule.setReturnValue('git log > /dev/null 2>&1',1)
stepRule.step.getCulprits(
[
gitSSHCredentialsId: '',
gitUrl: 'git@github.domain.com:IndustryCloudFoundation/pipeline-test-node.git',
gitCommitId: ''
],
'master',
2)
// asserts
assertThat(loggingRule.log, containsString('[mailSendNotification] No git context available to retrieve culprits'))
}
@Test
void testCulpritsWithoutGitCommit() throws Exception {
shellRule.setReturnValue('git log > /dev/null 2>&1',1)
stepRule.step.getCulprits(
[
gitSSHCredentialsId: '',
gitUrl: 'git@github.domain.com:IndustryCloudFoundation/pipeline-test-node.git',
gitCommitId: null
],
'master',
2)
// asserts
assertThat(loggingRule.log, containsString('[mailSendNotification] No git context available to retrieve culprits'))
}
@Test
void testCulpritsWithoutBranch() throws Exception {
shellRule.setReturnValue('git log > /dev/null 2>&1',1)
stepRule.step.getCulprits(
[
gitSSHCredentialsId: '',
gitUrl: 'git@github.domain.com:IndustryCloudFoundation/pipeline-test-node.git',
gitCommitId: ''
],
null,
2)
// asserts
assertThat(loggingRule.log, containsString('[mailSendNotification] No git context available to retrieve culprits'))
}
@Test
void testSendNotificationMail() throws Exception {
def emailParameters = [:]
def buildMock = [
fullProjectName: 'testProjectName',
displayName: 'testDisplayName',
result: 'FAILURE',
rawBuild: [
getLog: { cnt -> return ['Setting http proxy: proxy.domain.com:8080',
' > git fetch --no-tags --progress https://github.com/SAP/jenkins-library.git +refs/heads/*:refs/remotes/origin/*',
'Checking out Revision myUniqueCommitId (master)',
' > git config core.sparsecheckout # timeout=10',
' > git checkout -f myUniqueCommitId',
'Commit message: "Merge pull request #147 from marcusholl/pr/useGitRevParseForInsideGitRepoCheck"',
' > git rev-list --no-walk myUniqueCommitId # timeout=10',
'[Pipeline] node',
'Running on Jenkins in /var/jenkins_home/workspace/Test/UserId/ECHO',
'[Pipeline] {',
'[Pipeline] stage',
'[Pipeline] { (A)',
'[Pipeline] script',
'[Pipeline] {']
}
],
getPreviousBuild: {
return null
}
]
nullScript.currentBuild = buildMock
nullScript.commonPipelineEnvironment.configuration['steps']['mailSendNotification']['notificationRecipients'] = 'piper@domain.com'
helper.registerAllowedMethod('emailext', [Map.class], { map ->
emailParameters = map
return ''
})
stepRule.step.mailSendNotification(
script: nullScript,
notifyCulprits: false,
gitUrl: 'git@github.domain.com:IndustryCloudFoundation/pipeline-test-node.git'
)
// asserts
assertThat(emailParameters.to, is('piper@domain.com'))
assertThat(emailParameters.subject, is('FAILURE: Build testProjectName testDisplayName'))
assertThat(emailParameters.body, startsWith('<a href="http://build.url">http://build.url</a>\n<br>\nTo have a detailed look at the different pipeline stages: <a href="null">null</a>\n<br>\n<h3>Last lines of output</h3>'))
assertThat(emailParameters.body, containsString(' > git fetch --no-tags --progress https://github.com/SAP/jenkins-library.git +refs/heads/*:refs/remotes/origin/*'))
assertJobStatusSuccess()
}
@Test
void testSendNotificationMailWithGeneralConfig() throws Exception {
def credentials
nullScript.currentBuild = [
fullProjectName: 'testProjectName',
displayName: 'testDisplayName',
result: 'FAILURE',
rawBuild: [ getLog: { cnt -> return ['empty'] } ],
getChangeSets: { return null },
getPreviousBuild: { return null }
]
nullScript.commonPipelineEnvironment.configuration['general']['gitSshKeyCredentialsId'] = 'myCredentialsId'
helper.registerAllowedMethod('emailext', [Map.class], null)
helper.registerAllowedMethod("sshagent", [Map.class, Closure.class], { map, closure ->
credentials = map.credentials
return null
})
shellRule.setReturnValue("git log -0 --pretty=format:'%ae %ce'", 'user2@domain.com user3@domain.com')
stepRule.step.mailSendNotification(
script: nullScript,
gitCommitId: 'abcd1234',
//notifyCulprits: true,
gitUrl: 'git@github.domain.com:IndustryCloudFoundation/pipeline-test-node.git'
)
// asserts
assertThat(credentials, hasItem('myCredentialsId'))
assertJobStatusSuccess()
}
@Test
void testSendNotificationMailWithEmptySshKey() throws Exception {
def credentials
nullScript.currentBuild = [
fullProjectName: 'testProjectName',
displayName: 'testDisplayName',
result: 'FAILURE',
rawBuild: [ getLog: { cnt -> return ['empty'] } ],
getChangeSets: { return null },
getPreviousBuild: { return null }
]
helper.registerAllowedMethod('emailext', [Map.class], null)
helper.registerAllowedMethod("sshagent", [Map.class, Closure.class], { map, closure ->
credentials = map.credentials
return null
})
shellRule.setReturnValue("git log -0 --pretty=format:'%ae %ce'", 'user2@domain.com user3@domain.com')
stepRule.step.mailSendNotification(
script: nullScript,
gitCommitId: 'abcd1234',
gitUrl: 'git@github.domain.com:IndustryCloudFoundation/pipeline-test-node.git'
)
// asserts
assertThat(credentials, hasItem(''))
assertJobStatusSuccess()
}
}