Files
streamsql/functions/functions_array_test.go
T
2025-08-06 17:18:50 +08:00

97 lines
2.2 KiB
Go

package functions
import (
"reflect"
"testing"
)
// 测试数组函数
func TestArrayFunctions(t *testing.T) {
tests := []struct {
name string
funcName string
args []interface{}
expected interface{}
}{
{
name: "array_length basic",
funcName: "array_length",
args: []interface{}{[]interface{}{1, 2, 3}},
expected: 3,
},
{
name: "array_contains true",
funcName: "array_contains",
args: []interface{}{[]interface{}{1, 2, 3}, 2},
expected: true,
},
{
name: "array_contains false",
funcName: "array_contains",
args: []interface{}{[]interface{}{1, 2, 3}, 4},
expected: false,
},
{
name: "array_position found",
funcName: "array_position",
args: []interface{}{[]interface{}{1, 2, 3}, 2},
expected: 2,
},
{
name: "array_position not found",
funcName: "array_position",
args: []interface{}{[]interface{}{1, 2, 3}, 4},
expected: 0,
},
{
name: "array_remove basic",
funcName: "array_remove",
args: []interface{}{[]interface{}{1, 2, 3, 2}, 2},
expected: []interface{}{1, 3},
},
{
name: "array_distinct basic",
funcName: "array_distinct",
args: []interface{}{[]interface{}{1, 2, 2, 3, 1}},
expected: []interface{}{1, 2, 3},
},
{
name: "array_intersect basic",
funcName: "array_intersect",
args: []interface{}{[]interface{}{1, 2, 3}, []interface{}{2, 3, 4}},
expected: []interface{}{2, 3},
},
{
name: "array_union basic",
funcName: "array_union",
args: []interface{}{[]interface{}{1, 2}, []interface{}{2, 3}},
expected: []interface{}{1, 2, 3},
},
{
name: "array_except basic",
funcName: "array_except",
args: []interface{}{[]interface{}{1, 2, 3}, []interface{}{2}},
expected: []interface{}{1, 3},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
fn, exists := Get(tt.funcName)
if !exists {
t.Fatalf("Function %s not found", tt.funcName)
}
result, err := fn.Execute(&FunctionContext{}, tt.args)
if err != nil {
t.Errorf("Execute() error = %v", err)
return
}
if !reflect.DeepEqual(result, tt.expected) {
t.Errorf("Execute() = %v, want %v", result, tt.expected)
}
})
}
}