Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[azureeventhubreceiver] Migrate to new AzureSDK #33134

Closed
wants to merge 33 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
33 commits
Select commit Hold shift + click to select a range
81f0af3
remove continue from timestamp parse failure
nslaughter Feb 13, 2024
a82fee0
Merge branch 'main' into main
nslaughter Feb 14, 2024
ff6c517
add changelog entry
nslaughter Feb 14, 2024
58f987c
ignore ObservedTimestamp in test
nslaughter Feb 14, 2024
7eb742f
Merge branch 'main' into main
nslaughter Feb 14, 2024
948f4b7
Merge branch 'main' into main
nslaughter Feb 15, 2024
200e552
Merge branch 'main' into main
nslaughter Feb 15, 2024
93e588f
Merge branch 'main' into main
nslaughter Feb 15, 2024
4379aac
Merge branch 'main' into main
nslaughter Feb 15, 2024
1946a4b
Merge branch 'main' into main
nslaughter Feb 15, 2024
a686ed0
Merge branch 'main' into main
nslaughter Feb 16, 2024
47d3fd6
first cuts - not passing
nslaughter Apr 13, 2024
81112af
Update deps
nslaughter Apr 14, 2024
14edf92
sync
nslaughter Apr 15, 2024
4268aed
fill in helpers in eventhandler
nslaughter Apr 24, 2024
7781880
refact
nslaughter May 2, 2024
678084c
fix the signatures - interfaces
nslaughter May 2, 2024
7ad522e
add processor as a strategy
nslaughter May 10, 2024
fc80d31
guard nil checks
nslaughter May 10, 2024
e41b3ca
rework structure teeny tiny
nslaughter May 10, 2024
80cdcbe
fix panic
nslaughter May 20, 2024
3e0758d
rm azureventprocessor.go
nslaughter May 20, 2024
05a5515
Delete unused persister consumer
nslaughter May 20, 2024
35f9fef
time as string
nslaughter May 22, 2024
ca27e32
scratch change in azblob
nslaughter May 22, 2024
e785643
fix chlog
nslaughter May 22, 2024
7013455
delete commented out code
nslaughter May 23, 2024
4352622
wrap Collector storageClient
nslaughter May 23, 2024
9bf9c12
add debug for logs
nslaughter May 23, 2024
1320682
fix checkpoints - and test
nslaughter May 23, 2024
9c7fb13
add checkpoints
nslaughter May 23, 2024
74863cf
vet/fmt/goimports
nslaughter May 23, 2024
2b5c1e3
Merge branch 'main' into nslaughter/migrate-azure-sdk-for-eventhub
nslaughter Jun 11, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
27 changes: 27 additions & 0 deletions .chloggen/nslaughter_update-azure-sdk.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
# Use this changelog template to create an entry for release notes.

# One of 'breaking', 'deprecation', 'new_component', 'enhancement', 'bug_fix'
change_type: enhancement

# The name of the component, or a single word describing the area of concern, (e.g. filelogreceiver)
component: azureeventhubreceiver

# A brief description of the change. Surround your text with quotes ("") if it needs to start with a backtick (`).
note: Migrate to recommended Azure SDK modules

# Mandatory: One or more tracking issues related to the change. You can use the PR number here if no issue exists.
issues: [31252]

# (Optional) One or more lines of additional information to render under the primary note.
# These lines will be padded with 2 spaces and then inserted directly into the document.
# Use pipe (|) for multiline entries.
subtext:

# If your change doesn't affect end users or the exported elements of any package,
# you should instead start your pull request title with [chore] or use the "Skip Changelog" label.
# Optional: The change log or logs in which this entry should be included.
# e.g. '[user]' or '[user, api]'
# Include 'user' if the change is relevant to end users.
# Include 'api' if there is a change to a library API.
# Default: '[user]'
change_logs: []
1 change: 0 additions & 1 deletion go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -232,7 +232,6 @@ require (
github.com/Azure/go-autorest v14.2.0+incompatible // indirect
github.com/Azure/go-autorest/autorest v0.11.29 // indirect
github.com/Azure/go-autorest/autorest/adal v0.9.23 // indirect
github.com/Azure/go-autorest/autorest/azure/auth v0.5.12 // indirect
github.com/Azure/go-autorest/autorest/date v0.3.0 // indirect
github.com/Azure/go-autorest/autorest/to v0.4.0 // indirect
github.com/Azure/go-autorest/autorest/validation v0.3.1 // indirect
Expand Down
68 changes: 13 additions & 55 deletions go.sum

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

11 changes: 9 additions & 2 deletions pkg/translator/azure/resourcelogs_to_logs.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import (
"encoding/json"
"errors"
"strconv"
"time"

jsoniter "github.com/json-iterator/go"
"github.com/relvacode/iso8601"
Expand Down Expand Up @@ -109,12 +110,18 @@ func (r ResourceLogsUnmarshaler) UnmarshalLogs(buf []byte) (plog.Logs, error) {
log := logs[i]
nanos, err := getTimestamp(log)
if err != nil {
r.Logger.Warn("Unable to convert timestamp from log", zap.String("timestamp", log.Time))
r.Logger.Warn("Unable to convert timestamp from log", zap.String("time", log.Time), zap.String("timestamp", log.Timestamp))
r.Logger.Debug("unable to convert timestamp log record", zap.Any("record", log))
continue
}

lr := logRecords.AppendEmpty()
lr.SetTimestamp(nanos)
// only set timestamp if the record sent included a valid value
if err == nil {
lr.SetTimestamp(nanos)
}
// always set observed timestamp to time observed by Collector
lr.SetObservedTimestamp(pcommon.Timestamp(time.Now().UnixNano()))

if log.Level != nil {
severity := asSeverity(*log.Level)
Expand Down
2 changes: 1 addition & 1 deletion pkg/translator/azure/resourcelogs_to_logs_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -462,7 +462,7 @@ func TestUnmarshalLogs(t *testing.T) {
logs, err := sut.UnmarshalLogs(data)
assert.NoError(t, err)

assert.NoError(t, plogtest.CompareLogs(tt.expected, logs))
assert.NoError(t, plogtest.CompareLogs(tt.expected, logs, plogtest.IgnoreObservedTimestamp()))
})
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
package azureeventhubreceiver // import "github.com/open-telemetry/opentelemetry-collector-contrib/receiver/azureeventhubreceiver"

import (
eventhub "github.com/Azure/azure-event-hubs-go/v3"
"github.com/Azure/azure-sdk-for-go/sdk/messaging/azeventhubs"
"go.opentelemetry.io/collector/component"
"go.opentelemetry.io/collector/pdata/plog"
"go.uber.org/zap"
Expand All @@ -17,7 +17,6 @@ type AzureResourceLogsEventUnmarshaler struct {
}

func newAzureResourceLogsUnmarshaler(buildInfo component.BuildInfo, logger *zap.Logger) eventLogsUnmarshaler {

return AzureResourceLogsEventUnmarshaler{
unmarshaler: &azure.ResourceLogsUnmarshaler{
Version: buildInfo.Version,
Expand All @@ -32,7 +31,6 @@ func newAzureResourceLogsUnmarshaler(buildInfo component.BuildInfo, logger *zap.
// log record appears as fields and attributes in the
// OpenTelemetry representation; the bodies of the
// OpenTelemetry log records are empty.
func (r AzureResourceLogsEventUnmarshaler) UnmarshalLogs(event *eventhub.Event) (plog.Logs, error) {

return r.unmarshaler.UnmarshalLogs(event.Data)
func (r AzureResourceLogsEventUnmarshaler) UnmarshalLogs(event *azeventhubs.ReceivedEventData) (plog.Logs, error) {
return r.unmarshaler.UnmarshalLogs(event.Body)
}
118 changes: 118 additions & 0 deletions receiver/azureeventhubreceiver/azureresourcelogs_unmarshaler_test.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading
Loading