2016-06-16 11:15:56 +02:00
|
|
|
package mysql
|
|
|
|
|
|
|
|
import (
|
2019-01-01 10:57:46 +02:00
|
|
|
"strings"
|
2016-06-16 11:15:56 +02:00
|
|
|
"testing"
|
|
|
|
|
2017-02-12 13:13:54 +02:00
|
|
|
"github.com/pingcap/check"
|
2016-06-16 11:15:56 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
func Test(t *testing.T) {
|
|
|
|
check.TestingT(t)
|
|
|
|
}
|
|
|
|
|
|
|
|
type mysqlTestSuite struct {
|
|
|
|
}
|
|
|
|
|
|
|
|
var _ = check.Suite(&mysqlTestSuite{})
|
|
|
|
|
2019-01-01 10:57:46 +02:00
|
|
|
func (t *mysqlTestSuite) SetUpSuite(c *check.C) {
|
2016-06-16 11:15:56 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2019-01-01 10:57:46 +02:00
|
|
|
func (t *mysqlTestSuite) TearDownSuite(c *check.C) {
|
2016-06-16 11:15:56 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *mysqlTestSuite) TestMysqlGTIDInterval(c *check.C) {
|
|
|
|
i, err := parseInterval("1-2")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
c.Assert(i, check.DeepEquals, Interval{1, 3})
|
|
|
|
|
|
|
|
i, err = parseInterval("1")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
c.Assert(i, check.DeepEquals, Interval{1, 2})
|
|
|
|
|
|
|
|
i, err = parseInterval("1-1")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
c.Assert(i, check.DeepEquals, Interval{1, 2})
|
|
|
|
|
|
|
|
i, err = parseInterval("1-2")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *mysqlTestSuite) TestMysqlGTIDIntervalSlice(c *check.C) {
|
|
|
|
i := IntervalSlice{Interval{1, 2}, Interval{2, 4}, Interval{2, 3}}
|
|
|
|
i.Sort()
|
|
|
|
c.Assert(i, check.DeepEquals, IntervalSlice{Interval{1, 2}, Interval{2, 3}, Interval{2, 4}})
|
|
|
|
n := i.Normalize()
|
|
|
|
c.Assert(n, check.DeepEquals, IntervalSlice{Interval{1, 4}})
|
|
|
|
|
|
|
|
i = IntervalSlice{Interval{1, 2}, Interval{3, 5}, Interval{1, 3}}
|
|
|
|
i.Sort()
|
|
|
|
c.Assert(i, check.DeepEquals, IntervalSlice{Interval{1, 2}, Interval{1, 3}, Interval{3, 5}})
|
|
|
|
n = i.Normalize()
|
|
|
|
c.Assert(n, check.DeepEquals, IntervalSlice{Interval{1, 5}})
|
|
|
|
|
|
|
|
i = IntervalSlice{Interval{1, 2}, Interval{4, 5}, Interval{1, 3}}
|
|
|
|
i.Sort()
|
|
|
|
c.Assert(i, check.DeepEquals, IntervalSlice{Interval{1, 2}, Interval{1, 3}, Interval{4, 5}})
|
|
|
|
n = i.Normalize()
|
|
|
|
c.Assert(n, check.DeepEquals, IntervalSlice{Interval{1, 3}, Interval{4, 5}})
|
|
|
|
|
2019-01-01 10:57:46 +02:00
|
|
|
i = IntervalSlice{Interval{1, 4}, Interval{2, 3}}
|
|
|
|
i.Sort()
|
|
|
|
c.Assert(i, check.DeepEquals, IntervalSlice{Interval{1, 4}, Interval{2, 3}})
|
|
|
|
n = i.Normalize()
|
|
|
|
c.Assert(n, check.DeepEquals, IntervalSlice{Interval{1, 4}})
|
|
|
|
|
2016-06-16 11:15:56 +02:00
|
|
|
n1 := IntervalSlice{Interval{1, 3}, Interval{4, 5}}
|
|
|
|
n2 := IntervalSlice{Interval{1, 2}}
|
|
|
|
|
|
|
|
c.Assert(n1.Contain(n2), check.Equals, true)
|
|
|
|
c.Assert(n2.Contain(n1), check.Equals, false)
|
|
|
|
|
|
|
|
n1 = IntervalSlice{Interval{1, 3}, Interval{4, 5}}
|
|
|
|
n2 = IntervalSlice{Interval{1, 6}}
|
|
|
|
|
|
|
|
c.Assert(n1.Contain(n2), check.Equals, false)
|
|
|
|
c.Assert(n2.Contain(n1), check.Equals, true)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *mysqlTestSuite) TestMysqlGTIDCodec(c *check.C) {
|
|
|
|
us, err := ParseUUIDSet("de278ad0-2106-11e4-9f8e-6edd0ca20947:1-2")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
|
|
|
|
c.Assert(us.String(), check.Equals, "de278ad0-2106-11e4-9f8e-6edd0ca20947:1-2")
|
|
|
|
|
|
|
|
buf := us.Encode()
|
|
|
|
err = us.Decode(buf)
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
|
|
|
|
gs, err := ParseMysqlGTIDSet("de278ad0-2106-11e4-9f8e-6edd0ca20947:1-2,de278ad0-2106-11e4-9f8e-6edd0ca20948:1-2")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
|
|
|
|
buf = gs.Encode()
|
|
|
|
o, err := DecodeMysqlGTIDSet(buf)
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
c.Assert(gs, check.DeepEquals, o)
|
|
|
|
}
|
|
|
|
|
2019-01-01 10:57:46 +02:00
|
|
|
func (t *mysqlTestSuite) TestMysqlUpdate(c *check.C) {
|
|
|
|
g1, err := ParseMysqlGTIDSet("3E11FA47-71CA-11E1-9E33-C80AA9429562:21-57")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
|
|
|
|
g1.Update("3E11FA47-71CA-11E1-9E33-C80AA9429562:21-58")
|
|
|
|
|
|
|
|
c.Assert(strings.ToUpper(g1.String()), check.Equals, "3E11FA47-71CA-11E1-9E33-C80AA9429562:21-58")
|
|
|
|
}
|
|
|
|
|
2016-06-16 11:15:56 +02:00
|
|
|
func (t *mysqlTestSuite) TestMysqlGTIDContain(c *check.C) {
|
|
|
|
g1, err := ParseMysqlGTIDSet("3E11FA47-71CA-11E1-9E33-C80AA9429562:23")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
|
|
|
|
g2, err := ParseMysqlGTIDSet("3E11FA47-71CA-11E1-9E33-C80AA9429562:21-57")
|
|
|
|
c.Assert(err, check.IsNil)
|
|
|
|
|
|
|
|
c.Assert(g2.Contain(g1), check.Equals, true)
|
|
|
|
c.Assert(g1.Contain(g2), check.Equals, false)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *mysqlTestSuite) TestMysqlParseBinaryInt8(c *check.C) {
|
|
|
|
i8 := ParseBinaryInt8([]byte{128})
|
|
|
|
c.Assert(i8, check.Equals, int8(-128))
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *mysqlTestSuite) TestMysqlParseBinaryUint8(c *check.C) {
|
|
|
|
u8 := ParseBinaryUint8([]byte{128})
|
|
|
|
c.Assert(u8, check.Equals, uint8(128))
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *mysqlTestSuite) TestMysqlParseBinaryInt16(c *check.C) {
|
|
|
|
i16 := ParseBinaryInt16([]byte{1, 128})
|
2017-02-12 13:13:54 +02:00
|
|
|
c.Assert(i16, check.Equals, int16(-128*256+1))
|
2016-06-16 11:15:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (t *mysqlTestSuite) TestMysqlParseBinaryUint16(c *check.C) {
|
|
|
|
u16 := ParseBinaryUint16([]byte{1, 128})
|
2017-02-12 13:13:54 +02:00
|
|
|
c.Assert(u16, check.Equals, uint16(128*256+1))
|
2016-06-16 11:15:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (t *mysqlTestSuite) TestMysqlParseBinaryInt24(c *check.C) {
|
|
|
|
i32 := ParseBinaryInt24([]byte{1, 2, 128})
|
2017-02-12 13:13:54 +02:00
|
|
|
c.Assert(i32, check.Equals, int32(-128*65536+2*256+1))
|
2016-06-16 11:15:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (t *mysqlTestSuite) TestMysqlParseBinaryUint24(c *check.C) {
|
|
|
|
u32 := ParseBinaryUint24([]byte{1, 2, 128})
|
2017-02-12 13:13:54 +02:00
|
|
|
c.Assert(u32, check.Equals, uint32(128*65536+2*256+1))
|
2016-06-16 11:15:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (t *mysqlTestSuite) TestMysqlParseBinaryInt32(c *check.C) {
|
|
|
|
i32 := ParseBinaryInt32([]byte{1, 2, 3, 128})
|
2017-02-12 13:13:54 +02:00
|
|
|
c.Assert(i32, check.Equals, int32(-128*16777216+3*65536+2*256+1))
|
2016-06-16 11:15:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (t *mysqlTestSuite) TestMysqlParseBinaryUint32(c *check.C) {
|
|
|
|
u32 := ParseBinaryUint32([]byte{1, 2, 3, 128})
|
2017-02-12 13:13:54 +02:00
|
|
|
c.Assert(u32, check.Equals, uint32(128*16777216+3*65536+2*256+1))
|
2016-06-16 11:15:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (t *mysqlTestSuite) TestMysqlParseBinaryInt64(c *check.C) {
|
|
|
|
i64 := ParseBinaryInt64([]byte{1, 2, 3, 4, 5, 6, 7, 128})
|
2017-02-12 13:13:54 +02:00
|
|
|
c.Assert(i64, check.Equals, -128*int64(72057594037927936)+7*int64(281474976710656)+6*int64(1099511627776)+5*int64(4294967296)+4*16777216+3*65536+2*256+1)
|
2016-06-16 11:15:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (t *mysqlTestSuite) TestMysqlParseBinaryUint64(c *check.C) {
|
|
|
|
u64 := ParseBinaryUint64([]byte{1, 2, 3, 4, 5, 6, 7, 128})
|
2017-02-12 13:13:54 +02:00
|
|
|
c.Assert(u64, check.Equals, 128*uint64(72057594037927936)+7*uint64(281474976710656)+6*uint64(1099511627776)+5*uint64(4294967296)+4*16777216+3*65536+2*256+1)
|
2016-06-16 11:15:56 +02:00
|
|
|
}
|
2019-01-01 10:57:46 +02:00
|
|
|
|
|
|
|
func (t *mysqlTestSuite) TestErrorCode(c *check.C) {
|
|
|
|
tbls := []struct {
|
|
|
|
msg string
|
|
|
|
code int
|
|
|
|
}{
|
|
|
|
{"ERROR 1094 (HY000): Unknown thread id: 1094", 1094},
|
|
|
|
{"error string", 0},
|
|
|
|
{"abcdefg", 0},
|
|
|
|
{"123455 ks094", 0},
|
|
|
|
{"ERROR 1046 (3D000): Unknown error 1046", 1046},
|
|
|
|
}
|
|
|
|
for _, v := range tbls {
|
|
|
|
c.Assert(ErrorCode(v.msg), check.Equals, v.code)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (t *mysqlTestSuite) TestMysqlNullDecode(c *check.C) {
|
|
|
|
_, isNull, n := LengthEncodedInt([]byte{0xfb})
|
|
|
|
|
|
|
|
c.Assert(isNull, check.IsTrue)
|
|
|
|
c.Assert(n, check.Equals, 1)
|
|
|
|
}
|