From 9996d1e52197293d485574b2cf7a263f390ac0f7 Mon Sep 17 00:00:00 2001 From: Noah Treuhaft Date: Wed, 18 Dec 2024 11:13:28 -0500 Subject: [PATCH] Implement vector error() function This includes a ztest for the assert operator because the error() function is the final missing piece required to make that operator work on vectors. --- runtime/vam/expr/function/function.go | 2 ++ runtime/vam/expr/function/types.go | 10 ++++++++++ runtime/ztests/expr/function/error.yaml | 17 +++++++++++++++++ runtime/ztests/op/assert.yaml | 13 +++++++++++++ 4 files changed, 42 insertions(+) create mode 100644 runtime/ztests/expr/function/error.yaml create mode 100644 runtime/ztests/op/assert.yaml diff --git a/runtime/vam/expr/function/function.go b/runtime/vam/expr/function/function.go index b489b08ea8..e35923d480 100644 --- a/runtime/vam/expr/function/function.go +++ b/runtime/vam/expr/function/function.go @@ -28,6 +28,8 @@ func New(zctx *super.Context, name string, narg int) (expr.Function, field.Path, case "every": path = field.Path{"ts"} f = &Bucket{zctx: zctx, name: name} + case "error": + f = &Error{zctx} case "fields": f = NewFields(zctx) case "grep": diff --git a/runtime/vam/expr/function/types.go b/runtime/vam/expr/function/types.go index 51d4c7d046..ef57940b81 100644 --- a/runtime/vam/expr/function/types.go +++ b/runtime/vam/expr/function/types.go @@ -15,6 +15,16 @@ func (t *TypeOf) Call(args ...vector.Any) vector.Any { return vector.NewConst(val, args[0].Len(), nil) } +// https://github.com/brimdata/super/blob/main/docs/language/functions.md#error +type Error struct { + zctx *super.Context +} + +func (e *Error) Call(args ...vector.Any) vector.Any { + vec := args[0] + return vector.NewError(e.zctx.LookupTypeError(vec.Type()), vec, nil) +} + // https://github.com/brimdata/super/blob/main/docs/language/functions.md#kind type Kind struct { zctx *super.Context diff --git a/runtime/ztests/expr/function/error.yaml b/runtime/ztests/expr/function/error.yaml new file mode 100644 index 0000000000..f8d30bdc0f --- /dev/null +++ b/runtime/ztests/expr/function/error.yaml @@ -0,0 +1,17 @@ +zed: yield error(this) + +vector: true + +input: | + 1 + "s" + {a:1} + null + null(int64) + +output: | + error(1) + error("s") + error({a:1}) + null(error(null)) + null(error(int64)) diff --git a/runtime/ztests/op/assert.yaml b/runtime/ztests/op/assert.yaml new file mode 100644 index 0000000000..aebf4f0bf0 --- /dev/null +++ b/runtime/ztests/op/assert.yaml @@ -0,0 +1,13 @@ +zed: assert a==1 + +vector: true + +input: | + {a:1} + {a:2} + 1 + +output: | + {a:1} + error({message:"assertion failed",expr:"a==1",on:{a:2}}) + error({message:"?-operator: bool predicate required",on:error("missing")})