-
Notifications
You must be signed in to change notification settings - Fork 90
/
Copy pathtypes_test.go
77 lines (68 loc) · 1.73 KB
/
types_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
65
66
67
68
69
70
71
72
73
74
75
76
77
package clickhouse
import (
"database/sql/driver"
"net"
"testing"
"time"
"github.com/stretchr/testify/assert"
)
func TestArray(t *testing.T) {
testCases := []struct {
value interface{}
expected driver.Value
}{
{[]int16{1, 2}, []byte("[1,2]")},
{[]int32{1, 2}, []byte("[1,2]")},
{[]int64{1, 2}, []byte("[1,2]")},
{[]uint16{1, 2}, []byte("[1,2]")},
{[]uint32{1, 2}, []byte("[1,2]")},
{[]uint64{1, 2}, []byte("[1,2]")},
{[]uint64{}, []byte("[]")},
}
for _, tc := range testCases {
dv, err := Array(tc.value).Value()
if assert.NoError(t, err) {
assert.Equal(t, tc.expected, dv)
}
}
}
func TestDate(t *testing.T) {
d := time.Date(2016, 4, 4, 0, 0, 0, 0, time.Local)
dv, err := Date(d).Value()
if assert.NoError(t, err) {
assert.Equal(t, []byte("'2016-04-04'"), dv)
}
}
func TestUInt64(t *testing.T) {
u := uint64(1) << 63
dv, err := UInt64(u).Value()
if assert.NoError(t, err) {
assert.Equal(t, []byte("9223372036854775808"), dv)
}
}
func TestDecimal(t *testing.T) {
dv, err := Decimal32("1000", 4).Value()
if assert.NoError(t, err) {
assert.Equal(t, []byte("toDecimal32('1000', 4)"), dv)
}
dv, err = Decimal64(100, 1).Value()
if assert.NoError(t, err) {
assert.Equal(t, []byte("toDecimal64('100', 1)"), dv)
}
dv, err = Decimal128(100.01, 1).Value()
if assert.NoError(t, err) {
assert.Equal(t, []byte("toDecimal128('100.01', 1)"), dv)
}
}
func TestIP(t *testing.T) {
ipv4 := net.ParseIP("127.0.0.1")
assert.NotNil(t, ipv4)
ipv6 := net.ParseIP("2001:44c8:129:2632:33:0:252:2")
assert.NotNil(t, ipv6)
dv, err := IP(ipv4).Value()
assert.NoError(t, err)
assert.Equal(t, "127.0.0.1", dv)
dv, err = IP(ipv6).Value()
assert.NoError(t, err)
assert.Equal(t, "2001:44c8:129:2632:33:0:252:2", dv)
}