forked from pingcap/tidb
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuiltin_info_vec_test.go
118 lines (110 loc) · 4.35 KB
/
builtin_info_vec_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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
// Copyright 2019 PingCAP, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// See the License for the specific language governing permissions and
// limitations under the License.
package expression
import (
"encoding/hex"
"math/rand"
"testing"
. "github.com/pingcap/check"
"github.com/pingcap/parser/ast"
"github.com/pingcap/parser/mysql"
"github.com/pingcap/tidb/kv"
"github.com/pingcap/tidb/tablecodec"
"github.com/pingcap/tidb/types"
)
type tidbKeyGener struct {
inner *defaultGener
}
func (g *tidbKeyGener) gen() interface{} {
tableID := g.inner.gen().(int64)
var result []byte
if rand.Intn(2) == 1 {
// Generate a record key
handle := g.inner.gen().(int64)
result = tablecodec.EncodeRowKeyWithHandle(tableID, kv.IntHandle(handle))
} else {
// Generate an index key
idx := g.inner.gen().(int64)
result = tablecodec.EncodeTableIndexPrefix(tableID, idx)
}
return hex.EncodeToString(result)
}
var vecBuiltinInfoCases = map[string][]vecExprBenchCase{
ast.Version: {
{retEvalType: types.ETString, childrenTypes: []types.EvalType{}},
},
ast.TiDBVersion: {
{retEvalType: types.ETString, childrenTypes: []types.EvalType{}},
},
ast.CurrentUser: {
{retEvalType: types.ETString, childrenTypes: []types.EvalType{}},
},
ast.FoundRows: {
{retEvalType: types.ETInt},
},
ast.Database: {
{retEvalType: types.ETString, childrenTypes: []types.EvalType{}},
},
ast.User: {
{retEvalType: types.ETString, childrenTypes: []types.EvalType{}},
},
ast.TiDBDecodeKey: {
{
retEvalType: types.ETString,
childrenTypes: []types.EvalType{types.ETString},
geners: []dataGenerator{&tidbKeyGener{
inner: newDefaultGener(0, types.ETInt),
}},
},
},
ast.RowCount: {
{retEvalType: types.ETInt, childrenTypes: []types.EvalType{}},
},
ast.CurrentRole: {
{retEvalType: types.ETString, childrenTypes: []types.EvalType{}},
},
ast.TiDBIsDDLOwner: {
{retEvalType: types.ETInt, childrenTypes: []types.EvalType{}},
},
ast.ConnectionID: {
{retEvalType: types.ETInt, childrenTypes: []types.EvalType{}},
},
ast.LastInsertId: {
{retEvalType: types.ETInt, childrenTypes: []types.EvalType{}},
{retEvalType: types.ETInt, childrenTypes: []types.EvalType{types.ETInt}},
},
ast.Benchmark: {
{retEvalType: types.ETInt, childrenTypes: []types.EvalType{types.ETInt, types.ETInt},
constants: []*Constant{{Value: types.NewIntDatum(10), RetType: types.NewFieldType(mysql.TypeLonglong)}, nil}},
{retEvalType: types.ETInt, childrenTypes: []types.EvalType{types.ETInt, types.ETReal},
constants: []*Constant{{Value: types.NewIntDatum(11), RetType: types.NewFieldType(mysql.TypeLonglong)}, nil}},
{retEvalType: types.ETInt, childrenTypes: []types.EvalType{types.ETInt, types.ETDecimal},
constants: []*Constant{{Value: types.NewIntDatum(12), RetType: types.NewFieldType(mysql.TypeLonglong)}, nil}},
{retEvalType: types.ETInt, childrenTypes: []types.EvalType{types.ETInt, types.ETString},
constants: []*Constant{{Value: types.NewIntDatum(13), RetType: types.NewFieldType(mysql.TypeLonglong)}, nil}},
{retEvalType: types.ETInt, childrenTypes: []types.EvalType{types.ETInt, types.ETDatetime},
constants: []*Constant{{Value: types.NewIntDatum(14), RetType: types.NewFieldType(mysql.TypeLonglong)}, nil}},
{retEvalType: types.ETInt, childrenTypes: []types.EvalType{types.ETInt, types.ETTimestamp},
constants: []*Constant{{Value: types.NewIntDatum(15), RetType: types.NewFieldType(mysql.TypeLonglong)}, nil}},
{retEvalType: types.ETInt, childrenTypes: []types.EvalType{types.ETInt, types.ETDuration},
constants: []*Constant{{Value: types.NewIntDatum(16), RetType: types.NewFieldType(mysql.TypeLonglong)}, nil}},
{retEvalType: types.ETInt, childrenTypes: []types.EvalType{types.ETInt, types.ETJson},
constants: []*Constant{{Value: types.NewIntDatum(17), RetType: types.NewFieldType(mysql.TypeLonglong)}, nil}},
},
}
func (s *testEvaluatorSuite) TestVectorizedBuiltinInfoFunc(c *C) {
testVectorizedBuiltinFunc(c, vecBuiltinInfoCases)
}
func BenchmarkVectorizedBuiltinInfoFunc(b *testing.B) {
benchmarkVectorizedBuiltinFunc(b, vecBuiltinInfoCases)
}