Skip to content

Commit

Permalink
add libhoney parser tests
Browse files Browse the repository at this point in the history
  • Loading branch information
mterhar committed Dec 18, 2024
1 parent beeac27 commit d3040df
Showing 1 changed file with 294 additions and 0 deletions.
294 changes: 294 additions & 0 deletions receiver/libhoneyreceiver/internal/libhoneyevent/libhoneyevent_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,294 @@
// Copyright The OpenTelemetry Authors
// SPDX-License-Identifier: Apache-2.0

package libhoneyevent

import (
"encoding/json"
"testing"
"time"

"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
"go.opentelemetry.io/collector/pdata/pcommon"
"go.opentelemetry.io/collector/pdata/plog"
"go.uber.org/zap"
)

func TestLibhoneyEvent_UnmarshalJSON(t *testing.T) {
tests := []struct {
name string
json string
want LibhoneyEvent
wantErr bool
}{
{
name: "basic event",
json: `{
"time": "2024-01-01T00:00:00Z",
"data": {"key": "value"},
"samplerate": 1
}`,
want: LibhoneyEvent{
Time: "2024-01-01T00:00:00Z",
Data: map[string]any{"key": "value"},
Samplerate: 1,
},
},
{
name: "invalid json",
json: `{invalid`,
wantErr: true,
},
}

for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
var got LibhoneyEvent
err := json.Unmarshal([]byte(tt.json), &got)

if tt.wantErr {
assert.Error(t, err)
return
}

require.NoError(t, err)
assert.Equal(t, tt.want.Time, got.Time)
assert.Equal(t, tt.want.Data, got.Data)
assert.Equal(t, tt.want.Samplerate, got.Samplerate)
assert.NotNil(t, got.MsgPackTimestamp)
})
}

test := struct {
name string
json string
want LibhoneyEvent
wantErr bool
}{
name: "missing time uses current",
json: `{
"data": {"key": "value"},
"samplerate": 2
}`,
want: LibhoneyEvent{
Time: "",
Data: map[string]any{"key": "value"},
Samplerate: 2,
},
}
t.Run(test.name, func(t *testing.T) {
var got LibhoneyEvent
err := json.Unmarshal([]byte(test.json), &got)

require.NoError(t, err)
assert.Equal(t, test.want.Data, got.Data)
gotTime, timeErr := time.Parse(time.RFC3339Nano, got.Time)
assert.Nil(t, timeErr)
assert.WithinDuration(t, time.Now(), gotTime, time.Second)
assert.Equal(t, test.want.Samplerate, got.Samplerate)
assert.NotNil(t, got.MsgPackTimestamp)
})
}

func TestLibHoneyEvent_ToPLogRecord(t *testing.T) {
logger := zap.NewNop()
now := time.Now()
tests := []struct {
name string
event LibhoneyEvent
alreadyUsedFields []string
want func(plog.LogRecord)
wantErr bool
}{
{
name: "basic conversion",
event: LibhoneyEvent{
Samplerate: 1,
MsgPackTimestamp: &now,
Data: map[string]any{
"severity_text": "ERROR",
"severity_code": int64(2),
"body": "test message",
"string_attr": "value",
"int_attr": 42,
"float_attr": 3.14,
"bool_attr": true,
},
},
want: func(lr plog.LogRecord) {
lr.SetSeverityText("ERROR")
lr.SetSeverityNumber(plog.SeverityNumber(2))
lr.Body().SetStr("test message")
lr.Attributes().PutStr("string_attr", "value")
lr.Attributes().PutInt("int_attr", 42)
lr.Attributes().PutDouble("float_attr", 3.14)
lr.Attributes().PutBool("bool_attr", true)
lr.Attributes().PutInt("SampleRate", 1)
},
},
{
name: "skip already used fields",
event: LibhoneyEvent{
MsgPackTimestamp: &now,
Data: map[string]any{
"skip_me": "value",
"keep_me": "value",
},
},
alreadyUsedFields: []string{"skip_me"},
want: func(lr plog.LogRecord) {
lr.Attributes().PutStr("keep_me", "value")
lr.Attributes().PutInt("SampleRate", 0)
},
},
}

for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
newLog := plog.NewLogRecord()
err := tt.event.ToPLogRecord(&newLog, &tt.alreadyUsedFields, *logger)

if tt.wantErr {
assert.Error(t, err)
return
}
require.NoError(t, err)
if tt.want != nil {
want := plog.NewLogRecord()
tt.want(want)

// Check severity
assert.Equal(t, want.SeverityText(), newLog.SeverityText())
assert.Equal(t, want.SeverityNumber(), newLog.SeverityNumber())

// Check body
assert.Equal(t, want.Body().AsString(), newLog.Body().AsString())

// Check each attribute has correct type and value
want.Attributes().Range(func(k string, v pcommon.Value) bool {
got, ok := newLog.Attributes().Get(k)
assert.True(t, ok, "missing attribute %s", k)
assert.Equal(t, v.Type(), got.Type(), "wrong type for attribute %s", k)
assert.Equal(t, v, got, "wrong value for attribute %s", k)

return true
})

// Verify no extra attributes
assert.Equal(t, want.Attributes().Len(), newLog.Attributes().Len())
}
})
}
}

func TestLibHoneyEvent_GetService(t *testing.T) {
tests := []struct {
name string
event LibhoneyEvent
fields FieldMapConfig
dataset string
want string
wantErr bool
}{
{
name: "service name found",
event: LibhoneyEvent{
Data: map[string]any{
"service.name": "test-service",
},
},
fields: FieldMapConfig{
Resources: ResourcesConfig{
ServiceName: "service.name",
},
},
want: "test-service",
},
{
name: "service name not found",
event: LibhoneyEvent{
Data: map[string]any{},
},
fields: FieldMapConfig{
Resources: ResourcesConfig{
ServiceName: "service.name",
},
},
dataset: "default-dataset",
want: "default-dataset",
wantErr: true,
},
}

for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
seen := &ServiceHistory{NameCount: make(map[string]int)}
got, err := tt.event.GetService(tt.fields, seen, tt.dataset)

if tt.wantErr {
assert.Error(t, err)
} else {
assert.NoError(t, err)
}
assert.Equal(t, tt.want, got)
})
}
}

func TestLibhoneyEvent_GetScope(t *testing.T) {
tests := []struct {
name string
event LibhoneyEvent
fields FieldMapConfig
serviceName string
want string
wantErr bool
}{
{
name: "scope found",
event: LibhoneyEvent{
Data: map[string]any{
"library.name": "test-lib",
"library.version": "1.0.0",
},
},
fields: FieldMapConfig{
Scopes: ScopesConfig{
LibraryName: "library.name",
LibraryVersion: "library.version",
},
},
serviceName: "test-service",
want: "test-servicetest-lib",
},
{
name: "scope not found",
event: LibhoneyEvent{
Data: map[string]any{},
},
fields: FieldMapConfig{
Scopes: ScopesConfig{
LibraryName: "library.name",
},
},
serviceName: "test-service",
want: "libhoney.receiver",
wantErr: true,
},
}

for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
seen := &ScopeHistory{Scope: make(map[string]SimpleScope)}
got, err := tt.event.GetScope(tt.fields, seen, tt.serviceName)

if tt.wantErr {
assert.Error(t, err)
} else {
assert.NoError(t, err)
}
assert.Equal(t, tt.want, got)
})
}
}

0 comments on commit d3040df

Please sign in to comment.