227 lines
4.7 KiB
Go
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)
|
|
}
|