mirror of
https://github.com/SAP/jenkins-library.git
synced 2025-01-18 05:18:24 +02:00
b88ebdad6c
* Adds inital splunk hook and logCollector * Adds documentation of the Splunk hook * Fixes markdown lint issues and removes comment from telemetry.go file * Fixes markdown lint issues and adds missing generated file * Markdown linting * Changes documentation according to review, adds Splunk token automatically during init * Adds error handling for marshalling hook config * Markdown lint und correct Splunk token in httpclient * Registeres Splunk token as secret and adjusts test cases * Adds missing error handling and removes unnecessary comments * Creates new function readPipelineEnvironment, adds tests * Moves MonitoringData struct, edits defaults for json fields * Adds gitRepository and gitOwner to telemetry information * Simplifies readCommonPipelineEnvironment function, adds more descriptive errors, adds automated adding of Splunk prefix token * Adjusts error handling * Cleaner error logging
94 lines
2.0 KiB
Go
94 lines
2.0 KiB
Go
package log
|
|
|
|
import (
|
|
"reflect"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/sirupsen/logrus"
|
|
)
|
|
|
|
func TestCollectorHook_Fire(t *testing.T) {
|
|
type fields struct {
|
|
CorrelationID string
|
|
Messages []Message
|
|
}
|
|
type args struct {
|
|
entry *logrus.Entry
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
fields fields
|
|
args args
|
|
wantErr bool
|
|
}{
|
|
{"Test Fire",
|
|
fields{
|
|
CorrelationID: "123",
|
|
Messages: []Message{},
|
|
},
|
|
args{entry: &logrus.Entry{
|
|
Time: time.Now(),
|
|
Data: logrus.Fields{"test": "test value"},
|
|
Message: "Test Message",
|
|
},
|
|
},
|
|
false,
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
initialMessageLength := len(tt.fields.Messages)
|
|
f := &CollectorHook{
|
|
CorrelationID: tt.fields.CorrelationID,
|
|
Messages: tt.fields.Messages,
|
|
}
|
|
// Check if hook was triggered
|
|
if err := f.Fire(tt.args.entry); (err != nil) != tt.wantErr {
|
|
t.Errorf("Fire() error = %v, wantErr %v", err, tt.wantErr)
|
|
}
|
|
|
|
// Check if the message was successfully added
|
|
if len(f.Messages) != initialMessageLength+1 {
|
|
t.Errorf("Fire() error - Messages not added to array - Message count %v", len(f.Messages))
|
|
}
|
|
})
|
|
}
|
|
}
|
|
func TestCollectorHook_Levels(t *testing.T) {
|
|
type fields struct {
|
|
CorrelationID string
|
|
Messages []Message
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
fields fields
|
|
want []logrus.Level
|
|
}{
|
|
{"Test Levels",
|
|
fields{
|
|
CorrelationID: "123",
|
|
Messages: []Message{
|
|
{
|
|
Time: time.Now(),
|
|
Level: logrus.DebugLevel,
|
|
Message: "Test Message",
|
|
},
|
|
},
|
|
},
|
|
[]logrus.Level{logrus.InfoLevel, logrus.DebugLevel, logrus.WarnLevel, logrus.ErrorLevel, logrus.PanicLevel, logrus.FatalLevel},
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
f := &CollectorHook{
|
|
CorrelationID: tt.fields.CorrelationID,
|
|
Messages: tt.fields.Messages,
|
|
}
|
|
if got := f.Levels(); !reflect.DeepEqual(got, tt.want) {
|
|
t.Errorf("Levels() = %v, want %v", got, tt.want)
|
|
}
|
|
})
|
|
}
|
|
}
|