Skip to content

Commit

Permalink
Signozlogspipelineprocessor: add support for using severity in route …
Browse files Browse the repository at this point in the history
…operator (pipeline filter) expressions (#405)

Contributes to SigNoz/engineering-pod#1446
  • Loading branch information
raj-k-singh authored Sep 20, 2024
1 parent 8969d16 commit 629ff58
Show file tree
Hide file tree
Showing 4 changed files with 92 additions and 4 deletions.
48 changes: 48 additions & 0 deletions processor/signozlogspipelineprocessor/processor_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ package signozlogspipelineprocessor
import (
"context"
"encoding/hex"
"fmt"
"testing"
"time"

Expand Down Expand Up @@ -305,6 +306,53 @@ func TestSignozLogPipelineWithRouterOp(t *testing.T) {
validateProcessorBehavior(t, confYaml, input, expectedOutput)
}

// logstransform in otel-collector-contrib doesn't support using severity text and number in route expressions
func TestSeverityBasedRouteExpressions(t *testing.T) {
for _, routeExpr := range []string{
`severity_number == 9`,
`severity_text == "INFO"`,
} {
confYaml := fmt.Sprintf(`
operators:
- default: noop
id: router_signoz
routes:
- expr: %s
output: add-test-value
type: router
- id: add-test-value
on_error: send
type: add
field: attributes.test
value: test-value
- id: noop
type: noop
`, routeExpr)

// should process matching log
input := []plog.Logs{makePlogWithTopLevelFields(
t, "test log", map[string]any{},
map[string]any{"severity_text": "INFO", "severity_number": 9},
)}
expectedOutput := []plog.Logs{makePlogWithTopLevelFields(
t, "test log", map[string]any{"test": "test-value"},
map[string]any{"severity_text": "INFO", "severity_number": 9},
)}
validateProcessorBehavior(t, confYaml, input, expectedOutput)

// should ignore non-matching log
input = []plog.Logs{makePlogWithTopLevelFields(
t, "test log", map[string]any{},
map[string]any{"severity_text": "ERROR", "severity_number": 17},
)}
expectedOutput = []plog.Logs{makePlogWithTopLevelFields(
t, "test log", map[string]any{},
map[string]any{"severity_text": "ERROR", "severity_number": 17},
)}
validateProcessorBehavior(t, confYaml, input, expectedOutput)
}
}

func validateProcessorBehavior(
t *testing.T,
confYaml string,
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
// Mostly brought in as-is from otel-collector-contrib with minor changes
// For example: includes severity_text and severity_number in GetExprEnv

package signozstanzahelper

import (
"os"
"sync"

"github.com/open-telemetry/opentelemetry-collector-contrib/pkg/stanza/entry"
)

var envPool = sync.Pool{
New: func() any {
return map[string]any{
"os_env_func": os.Getenv,
}
},
}

// GetExprEnv returns a map of key/value pairs that can be be used to evaluate an expression
func GetExprEnv(e *entry.Entry) map[string]any {
env := envPool.Get().(map[string]any)
env["$"] = e.Body
env["body"] = e.Body
env["attributes"] = e.Attributes
env["resource"] = e.Resource
env["timestamp"] = e.Timestamp
env["severity_text"] = e.SeverityText
env["severity_number"] = int(e.Severity)

return env
}

// PutExprEnv adds a key/value pair that will can be used to evaluate an expression
func PutExprEnv(e map[string]any) {
envPool.Put(e)
}
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import (
"fmt"
"strings"

signozstanzahelper "github.com/SigNoz/signoz-otel-collector/processor/signozlogspipelineprocessor/stanza/operator/helper"
"github.com/expr-lang/expr/vm"

"github.com/open-telemetry/opentelemetry-collector-contrib/pkg/stanza/entry"
Expand All @@ -33,8 +34,8 @@ func (t *Transformer) Transform(e *entry.Entry) error {
return e.Set(t.Field, t.Value)
}
if t.program != nil {
env := helper.GetExprEnv(e)
defer helper.PutExprEnv(env)
env := signozstanzahelper.GetExprEnv(e)
defer signozstanzahelper.PutExprEnv(env)

result, err := vm.Run(t.program, env)
if err != nil {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ import (
"context"
"fmt"

signozstanzahelper "github.com/SigNoz/signoz-otel-collector/processor/signozlogspipelineprocessor/stanza/operator/helper"
"github.com/expr-lang/expr/vm"
"go.uber.org/zap"

Expand Down Expand Up @@ -35,8 +36,8 @@ func (t *Transformer) CanProcess() bool {

// Process will route incoming entries based on matching expressions
func (t *Transformer) Process(ctx context.Context, entry *entry.Entry) error {
env := helper.GetExprEnv(entry)
defer helper.PutExprEnv(env)
env := signozstanzahelper.GetExprEnv(entry)
defer signozstanzahelper.PutExprEnv(env)

for _, route := range t.routes {
matches, err := vm.Run(route.Expression, env)
Expand Down

0 comments on commit 629ff58

Please sign in to comment.