Files
tidb/rset/rsets/fields_test.go
2015-10-17 10:47:37 +08:00

123 lines
3.4 KiB
Go

// Copyright 2015 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 rsets
import (
. "github.com/pingcap/check"
"github.com/pingcap/tidb/expression"
"github.com/pingcap/tidb/field"
"github.com/pingcap/tidb/model"
"github.com/pingcap/tidb/plan/plans"
"github.com/pingcap/tidb/table/tables"
)
var _ = Suite(&testSelectFieldsPlannerSuite{})
type testSelectFieldsPlannerSuite struct {
sr *SelectFieldsRset
fr *SelectFromDualRset
}
func (s *testSelectFieldsPlannerSuite) SetUpSuite(c *C) {
names := []string{"id", "name"}
tblPlan := newTestTablePlan(testData, names)
resultFields := tblPlan.GetFields()
fields := make([]*field.Field, len(resultFields))
for i, resultField := range resultFields {
name := resultField.Name
fields[i] = &field.Field{Expr: &expression.Ident{CIStr: model.NewCIStr(name)}}
}
selectList := &plans.SelectList{
HiddenFieldOffset: len(resultFields),
ResultFields: resultFields,
Fields: fields,
}
s.sr = &SelectFieldsRset{Src: tblPlan, SelectList: selectList}
}
func (s *testSelectFieldsPlannerSuite) TestDistinctPlanner(c *C) {
// check src plan, like `select c1, c2 from t`.
p, err := s.sr.Plan(nil)
c.Assert(err, IsNil)
_, ok := p.(*testTablePlan)
c.Assert(ok, IsTrue, Commentf("%T", p))
// check SelectFieldsDefaultPlan, like `select c1, 1 from t`.
fld := &field.Field{Expr: expression.Value{Val: 1}}
s.sr.SelectList.Fields[0] = fld
p, err = s.sr.Plan(nil)
c.Assert(err, IsNil)
_, ok = p.(*plans.SelectFieldsDefaultPlan)
c.Assert(ok, IsTrue)
oldFld := s.sr.SelectList.Fields[1]
s.sr.SelectList.Fields = s.sr.SelectList.Fields[:1]
s.sr.SelectList.HiddenFieldOffset = len(s.sr.SelectList.Fields)
p, err = s.sr.Plan(nil)
c.Assert(err, IsNil)
_, ok = p.(*plans.SelectFieldsDefaultPlan)
c.Assert(ok, IsTrue)
// check src plan set TableNilPlan, like `select 1 from t`.
tdp := &plans.TableDefaultPlan{T: &tables.Table{}, Fields: s.sr.SelectList.ResultFields}
s.sr.Src = tdp
s.sr.SelectList.Fields = []*field.Field{fld}
s.sr.SelectList.HiddenFieldOffset = len(s.sr.SelectList.Fields)
p, err = s.sr.Plan(nil)
c.Assert(err, IsNil)
sp, ok := p.(*plans.SelectFieldsDefaultPlan)
c.Assert(ok, IsTrue)
c.Assert(sp, NotNil)
_, ok = sp.Src.(*plans.TableNilPlan)
c.Assert(ok, IsTrue)
// cover isConst check, like `select 1, c1 from t`
s.sr.SelectList.Fields = []*field.Field{fld, oldFld}
s.sr.SelectList.HiddenFieldOffset = len(s.sr.SelectList.Fields)
p, err = s.sr.Plan(nil)
c.Assert(err, IsNil)
_, ok = sp.Src.(*plans.TableNilPlan)
c.Assert(ok, IsTrue)
}
func (s *testSelectFieldsPlannerSuite) TestFieldPlanner(c *C) {
fields := make([]*field.Field, 1)
fields[0] = &field.Field{Expr: &expression.Value{Val: "abc"}}
s.fr = &SelectFromDualRset{Fields: fields}
p, err := s.fr.Plan(nil)
c.Assert(err, IsNil)
_, ok := p.(*plans.SelectFromDualPlan)
c.Assert(ok, IsTrue)
fields[0] = &field.Field{Expr: &expression.Ident{CIStr: model.NewCIStr("value")}}
s.fr = &SelectFromDualRset{Fields: fields}
_, err = s.fr.Plan(nil)
c.Assert(err, NotNil)
}