mirror of
https://github.com/jwetzell/showbridge-go.git
synced 2026-04-27 13:25:40 +00:00
wrap all payload types for expr env
This commit is contained in:
@@ -15,27 +15,21 @@ type FilterExpr struct {
|
||||
Program *vm.Program
|
||||
}
|
||||
|
||||
type PayloadStruct struct {
|
||||
func SafeExprEnv(payload any) any {
|
||||
exprEnv := ExprEnv{
|
||||
Payload: payload,
|
||||
}
|
||||
|
||||
return exprEnv
|
||||
}
|
||||
|
||||
type ExprEnv struct {
|
||||
Payload any
|
||||
}
|
||||
|
||||
func (se *FilterExpr) Process(ctx context.Context, payload any) (any, error) {
|
||||
payloadType := fmt.Sprintf("%T", payload)
|
||||
|
||||
exprEnv := payload
|
||||
|
||||
switch payloadType {
|
||||
case "uint", "uint8", "uint16", "uint32", "uint64":
|
||||
exprEnv = PayloadStruct{Payload: payload}
|
||||
case "int", "int8", "int16", "int32", "int64":
|
||||
exprEnv = PayloadStruct{Payload: payload}
|
||||
case "float32", "float64":
|
||||
exprEnv = PayloadStruct{Payload: payload}
|
||||
case "string":
|
||||
exprEnv = PayloadStruct{Payload: payload}
|
||||
case "bool":
|
||||
exprEnv = PayloadStruct{Payload: payload}
|
||||
}
|
||||
exprEnv := SafeExprEnv(payload)
|
||||
|
||||
output, err := expr.Run(se.Program, exprEnv)
|
||||
if err != nil {
|
||||
|
||||
@@ -17,22 +17,7 @@ type ScriptExpr struct {
|
||||
|
||||
func (se *ScriptExpr) Process(ctx context.Context, payload any) (any, error) {
|
||||
|
||||
payloadType := fmt.Sprintf("%T", payload)
|
||||
|
||||
exprEnv := payload
|
||||
|
||||
switch payloadType {
|
||||
case "uint", "uint8", "uint16", "uint32", "uint64":
|
||||
exprEnv = PayloadStruct{Payload: payload}
|
||||
case "int", "int8", "int16", "int32", "int64":
|
||||
exprEnv = PayloadStruct{Payload: payload}
|
||||
case "float32", "float64":
|
||||
exprEnv = PayloadStruct{Payload: payload}
|
||||
case "string":
|
||||
exprEnv = PayloadStruct{Payload: payload}
|
||||
case "bool":
|
||||
exprEnv = PayloadStruct{Payload: payload}
|
||||
}
|
||||
exprEnv := SafeExprEnv(payload)
|
||||
|
||||
output, err := expr.Run(se.Program, exprEnv)
|
||||
if err != nil {
|
||||
|
||||
@@ -39,7 +39,7 @@ func TestGoodFilterExpr(t *testing.T) {
|
||||
{
|
||||
name: "number",
|
||||
params: map[string]any{
|
||||
"expression": "Int > 0",
|
||||
"expression": "Payload.Int > 0",
|
||||
},
|
||||
payload: TestStruct{
|
||||
Int: 1,
|
||||
@@ -51,7 +51,7 @@ func TestGoodFilterExpr(t *testing.T) {
|
||||
{
|
||||
name: "string",
|
||||
params: map[string]any{
|
||||
"expression": "String == 'hello'",
|
||||
"expression": "Payload.String == 'hello'",
|
||||
},
|
||||
payload: TestStruct{
|
||||
String: "hello",
|
||||
@@ -63,7 +63,7 @@ func TestGoodFilterExpr(t *testing.T) {
|
||||
{
|
||||
name: "not matching",
|
||||
params: map[string]any{
|
||||
"expression": "Int > 0",
|
||||
"expression": "Payload.Int > 0",
|
||||
},
|
||||
payload: TestStruct{
|
||||
Int: 0,
|
||||
@@ -136,12 +136,12 @@ func TestBadFilterExpr(t *testing.T) {
|
||||
{
|
||||
name: "accessing missing field",
|
||||
params: map[string]any{
|
||||
"expression": "foo + bar",
|
||||
"expression": "Payload.foo + Payload.bar",
|
||||
},
|
||||
payload: map[string]any{
|
||||
"foo": 1,
|
||||
},
|
||||
errorString: "invalid operation: int + <nil> (1:5)\n | foo + bar\n | ....^",
|
||||
errorString: "invalid operation: int + <nil> (1:13)\n | Payload.foo + Payload.bar\n | ............^",
|
||||
},
|
||||
}
|
||||
|
||||
|
||||
@@ -28,58 +28,6 @@ func TestScriptExprFromRegistry(t *testing.T) {
|
||||
}
|
||||
}
|
||||
|
||||
func TestScriptExprNoProgram(t *testing.T) {
|
||||
registration, ok := processor.ProcessorRegistry["script.expr"]
|
||||
if !ok {
|
||||
t.Fatalf("script.expr processor not registered")
|
||||
}
|
||||
|
||||
_, err := registration.New(config.ProcessorConfig{
|
||||
Type: "script.expr",
|
||||
Params: map[string]any{},
|
||||
})
|
||||
|
||||
if err == nil {
|
||||
t.Fatalf("script.expr processor should have thrown an error when creating")
|
||||
}
|
||||
}
|
||||
|
||||
func TestScriptExprBadConfigWrongExpressionType(t *testing.T) {
|
||||
registration, ok := processor.ProcessorRegistry["script.expr"]
|
||||
if !ok {
|
||||
t.Fatalf("script.expr processor not registered")
|
||||
}
|
||||
|
||||
_, err := registration.New(config.ProcessorConfig{
|
||||
Type: "script.expr",
|
||||
Params: map[string]any{
|
||||
"expression": 12345,
|
||||
},
|
||||
})
|
||||
|
||||
if err == nil {
|
||||
t.Fatalf("script.expr processor should have thrown an error when creating with non-string expression")
|
||||
}
|
||||
}
|
||||
|
||||
func TestScriptExprBadConfigNonCompilingExpression(t *testing.T) {
|
||||
registration, ok := processor.ProcessorRegistry["script.expr"]
|
||||
if !ok {
|
||||
t.Fatalf("script.expr processor not registered")
|
||||
}
|
||||
|
||||
_, err := registration.New(config.ProcessorConfig{
|
||||
Type: "script.expr",
|
||||
Params: map[string]any{
|
||||
"expression": "foo + ",
|
||||
},
|
||||
})
|
||||
|
||||
if err == nil {
|
||||
t.Fatalf("script.expr processor should have thrown an error when creating with non-compiling expression")
|
||||
}
|
||||
}
|
||||
|
||||
func TestGoodScriptExpr(t *testing.T) {
|
||||
tests := []struct {
|
||||
name string
|
||||
@@ -90,7 +38,7 @@ func TestGoodScriptExpr(t *testing.T) {
|
||||
{
|
||||
name: "number",
|
||||
params: map[string]any{
|
||||
"expression": "foo + bar",
|
||||
"expression": "Payload.foo + Payload.bar",
|
||||
},
|
||||
payload: map[string]any{
|
||||
"foo": 1,
|
||||
@@ -101,7 +49,7 @@ func TestGoodScriptExpr(t *testing.T) {
|
||||
{
|
||||
name: "string",
|
||||
params: map[string]any{
|
||||
"expression": "foo + bar",
|
||||
"expression": "Payload.foo + Payload.bar",
|
||||
},
|
||||
payload: map[string]any{
|
||||
"foo": "1",
|
||||
@@ -145,18 +93,24 @@ func TestBadScriptExpr(t *testing.T) {
|
||||
tests := []struct {
|
||||
name string
|
||||
params map[string]any
|
||||
payload map[string]any
|
||||
payload any
|
||||
errorString string
|
||||
}{
|
||||
{
|
||||
name: "no expression parameter",
|
||||
params: map[string]any{},
|
||||
payload: map[string]any{"foo": 1, "bar": 1},
|
||||
errorString: "script.expr expression error: not found",
|
||||
},
|
||||
{
|
||||
name: "accessing missing field",
|
||||
params: map[string]any{
|
||||
"expression": "foo + bar",
|
||||
"expression": "Payload.foo + Payload.bar",
|
||||
},
|
||||
payload: map[string]any{
|
||||
"foo": 1,
|
||||
},
|
||||
errorString: "invalid operation: int + <nil> (1:5)\n | foo + bar\n | ....^",
|
||||
errorString: "invalid operation: int + <nil> (1:13)\n | Payload.foo + Payload.bar\n | ............^",
|
||||
},
|
||||
}
|
||||
|
||||
@@ -172,6 +126,13 @@ func TestBadScriptExpr(t *testing.T) {
|
||||
Params: test.params,
|
||||
})
|
||||
|
||||
if err != nil {
|
||||
if err.Error() != test.errorString {
|
||||
t.Fatalf("script.expr got error '%s', expected '%s'", err.Error(), test.errorString)
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
got, err := processorInstance.Process(t.Context(), test.payload)
|
||||
|
||||
if err == nil {
|
||||
|
||||
Reference in New Issue
Block a user