-
Notifications
You must be signed in to change notification settings - Fork 1.5k
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
Add logs scraper in factory #11822
Open
sincejune
wants to merge
42
commits into
open-telemetry:main
Choose a base branch
from
sincejune:add-logs-scraper-in-factory
base: main
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Add logs scraper in factory #11822
Changes from 10 commits
Commits
Show all changes
42 commits
Select commit
Hold shift + click to select a range
90a3adf
Add scraper for logs
sincejune fe03c9c
Update
sincejune 6e889ab
Update
sincejune 3d60d14
Fix
sincejune 092e62a
Merge branch 'main' into add-logs-scraper
sincejune b52732a
Merge branch 'main' into add-logs-scraper
sincejune ea35198
Update
sincejune 9bc8cb6
Add logs scraper in the factory
sincejune b1d1de0
Update
sincejune 92156f1
Merge branch 'main' into add-logs-scraper-in-factory
sincejune 0124c61
Merge branch 'main' into add-logs-scraper-in-factory
sincejune b33cec6
Merge branch 'main' into add-logs-scraper-in-factory
sincejune ed603a1
Merge branch 'main' into add-logs-scraper-in-factory
sincejune ce9b96b
Merge branch 'main' into add-logs-scraper-in-factory
sincejune d64b454
Merge branch 'main' into add-logs-scraper-in-factory
sincejune fc59d50
Merge branch 'main' into add-logs-scraper-in-factory
sincejune 03263de
Merge branch 'main' into add-logs-scraper-in-factory
sincejune 33eca67
Merge branch 'main' into add-logs-scraper-in-factory
sincejune 33c942f
Update
sincejune a4345c1
Merge branch 'main' into add-logs-scraper-in-factory
sincejune 365f9cf
Merge branch 'main' into add-logs-scraper-in-factory
sincejune 5f15faa
Merge branch 'main' into add-logs-scraper-in-factory
sincejune d0e4fe0
Merge branch 'main' into add-logs-scraper-in-factory
sincejune ea10b91
Merge branch 'main' into add-logs-scraper-in-factory
sincejune f0dfd93
Merge branch 'main' into add-logs-scraper-in-factory
sincejune f9325fe
Merge branch 'main' into add-logs-scraper-in-factory
sincejune f4ec5a9
Merge branch 'main' into add-logs-scraper-in-factory
sincejune db46e30
Merge branch 'main' into add-logs-scraper-in-factory
sincejune b518e4d
Merge branch 'main' into add-logs-scraper-in-factory
sincejune 367765b
Update
sincejune 5f88901
Merge branch 'main' into add-logs-scraper-in-factory
sincejune 06c4513
Update
sincejune 14195ff
Merge branch 'main' into add-logs-scraper-in-factory
sincejune 0def70f
Merge branch 'main' into add-logs-scraper-in-factory
sincejune 46cd15d
Merge branch 'main' into add-logs-scraper-in-factory
sincejune 6c14808
Merge branch 'main' into add-logs-scraper-in-factory
sincejune 0392be8
Merge branch 'main' into add-logs-scraper-in-factory
sincejune 94f6762
Merge branch 'main' into add-logs-scraper-in-factory
sincejune 3d31da9
Merge branch 'main' into add-logs-scraper-in-factory
sincejune 3dbb083
Merge branch 'main' into add-logs-scraper-in-factory
sincejune f13709c
Merge branch 'main' into add-logs-scraper-in-factory
sincejune 42fb906
Merge branch 'main' into add-logs-scraper-in-factory
sincejune File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
# 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. otlpreceiver) | ||
component: receiver/scraperhelper | ||
|
||
# A brief description of the change. Surround your text with quotes ("") if it needs to start with a backtick (`). | ||
note: Add scraper for logs | ||
|
||
# One or more tracking issues or pull requests related to the change | ||
issues: [11799,11822] | ||
|
||
# (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: | ||
|
||
# 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: [api] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
// Copyright The OpenTelemetry Authors | ||
// SPDX-License-Identifier: Apache-2.0 | ||
|
||
package scraper // import "go.opentelemetry.io/collector/scraper" | ||
|
||
import ( | ||
"context" | ||
|
||
"go.opentelemetry.io/collector/component" | ||
"go.opentelemetry.io/collector/pdata/plog" | ||
) | ||
|
||
// Logs is the base interface for logs scrapers. | ||
type Logs interface { | ||
component.Component | ||
|
||
// ScrapeLogs is the base interface to indicate that how should logs be scraped. | ||
ScrapeLogs(context.Context) (plog.Logs, error) | ||
} | ||
|
||
// ScrapeLogsFunc is a helper function that is similar to Logs.ScrapeLogs. | ||
type ScrapeLogsFunc ScrapeFunc[plog.Logs] | ||
|
||
func (sf ScrapeLogsFunc) ScrapeLogs(ctx context.Context) (plog.Logs, error) { | ||
return sf(ctx) | ||
} | ||
|
||
type logs struct { | ||
baseScraper | ||
ScrapeLogsFunc | ||
} | ||
|
||
// NewLogs creates a new Logs scraper. | ||
func NewLogs(scrape ScrapeLogsFunc, options ...Option) (Logs, error) { | ||
if scrape == nil { | ||
return nil, errNilFunc | ||
} | ||
bs := &logs{ | ||
baseScraper: newBaseScraper(options), | ||
ScrapeLogsFunc: scrape, | ||
} | ||
|
||
return bs, nil | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,79 @@ | ||
// Copyright The OpenTelemetry Authors | ||
// SPDX-License-Identifier: Apache-2.0 | ||
|
||
package scraper | ||
|
||
import ( | ||
"context" | ||
"errors" | ||
"sync" | ||
"testing" | ||
|
||
"github.com/stretchr/testify/assert" | ||
"github.com/stretchr/testify/require" | ||
|
||
"go.opentelemetry.io/collector/component" | ||
"go.opentelemetry.io/collector/component/componenttest" | ||
"go.opentelemetry.io/collector/pdata/plog" | ||
) | ||
|
||
func TestNewLogs(t *testing.T) { | ||
mp, err := NewLogs(newTestScrapeLogsFunc(nil)) | ||
require.NoError(t, err) | ||
|
||
require.NoError(t, mp.Start(context.Background(), componenttest.NewNopHost())) | ||
md, err := mp.ScrapeLogs(context.Background()) | ||
require.NoError(t, err) | ||
assert.Equal(t, plog.NewLogs(), md) | ||
require.NoError(t, mp.Shutdown(context.Background())) | ||
} | ||
|
||
func TestNewLogs_WithOptions(t *testing.T) { | ||
want := errors.New("my_error") | ||
mp, err := NewLogs(newTestScrapeLogsFunc(nil), | ||
WithStart(func(context.Context, component.Host) error { return want }), | ||
WithShutdown(func(context.Context) error { return want })) | ||
require.NoError(t, err) | ||
|
||
assert.Equal(t, want, mp.Start(context.Background(), componenttest.NewNopHost())) | ||
assert.Equal(t, want, mp.Shutdown(context.Background())) | ||
} | ||
|
||
func TestNewLogs_NilRequiredFields(t *testing.T) { | ||
_, err := NewLogs(nil) | ||
require.Error(t, err) | ||
} | ||
|
||
func TestNewLogs_ProcessLogsError(t *testing.T) { | ||
want := errors.New("my_error") | ||
mp, err := NewLogs(newTestScrapeLogsFunc(want)) | ||
require.NoError(t, err) | ||
_, err = mp.ScrapeLogs(context.Background()) | ||
require.ErrorIs(t, err, want) | ||
} | ||
|
||
func TestLogsConcurrency(t *testing.T) { | ||
mp, err := NewLogs(newTestScrapeLogsFunc(nil)) | ||
require.NoError(t, err) | ||
require.NoError(t, mp.Start(context.Background(), componenttest.NewNopHost())) | ||
|
||
var wg sync.WaitGroup | ||
for i := 0; i < 10; i++ { | ||
wg.Add(1) | ||
go func() { | ||
defer wg.Done() | ||
for j := 0; j < 10000; j++ { | ||
_, errScrape := mp.ScrapeLogs(context.Background()) | ||
assert.NoError(t, errScrape) | ||
} | ||
}() | ||
} | ||
wg.Wait() | ||
require.NoError(t, mp.Shutdown(context.Background())) | ||
} | ||
|
||
func newTestScrapeLogsFunc(retError error) ScrapeLogsFunc { | ||
return func(_ context.Context) (plog.Logs, error) { | ||
return plog.NewLogs(), retError | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
sorry, what is
next
here?There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@atoulme Good catch! I think this line is copied from somewhere. Removed it.