Files
tidb/meta/meta_test.go
2015-11-10 11:12:03 +08:00

227 lines
4.7 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 meta_test
import (
"testing"
. "github.com/pingcap/check"
"github.com/pingcap/tidb/meta"
"github.com/pingcap/tidb/model"
"github.com/pingcap/tidb/store/localstore"
"github.com/pingcap/tidb/store/localstore/goleveldb"
)
func TestT(t *testing.T) {
TestingT(t)
}
var _ = Suite(&testSuite{})
type testSuite struct {
}
func (s *testSuite) TestMeta(c *C) {
driver := localstore.Driver{Driver: goleveldb.MemoryDriver{}}
store, err := driver.Open("memory")
c.Assert(err, IsNil)
defer store.Close()
txn, err := store.Begin()
c.Assert(err, IsNil)
defer txn.Rollback()
t := meta.NewMeta(txn)
n, err := t.GenGlobalID()
c.Assert(err, IsNil)
c.Assert(n, Equals, int64(1))
n, err = t.GetGlobalID()
c.Assert(err, IsNil)
c.Assert(n, Equals, int64(1))
n, err = t.GetSchemaVersion()
c.Assert(err, IsNil)
c.Assert(n, Equals, int64(0))
n, err = t.GenSchemaVersion()
c.Assert(err, IsNil)
c.Assert(n, Equals, int64(1))
n, err = t.GetSchemaVersion()
c.Assert(err, IsNil)
c.Assert(n, Equals, int64(1))
dbInfo := &model.DBInfo{
ID: 1,
Name: model.NewCIStr("a"),
}
err = t.CreateDatabase(dbInfo)
c.Assert(err, IsNil)
err = t.CreateDatabase(dbInfo)
c.Assert(err, NotNil)
v, err := t.GetDatabase(1)
c.Assert(err, IsNil)
c.Assert(v, DeepEquals, dbInfo)
dbInfo.Name = model.NewCIStr("aa")
err = t.UpdateDatabase(dbInfo)
c.Assert(err, IsNil)
v, err = t.GetDatabase(1)
c.Assert(err, IsNil)
c.Assert(v, DeepEquals, dbInfo)
dbs, err := t.ListDatabases()
c.Assert(err, IsNil)
c.Assert(dbs, DeepEquals, []*model.DBInfo{dbInfo})
tbInfo := &model.TableInfo{
ID: 1,
Name: model.NewCIStr("t"),
}
err = t.CreateTable(1, tbInfo)
c.Assert(err, IsNil)
n, err = t.GenAutoTableID(1, 1, 10)
c.Assert(err, IsNil)
c.Assert(n, Equals, int64(10))
n, err = t.GetAutoTableID(1, 1)
c.Assert(err, IsNil)
c.Assert(n, Equals, int64(10))
err = t.CreateTable(1, tbInfo)
c.Assert(err, NotNil)
tbInfo.Name = model.NewCIStr("tt")
err = t.UpdateTable(1, tbInfo)
c.Assert(err, IsNil)
table, err := t.GetTable(1, 1)
c.Assert(err, IsNil)
c.Assert(table, DeepEquals, tbInfo)
table, err = t.GetTable(1, 2)
c.Assert(err, IsNil)
c.Assert(table, IsNil)
tbInfo2 := &model.TableInfo{
ID: 2,
Name: model.NewCIStr("bb"),
}
err = t.CreateTable(1, tbInfo2)
c.Assert(err, IsNil)
tables, err := t.ListTables(1)
c.Assert(err, IsNil)
c.Assert(tables, DeepEquals, []*model.TableInfo{tbInfo, tbInfo2})
err = t.DropTable(1, 2)
c.Assert(err, IsNil)
tables, err = t.ListTables(1)
c.Assert(err, IsNil)
c.Assert(tables, DeepEquals, []*model.TableInfo{tbInfo})
err = t.DropDatabase(1)
c.Assert(err, IsNil)
dbs, err = t.ListDatabases()
c.Assert(err, IsNil)
c.Assert(dbs, HasLen, 0)
bootstrapped, err := t.IsBootstrapped()
c.Assert(err, IsNil)
c.Assert(bootstrapped, IsFalse)
err = t.FinishBootstrap()
c.Assert(err, IsNil)
bootstrapped, err = t.IsBootstrapped()
c.Assert(err, IsNil)
c.Assert(bootstrapped, IsTrue)
err = txn.Commit()
c.Assert(err, IsNil)
}
func (s *testSuite) TestDDL(c *C) {
driver := localstore.Driver{Driver: goleveldb.MemoryDriver{}}
store, err := driver.Open("memory")
c.Assert(err, IsNil)
defer store.Close()
txn, err := store.Begin()
c.Assert(err, IsNil)
defer txn.Rollback()
t := meta.NewMeta(txn)
owner := &model.Owner{OwnerID: "1"}
err = t.SetDDLOwner(owner)
c.Assert(err, IsNil)
ov, err := t.GetDDLOwner()
c.Assert(err, IsNil)
c.Assert(owner, DeepEquals, ov)
job := &model.Job{ID: 1}
err = t.EnQueueDDLJob(job)
c.Assert(err, IsNil)
n, err := t.DDLJobLength()
c.Assert(err, IsNil)
c.Assert(n, Equals, int64(1))
v, err := t.GetDDLJob(0)
c.Assert(err, IsNil)
c.Assert(v, DeepEquals, job)
v, err = t.GetDDLJob(1)
c.Assert(err, IsNil)
c.Assert(v, IsNil)
job.ID = 2
err = t.UpdateDDLJob(0, job)
c.Assert(err, IsNil)
err = t.UpdateDDLReorgHandle(job, 1)
c.Assert(err, IsNil)
h, err := t.GetDDLReorgHandle(job)
c.Assert(err, IsNil)
c.Assert(h, Equals, int64(1))
err = t.RemoveDDLReorgHandle(job)
c.Assert(err, IsNil)
v, err = t.DeQueueDDLJob()
c.Assert(err, IsNil)
c.Assert(v, DeepEquals, job)
err = t.AddHistoryDDLJob(job)
c.Assert(err, IsNil)
v, err = t.GetHistoryDDLJob(2)
c.Assert(err, IsNil)
c.Assert(v, DeepEquals, job)
err = txn.Commit()
c.Assert(err, IsNil)
}