This repository was archived by the owner on Jan 28, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 109
/
Copy pathcoalesce_test.go
64 lines (55 loc) · 2.01 KB
/
coalesce_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
package function
import (
"testing"
"github.com/src-d/go-mysql-server/sql"
"github.com/src-d/go-mysql-server/sql/expression"
"github.com/stretchr/testify/require"
)
func TestEmptyCoalesce(t *testing.T) {
_, err := NewCoalesce()
require.True(t, sql.ErrInvalidArgumentNumber.Is(err))
}
func TestCoalesce(t *testing.T) {
testCases := []struct {
name string
input []sql.Expression
expected interface{}
typ sql.Type
nullable bool
}{
{"coalesce(1, 2, 3)", []sql.Expression{expression.NewLiteral(1, sql.Int32), expression.NewLiteral(2, sql.Int32), expression.NewLiteral(3, sql.Int32)}, 1, sql.Int32, false},
{"coalesce(NULL, NULL, 3)", []sql.Expression{nil, nil, expression.NewLiteral(3, sql.Int32)}, 3, sql.Int32, false},
{"coalesce(NULL, NULL, '3')", []sql.Expression{nil, nil, expression.NewLiteral("3", sql.Text)}, "3", sql.Text, false},
{"coalesce(NULL, '2', 3)", []sql.Expression{nil, expression.NewLiteral("2", sql.Text), expression.NewLiteral(3, sql.Int32)}, "2", sql.Text, false},
{"coalesce(NULL, NULL, NULL)", []sql.Expression{nil, nil, nil}, nil, nil, true},
}
for _, tt := range testCases {
c, err := NewCoalesce(tt.input...)
require.NoError(t, err)
require.Equal(t, tt.typ, c.Type())
require.Equal(t, tt.nullable, c.IsNullable())
v, err := c.Eval(sql.NewEmptyContext(), nil)
require.NoError(t, err)
require.Equal(t, tt.expected, v)
}
}
func TestComposeCoalasce(t *testing.T) {
c1, err := NewCoalesce(nil)
require.NoError(t, err)
require.Equal(t, nil, c1.Type())
v, err := c1.Eval(sql.NewEmptyContext(), nil)
require.NoError(t, err)
require.Equal(t, nil, v)
c2, err := NewCoalesce(nil, expression.NewLiteral(1, sql.Int32))
require.NoError(t, err)
require.Equal(t, sql.Int32, c2.Type())
v, err = c2.Eval(sql.NewEmptyContext(), nil)
require.NoError(t, err)
require.Equal(t, 1, v)
c, err := NewCoalesce(nil, c1, c2)
require.NoError(t, err)
require.Equal(t, sql.Int32, c.Type())
v, err = c.Eval(sql.NewEmptyContext(), nil)
require.NoError(t, err)
require.Equal(t, 1, v)
}