mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-06 04:13:55 +02:00
d9e30418bc
* Removes unecessary fields from telemetry, restructuring splunk pkg * Removes t.skip() and reactivates integration test * Adjusts tests for fatalHook and helper functions, including log test * Moves pipelinetelemetry to inner source, removes pipelineTelemetry from telemetry pkg, using generic map[string]interface for splunk * Removes Read JSON from fatalHook -> moves to inner source * Removed log output test * go fmt * log step telemetry data send to splunk * Adjusts error logging * Adds log information in case api information could not be retrieved Co-authored-by: Oliver Nocon <33484802+OliverNocon@users.noreply.github.com>
256 lines
6.4 KiB
Go
256 lines
6.4 KiB
Go
package telemetry
|
|
|
|
import (
|
|
"fmt"
|
|
"github.com/SAP/jenkins-library/pkg/orchestrator"
|
|
"github.com/jarcoal/httpmock"
|
|
"net/http"
|
|
"reflect"
|
|
"testing"
|
|
"time"
|
|
|
|
piperhttp "github.com/SAP/jenkins-library/pkg/http"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestTelemetry_Initialize(t *testing.T) {
|
|
type fields struct {
|
|
baseData BaseData
|
|
baseMetaData BaseMetaData
|
|
data Data
|
|
provider orchestrator.OrchestratorSpecificConfigProviding
|
|
disabled bool
|
|
client *piperhttp.Client
|
|
CustomReportingDsn string
|
|
CustomReportingToken string
|
|
customClient *piperhttp.Client
|
|
BaseURL string
|
|
Endpoint string
|
|
SiteID string
|
|
}
|
|
type args struct {
|
|
telemetryDisabled bool
|
|
stepName string
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
fields fields
|
|
args args
|
|
want *piperhttp.Client
|
|
}{
|
|
{
|
|
name: "telemetry disabled",
|
|
fields: fields{},
|
|
args: args{
|
|
telemetryDisabled: true,
|
|
stepName: "test",
|
|
},
|
|
want: nil,
|
|
},
|
|
{
|
|
name: "telemetry enabled",
|
|
fields: fields{},
|
|
args: args{
|
|
telemetryDisabled: false,
|
|
stepName: "test",
|
|
},
|
|
want: &piperhttp.Client{},
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t1 *testing.T) {
|
|
telemetryClient := &Telemetry{}
|
|
telemetryClient.Initialize(tt.args.telemetryDisabled, tt.args.stepName)
|
|
// assert
|
|
assert.NotEqual(t, tt.want, telemetryClient.client)
|
|
assert.Equal(t, tt.args.stepName, telemetryClient.baseData.StepName)
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestTelemetry_Send(t *testing.T) {
|
|
type fields struct {
|
|
baseData BaseData
|
|
baseMetaData BaseMetaData
|
|
data Data
|
|
provider orchestrator.OrchestratorSpecificConfigProviding
|
|
disabled bool
|
|
client *piperhttp.Client
|
|
CustomReportingDsn string
|
|
CustomReportingToken string
|
|
BaseURL string
|
|
Endpoint string
|
|
SiteID string
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
fields fields
|
|
swaCalls int
|
|
}{
|
|
{
|
|
name: "Telemetry disabled, reporting disabled",
|
|
fields: fields{
|
|
disabled: true,
|
|
},
|
|
swaCalls: 0,
|
|
},
|
|
{
|
|
name: "Telemetry enabled",
|
|
fields: fields{
|
|
disabled: false,
|
|
},
|
|
swaCalls: 1,
|
|
},
|
|
{
|
|
name: "Telemetry disabled",
|
|
fields: fields{
|
|
disabled: true,
|
|
},
|
|
swaCalls: 0,
|
|
},
|
|
}
|
|
|
|
httpmock.Activate()
|
|
defer httpmock.DeactivateAndReset()
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
httpmock.Reset()
|
|
telemetryClient := &Telemetry{disabled: tt.fields.disabled}
|
|
telemetryClient.Initialize(tt.fields.disabled, tt.name)
|
|
telemetryClient.CustomReportingDsn = tt.fields.CustomReportingDsn
|
|
if telemetryClient.client == nil {
|
|
telemetryClient.client = &piperhttp.Client{}
|
|
}
|
|
|
|
url := telemetryClient.BaseURL + telemetryClient.Endpoint
|
|
|
|
telemetryClient.client.SetOptions(piperhttp.ClientOptions{
|
|
MaxRequestDuration: 5 * time.Second,
|
|
Token: "TOKEN",
|
|
TransportSkipVerification: true,
|
|
UseDefaultTransport: true,
|
|
MaxRetries: -1,
|
|
})
|
|
|
|
if tt.fields.CustomReportingDsn != "" {
|
|
telemetryClient.customClient = &piperhttp.Client{}
|
|
telemetryClient.customClient.SetOptions(piperhttp.ClientOptions{
|
|
MaxRequestDuration: 5 * time.Second,
|
|
Token: "TOKEN",
|
|
TransportSkipVerification: true,
|
|
UseDefaultTransport: true, // Needed for mocking
|
|
MaxRetries: -1,
|
|
})
|
|
}
|
|
|
|
httpmock.RegisterResponder(http.MethodGet, url,
|
|
func(req *http.Request) (*http.Response, error) {
|
|
return httpmock.NewStringResponse(200, "Ok"), nil
|
|
},
|
|
)
|
|
httpmock.RegisterResponder(http.MethodPost, telemetryClient.CustomReportingDsn,
|
|
func(req *http.Request) (*http.Response, error) {
|
|
return httpmock.NewStringResponse(200, "Ok"), nil
|
|
},
|
|
)
|
|
|
|
// test
|
|
telemetryClient.SetData(&CustomData{})
|
|
telemetryClient.Send()
|
|
|
|
// assert
|
|
info := httpmock.GetCallCountInfo()
|
|
|
|
if got := info["GET "+url]; !assert.Equal(t, got, tt.swaCalls) {
|
|
t.Errorf("Send() = swa calls %v, wanted %v", got, tt.swaCalls)
|
|
}
|
|
|
|
})
|
|
}
|
|
defer httpmock.DeactivateAndReset()
|
|
}
|
|
|
|
func TestSetData(t *testing.T) {
|
|
type args struct {
|
|
customData *CustomData
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
args args
|
|
want Data
|
|
}{
|
|
{
|
|
name: "Test",
|
|
args: args{customData: &CustomData{
|
|
Duration: "100",
|
|
ErrorCode: "0",
|
|
ErrorCategory: "Undefined",
|
|
PiperCommitHash: "abcd12345",
|
|
},
|
|
},
|
|
want: Data{
|
|
BaseData: BaseData{
|
|
URL: "",
|
|
ActionName: "",
|
|
EventType: "",
|
|
StepName: "TestCreateDataObject",
|
|
SiteID: "",
|
|
PipelineURLHash: "",
|
|
BuildURLHash: "",
|
|
Orchestrator: "Unknown",
|
|
},
|
|
BaseMetaData: BaseMetaData{
|
|
StepNameLabel: "stepName",
|
|
StageNameLabel: "stageName",
|
|
PipelineURLHashLabel: "pipelineUrlHash",
|
|
BuildURLHashLabel: "buildUrlHash",
|
|
DurationLabel: "duration",
|
|
ExitCodeLabel: "exitCode",
|
|
ErrorCategoryLabel: "errorCategory",
|
|
OrchestratorLabel: "orchestrator",
|
|
PiperCommitHashLabel: "piperCommitHash",
|
|
},
|
|
CustomData: CustomData{
|
|
Duration: "100",
|
|
ErrorCode: "0",
|
|
ErrorCategory: "Undefined",
|
|
PiperCommitHash: "abcd12345",
|
|
Custom1Label: "",
|
|
Custom2Label: "",
|
|
Custom3Label: "",
|
|
Custom4Label: "",
|
|
Custom5Label: "",
|
|
Custom1: "",
|
|
Custom2: "",
|
|
Custom3: "",
|
|
Custom4: "",
|
|
Custom5: "",
|
|
},
|
|
},
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
telemetryClient := Telemetry{}
|
|
telemetryClient.Initialize(false, "TestCreateDataObject")
|
|
telemetryClient.baseData = BaseData{
|
|
URL: "",
|
|
ActionName: "",
|
|
EventType: "",
|
|
StepName: "TestCreateDataObject",
|
|
SiteID: "",
|
|
PipelineURLHash: "",
|
|
BuildURLHash: "",
|
|
Orchestrator: "Unknown",
|
|
}
|
|
telemetryClient.baseMetaData = baseMetaData
|
|
telemetryClient.SetData(tt.args.customData)
|
|
fmt.Println(telemetryClient.data)
|
|
fmt.Println(tt.want)
|
|
if !reflect.DeepEqual(telemetryClient.data, tt.want) {
|
|
t.Errorf("CreateDataObject() t.data= %v, want %v", telemetryClient.data, tt.want)
|
|
}
|
|
})
|
|
}
|
|
}
|