// 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 expression import ( . "github.com/pingcap/check" ) var _ = Suite(&testSubstringSuite{}) type testSubstringSuite struct { } func (s *testSubstringSuite) TestSubstring(c *C) { tbl := []struct { str string pos int64 slen int64 result string }{ {"Quadratically", 5, -1, "ratically"}, {"foobarbar", 4, -1, "barbar"}, {"Quadratically", 5, 6, "ratica"}, {"Sakila", -3, -1, "ila"}, {"Sakila", -5, 3, "aki"}, {"Sakila", -4, 2, "ki"}, {"Sakila", 1000, 2, ""}, {"", 2, 3, ""}, } for _, v := range tbl { f := FunctionSubstring{ StrExpr: &Value{Val: v.str}, Pos: &Value{Val: v.pos}, } if v.slen != -1 { f.Len = &Value{Val: v.slen} } c.Assert(f.IsStatic(), Equals, true) fs := f.String() c.Assert(len(fs), Greater, 0) f1 := f.Clone() r, err := f.Eval(nil, nil) c.Assert(err, IsNil) s, ok := r.(string) c.Assert(ok, Equals, true) c.Assert(s, Equals, v.result) r1, err := f1.Eval(nil, nil) c.Assert(err, IsNil) s1, ok := r1.(string) c.Assert(ok, Equals, true) c.Assert(s, Equals, s1) } errTbl := []struct { str interface{} pos interface{} len interface{} result string }{ {1, 5, -1, "ratically"}, {"foobarbar", "4", -1, "barbar"}, {"Quadratically", 5, "6", "ratica"}, } for _, v := range errTbl { f := FunctionSubstring{ StrExpr: &Value{Val: v.str}, Pos: &Value{Val: v.pos}, } if v.len != -1 { f.Len = &Value{Val: v.len} } _, err := f.Eval(nil, nil) c.Assert(err, NotNil) } } func (s *testSubstringSuite) TestSubstringIndex(c *C) { tbl := []struct { str string delim string count int64 result string }{ {"www.mysql.com", ".", 2, "www.mysql"}, {"www.mysql.com", ".", -2, "mysql.com"}, {"www.mysql.com", ".", 20, "www.mysql.com"}, {"www.mysql.com", ".", -20, "www.mysql.com"}, {"www.mysql.com", "_", 2, "www.mysql.com"}, {"www.mysql.com", "_", 0, ""}, } for _, v := range tbl { f := FunctionSubstringIndex{ StrExpr: &Value{Val: v.str}, Delim: &Value{Val: v.delim}, Count: &Value{Val: v.count}, } c.Assert(f.IsStatic(), Equals, true) fs := f.String() c.Assert(len(fs), Greater, 0) f1 := f.Clone() r, err := f.Eval(nil, nil) c.Assert(err, IsNil) s, ok := r.(string) c.Assert(ok, Equals, true) c.Assert(s, Equals, v.result) r1, err := f1.Eval(nil, nil) c.Assert(err, IsNil) s1, ok := r1.(string) c.Assert(ok, Equals, true) c.Assert(s, Equals, s1) } } func (s *testSubstringSuite) TestLocate(c *C) { tbl := []struct { substr interface{} str interface{} pos interface{} result interface{} }{ {"bar", "foobarbar", -1, 4}, {"xbar", "foobarbar", -1, 0}, {"bar", "foobarbar", 5, 7}, {nil, "foobarbar", 5, nil}, {"bar", nil, 5, nil}, {1, 2, -1, 0}, {"bar", "foobarbar", "5", 7}, } for _, v := range tbl { f := FunctionLocate{ SubStr: &Value{Val: v.substr}, Str: &Value{Val: v.str}, } if v.pos != -1 { f.Pos = &Value{Val: v.pos} } c.Assert(f.IsStatic(), Equals, true) fs := f.String() c.Assert(len(fs), Greater, 0) f1 := f.Clone() r, err := f.Eval(nil, nil) c.Assert(err, IsNil) c.Assert(r, Equals, v.result) r1, err := f1.Eval(nil, nil) c.Assert(err, IsNil) c.Assert(r, Equals, r1) } errTbl := []struct { substr interface{} str interface{} pos interface{} result interface{} }{ {1, 5, -1, 0}, {"foobarbar", "4", -1, 0}, {"Quadratically", "Qua", "6", 0}, } for _, v := range errTbl { f := FunctionLocate{ Str: &Value{Val: v.str}, SubStr: &Value{Val: v.substr}, Pos: &Value{Val: v.pos}, } _, err := f.Eval(nil, nil) c.Assert(err, NotNil) } }