mirror of
https://github.com/SAP/jenkins-library.git
synced 2024-12-12 10:55:20 +02:00
166 lines
5.6 KiB
Groovy
166 lines
5.6 KiB
Groovy
import com.sap.piper.DefaultValueCache
|
|
import com.sap.piper.analytics.InfluxData
|
|
|
|
import org.junit.Before
|
|
import org.junit.Rule
|
|
import org.junit.Test
|
|
import org.junit.rules.RuleChain
|
|
import util.BasePiperTest
|
|
import util.JenkinsLoggingRule
|
|
import util.JenkinsStepRule
|
|
import util.JenkinsReadYamlRule
|
|
import util.Rules
|
|
|
|
import static org.hamcrest.Matchers.allOf
|
|
import static org.hamcrest.Matchers.containsString
|
|
import static org.hamcrest.Matchers.hasKey
|
|
import static org.hamcrest.Matchers.hasValue
|
|
import static org.hamcrest.Matchers.is
|
|
import static org.hamcrest.Matchers.isEmptyOrNullString
|
|
import static org.junit.Assert.assertThat
|
|
import static org.junit.Assert.assertTrue
|
|
import static org.junit.Assert.assertEquals
|
|
|
|
class InfluxWriteDataTest extends BasePiperTest {
|
|
public JenkinsLoggingRule loggingRule = new JenkinsLoggingRule(this)
|
|
private JenkinsStepRule stepRule = new JenkinsStepRule(this)
|
|
|
|
@Rule
|
|
public RuleChain ruleChain = Rules
|
|
.getCommonRules(this)
|
|
.around(new JenkinsReadYamlRule(this))
|
|
.around(loggingRule)
|
|
.around(stepRule)
|
|
|
|
Map fileMap = [:]
|
|
Map stepMap = [:]
|
|
String echoLog = ''
|
|
|
|
@Before
|
|
void init() throws Exception {
|
|
// Currently we have dependencies between the tests since
|
|
// DefaultValueCache is a singleton which keeps its status
|
|
// for all the tests. Depending on the test order we fail.
|
|
// As long as this status remains we need:
|
|
DefaultValueCache.reset()
|
|
//reset stepMap
|
|
stepMap = [:]
|
|
//reset fileMap
|
|
fileMap = [:]
|
|
|
|
helper.registerAllowedMethod('readYaml', [Map.class], { map ->
|
|
return [
|
|
general: [productiveBranch: 'develop'],
|
|
steps : [influxWriteData: [influxServer: 'testInflux']]
|
|
]
|
|
})
|
|
helper.registerAllowedMethod('writeFile', [Map.class],{m -> fileMap[m.file] = m.text})
|
|
helper.registerAllowedMethod('step', [Map.class],{m -> stepMap = m})
|
|
}
|
|
|
|
|
|
@Test
|
|
void testInfluxWriteDataWithDefault() throws Exception {
|
|
|
|
nullScript.commonPipelineEnvironment.setArtifactVersion('1.2.3')
|
|
stepRule.step.influxWriteData(script: nullScript)
|
|
|
|
assertThat(loggingRule.log, containsString('Artifact version: 1.2.3'))
|
|
|
|
assertThat(stepMap.selectedTarget, is('testInflux'))
|
|
assertThat(stepMap.customPrefix, isEmptyOrNullString())
|
|
|
|
assertThat(stepMap.customData, isEmptyOrNullString())
|
|
assertThat(stepMap.customDataMap, is([pipeline_data: [:], step_data: [:]]))
|
|
|
|
assertThat(fileMap, hasKey('jenkins_data.json'))
|
|
assertThat(fileMap, hasKey('influx_data.json'))
|
|
assertThat(fileMap, hasKey('jenkins_data_tags.json'))
|
|
assertThat(fileMap, hasKey('influx_data_tags.json'))
|
|
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
@Test
|
|
void testInfluxWriteDataNoInflux() throws Exception {
|
|
|
|
nullScript.commonPipelineEnvironment.setArtifactVersion('1.2.3')
|
|
stepRule.step.influxWriteData(script: nullScript, influxServer: '')
|
|
|
|
assertEquals(0, stepMap.size())
|
|
|
|
assertTrue(fileMap.containsKey('jenkins_data.json'))
|
|
assertTrue(fileMap.containsKey('influx_data.json'))
|
|
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
@Test
|
|
void testInfluxWriteDataNoArtifactVersion() throws Exception {
|
|
|
|
stepRule.step.influxWriteData(script: nullScript)
|
|
|
|
assertEquals(0, stepMap.size())
|
|
assertEquals(0, fileMap.size())
|
|
|
|
assertTrue(loggingRule.log.contains('no artifact version available -> exiting writeInflux without writing data'))
|
|
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
@Test
|
|
void testInfluxWriteDataWrapInNode() throws Exception {
|
|
|
|
boolean nodeCalled = false
|
|
helper.registerAllowedMethod('node', [String.class, Closure.class]) {s, body ->
|
|
nodeCalled = true
|
|
return body()
|
|
}
|
|
|
|
helper.registerAllowedMethod("deleteDir", [], null)
|
|
|
|
nullScript.commonPipelineEnvironment.setArtifactVersion('1.2.3')
|
|
stepRule.step.influxWriteData(script: nullScript, wrapInNode: true)
|
|
|
|
assertThat(nodeCalled, is(true))
|
|
|
|
}
|
|
|
|
@Test
|
|
void testInfluxCustomData() {
|
|
nullScript.commonPipelineEnvironment.setArtifactVersion('1.2.3')
|
|
stepRule.step.influxWriteData(
|
|
//juStabUtils: utils,
|
|
script: nullScript,
|
|
influxServer: 'myInstance',
|
|
customData: [key1: 'test1'],
|
|
customDataTags: [tag1: 'testTag1'],
|
|
customDataMap: [test_data: [key1: 'keyValue1']],
|
|
customDataMapTags: [test_data: [tag1: 'tagValue1']]
|
|
)
|
|
assertThat(stepMap.customData, allOf(hasKey('key1'), hasValue('test1')))
|
|
assertThat(stepMap.customDataTags, allOf(hasKey('tag1'), hasValue('testTag1')))
|
|
assertThat(stepMap.customDataMap, hasKey('test_data'))
|
|
assertThat(stepMap.customDataMapTags, hasKey('test_data'))
|
|
}
|
|
|
|
@Test
|
|
void testInfluxCustomDataFromCPE() {
|
|
nullScript.commonPipelineEnvironment.reset()
|
|
nullScript.commonPipelineEnvironment.setArtifactVersion('1.2.3')
|
|
InfluxData.addTag('jenkins_custom_data', 'tag1', 'testTag1')
|
|
InfluxData.addField('test_data', 'key1', 'keyValue1')
|
|
InfluxData.addTag('test_data', 'tag1', 'tagValue1')
|
|
stepRule.step.influxWriteData(
|
|
//juStabUtils: utils,
|
|
script: nullScript,
|
|
influxServer: 'myInstance'
|
|
)
|
|
assertThat(stepMap.customData, isEmptyOrNullString())
|
|
assertThat(stepMap.customDataTags, allOf(hasKey('tag1'), hasValue('testTag1')))
|
|
assertThat(stepMap.customDataMap, hasKey('test_data'))
|
|
assertThat(stepMap.customDataMapTags, hasKey('test_data'))
|
|
}
|
|
|
|
}
|