mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-18 05:18:24 +02:00
130e607446
influxWriteData requires a node to be executed. In a declarative pipeline the POST section by default does not provide a node/agent. This adds a parameter to force creation of a node/agent.
120 lines
3.6 KiB
Groovy
120 lines
3.6 KiB
Groovy
#!groovy
|
|
import com.sap.piper.DefaultValueCache
|
|
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.is
|
|
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 jsr = new JenkinsStepRule(this)
|
|
|
|
@Rule
|
|
public RuleChain ruleChain = Rules
|
|
.getCommonRules(this)
|
|
.around(new JenkinsReadYamlRule(this))
|
|
.around(loggingRule)
|
|
.around(jsr)
|
|
|
|
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')
|
|
jsr.step.influxWriteData(script: nullScript)
|
|
|
|
assertTrue(loggingRule.log.contains('Artifact version: 1.2.3'))
|
|
|
|
assertEquals('testInflux', stepMap.selectedTarget)
|
|
assertEquals(null, stepMap.customPrefix)
|
|
assertEquals([:], stepMap.customData)
|
|
assertEquals([pipeline_data: [:], step_data: [:]], stepMap.customDataMap)
|
|
|
|
assertTrue(fileMap.containsKey('jenkins_data.json'))
|
|
assertTrue(fileMap.containsKey('pipeline_data.json'))
|
|
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
@Test
|
|
void testInfluxWriteDataNoInflux() throws Exception {
|
|
|
|
nullScript.commonPipelineEnvironment.setArtifactVersion('1.2.3')
|
|
jsr.step.influxWriteData(script: nullScript, influxServer: '')
|
|
|
|
assertEquals(0, stepMap.size())
|
|
|
|
assertTrue(fileMap.containsKey('jenkins_data.json'))
|
|
assertTrue(fileMap.containsKey('pipeline_data.json'))
|
|
|
|
assertJobStatusSuccess()
|
|
}
|
|
|
|
@Test
|
|
void testInfluxWriteDataNoArtifactVersion() throws Exception {
|
|
|
|
jsr.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')
|
|
jsr.step.influxWriteData(script: nullScript, wrapInNode: true)
|
|
|
|
assertThat(nodeCalled, is(true))
|
|
|
|
}
|
|
}
|