2019-01-30 13:39:33 +02:00
|
|
|
package com.sap.piper.analytics
|
|
|
|
|
|
|
|
import org.junit.Rule
|
|
|
|
import org.junit.Before
|
|
|
|
import org.junit.Test
|
|
|
|
import static org.junit.Assert.assertThat
|
|
|
|
import static org.junit.Assume.assumeThat
|
|
|
|
import org.junit.rules.ExpectedException
|
|
|
|
import org.junit.rules.RuleChain
|
|
|
|
|
2019-03-28 12:54:45 +02:00
|
|
|
import static org.hamcrest.Matchers.allOf
|
2019-01-30 13:39:33 +02:00
|
|
|
import static org.hamcrest.Matchers.containsString
|
2019-03-28 12:54:45 +02:00
|
|
|
import static org.hamcrest.Matchers.empty
|
2019-01-30 13:39:33 +02:00
|
|
|
import static org.hamcrest.Matchers.is
|
|
|
|
import static org.hamcrest.Matchers.not
|
2019-03-28 12:54:45 +02:00
|
|
|
import static org.hamcrest.Matchers.startsWith
|
2019-01-30 13:39:33 +02:00
|
|
|
|
|
|
|
import util.JenkinsLoggingRule
|
|
|
|
import util.JenkinsShellCallRule
|
|
|
|
import util.BasePiperTest
|
|
|
|
import util.Rules
|
|
|
|
|
|
|
|
class TelemetryTest extends BasePiperTest {
|
|
|
|
private ExpectedException thrown = ExpectedException.none()
|
|
|
|
private JenkinsLoggingRule jlr = new JenkinsLoggingRule(this)
|
|
|
|
private JenkinsShellCallRule jscr = new JenkinsShellCallRule(this)
|
|
|
|
|
|
|
|
@Rule
|
|
|
|
public RuleChain rules = Rules
|
|
|
|
.getCommonRules(this)
|
|
|
|
.around(thrown)
|
|
|
|
.around(jscr)
|
|
|
|
.around(jlr)
|
|
|
|
|
|
|
|
private parameters
|
|
|
|
|
|
|
|
@Before
|
|
|
|
void setup() {
|
|
|
|
Telemetry.instance = null
|
|
|
|
parameters = [:]
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
void testCreateInstance() {
|
|
|
|
Telemetry.instance = new Telemetry()
|
|
|
|
// asserts
|
|
|
|
assertThat(Telemetry.getInstance().listenerList, is(empty()))
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
void testGetInstance() {
|
|
|
|
// asserts
|
|
|
|
assertThat(Telemetry.getInstance().listenerList, is(not(empty())))
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
void testRegisterListenerAndNotify() {
|
|
|
|
// prepare
|
|
|
|
Map notificationPayload = [:]
|
|
|
|
Telemetry.instance = new Telemetry()
|
|
|
|
assumeThat(Telemetry.getInstance().listenerList, is(empty()))
|
|
|
|
|
|
|
|
Telemetry.registerListener({ steps, payload ->
|
|
|
|
notificationPayload = payload
|
|
|
|
})
|
|
|
|
// test
|
|
|
|
Telemetry.notify(nullScript, [collectTelemetryData: true], [step: 'anyStep', anything: 'something'])
|
|
|
|
// asserts
|
|
|
|
assertThat(Telemetry.getInstance().listenerList, is(not(empty())))
|
|
|
|
assertThat(notificationPayload, is([step: 'anyStep', anything: 'something']))
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
void testNotifyWithOptOut() {
|
|
|
|
// prepare
|
|
|
|
Map notificationPayload = [:]
|
|
|
|
Telemetry.instance = new Telemetry()
|
|
|
|
assumeThat(Telemetry.getInstance().listenerList, is(empty()))
|
|
|
|
Telemetry.registerListener({ steps, payload ->
|
|
|
|
notificationPayload = payload
|
|
|
|
})
|
|
|
|
// test
|
|
|
|
Telemetry.notify(nullScript, [collectTelemetryData: false], [step: 'anyStep', anything: 'something'])
|
|
|
|
// asserts
|
|
|
|
assertThat(Telemetry.getInstance().listenerList, is(not(empty())))
|
2019-02-21 14:56:20 +02:00
|
|
|
assertThat(jlr.log, containsString("[anyStep] Sending telemetry data is disabled."))
|
2019-01-30 13:39:33 +02:00
|
|
|
assertThat(notificationPayload.keySet(), is(empty()))
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
void testNotifyWithOptOutWithEmptyConfig() {
|
|
|
|
// prepare
|
|
|
|
Map notificationPayload = [:]
|
|
|
|
Telemetry.instance = new Telemetry()
|
|
|
|
assumeThat(Telemetry.getInstance().listenerList, is(empty()))
|
|
|
|
Telemetry.registerListener({ steps, payload ->
|
|
|
|
notificationPayload = payload
|
|
|
|
})
|
|
|
|
// test
|
|
|
|
Telemetry.notify(nullScript, [:], [step: 'anyStep', anything: 'something'])
|
|
|
|
// asserts
|
|
|
|
assertThat(Telemetry.getInstance().listenerList, is(not(empty())))
|
2019-02-21 14:56:20 +02:00
|
|
|
assertThat(jlr.log, containsString("[anyStep] Sending telemetry data is disabled."))
|
2019-01-30 13:39:33 +02:00
|
|
|
assertThat(notificationPayload.keySet(), is(empty()))
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
void testNotifyWithOptOutWithoutConfig() {
|
|
|
|
// prepare
|
|
|
|
Map notificationPayload = [:]
|
|
|
|
Telemetry.instance = new Telemetry()
|
|
|
|
assumeThat(Telemetry.getInstance().listenerList, is(empty()))
|
|
|
|
Telemetry.registerListener({ steps, payload ->
|
|
|
|
notificationPayload = payload
|
|
|
|
})
|
|
|
|
// test
|
|
|
|
Telemetry.notify(nullScript, null, [step: 'anyStep', anything: 'something'])
|
|
|
|
// asserts
|
|
|
|
assertThat(Telemetry.getInstance().listenerList, is(not(empty())))
|
2019-02-21 14:56:20 +02:00
|
|
|
assertThat(jlr.log, containsString("[anyStep] Sending telemetry data is disabled."))
|
2019-01-30 13:39:33 +02:00
|
|
|
assertThat(notificationPayload.keySet(), is(empty()))
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
void testReportingToSWA() {
|
2019-03-28 12:54:45 +02:00
|
|
|
def httpParams = null
|
|
|
|
helper.registerAllowedMethod('httpRequest', [Map.class], {m ->
|
|
|
|
httpParams = m
|
|
|
|
})
|
|
|
|
helper.registerAllowedMethod("timeout", [Map.class, Closure.class], { m,c ->
|
|
|
|
c()
|
|
|
|
})
|
2019-01-30 13:39:33 +02:00
|
|
|
// prepare
|
|
|
|
assumeThat(Telemetry.getInstance().listenerList, is(not(empty())))
|
|
|
|
// test
|
|
|
|
Telemetry.notify(nullScript, [collectTelemetryData: true], [
|
|
|
|
actionName: 'Piper Library OS',
|
|
|
|
eventType: 'library-os',
|
|
|
|
jobUrlSha1: '1234',
|
|
|
|
buildUrlSha1: 'abcd',
|
|
|
|
step: 'anyStep',
|
|
|
|
stepParam1: 'something'
|
|
|
|
])
|
|
|
|
// asserts
|
2019-03-28 12:54:45 +02:00
|
|
|
assertThat(httpParams, is(not(null)))
|
|
|
|
assertThat(httpParams.url.toString(), allOf(
|
|
|
|
startsWith('https://webanalytics.cfapps.eu10.hana.ondemand.com/tracker/log?'),
|
|
|
|
containsString('action_name=Piper+Library+OS'),
|
|
|
|
containsString('event_type=library-os'),
|
|
|
|
containsString('custom3=anyStep'),
|
|
|
|
containsString('custom4=1234'),
|
|
|
|
containsString('custom5=abcd'),
|
|
|
|
containsString('custom11=something')
|
|
|
|
))
|
2019-01-30 13:39:33 +02:00
|
|
|
}
|
|
|
|
}
|