140 lines
5.6 KiB
Go
140 lines
5.6 KiB
Go
// Copyright 2021 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,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
package ddl_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/pingcap/tidb/domain"
|
|
"github.com/pingcap/tidb/errno"
|
|
"github.com/pingcap/tidb/parser/model"
|
|
"github.com/pingcap/tidb/session"
|
|
"github.com/pingcap/tidb/sessionctx"
|
|
"github.com/pingcap/tidb/table"
|
|
"github.com/pingcap/tidb/testkit"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func checkTableCacheStatus(t *testing.T, se session.Session, dbName, tableName string, status model.TableCacheStatusType) {
|
|
tb := testGetTableByNameT(t, se, dbName, tableName)
|
|
dom := domain.GetDomain(se)
|
|
err := dom.Reload()
|
|
require.NoError(t, err)
|
|
require.Equal(t, status, tb.Meta().TableCacheStatusType)
|
|
}
|
|
|
|
func testGetTableByNameT(t *testing.T, ctx sessionctx.Context, db, table string) table.Table {
|
|
dom := domain.GetDomain(ctx)
|
|
// Make sure the table schema is the new schema.
|
|
err := dom.Reload()
|
|
require.NoError(t, err)
|
|
tbl, err := dom.InfoSchema().TableByName(model.NewCIStr(db), model.NewCIStr(table))
|
|
require.NoError(t, err)
|
|
return tbl
|
|
}
|
|
|
|
func TestAlterPartitionCache(t *testing.T) {
|
|
t.Parallel()
|
|
store, clean := testkit.CreateMockStore(t)
|
|
defer clean()
|
|
|
|
tk := testkit.NewTestKit(t, store)
|
|
tk.MustExec("use test;")
|
|
tk.MustExec("drop table if exists cache_partition_table;")
|
|
tk.MustExec("create table cache_partition_table (a int, b int) partition by hash(a) partitions 3;")
|
|
tk.MustGetErrCode("alter table cache_partition_table cache", errno.ErrOptOnCacheTable)
|
|
defer tk.MustExec("drop table if exists cache_partition_table;")
|
|
tk.MustExec("drop table if exists cache_partition_range_table;")
|
|
tk.MustExec(`create table cache_partition_range_table (c1 smallint(6) not null, c2 char(5) default null) partition by range ( c1 ) (
|
|
partition p0 values less than (10),
|
|
partition p1 values less than (20),
|
|
partition p2 values less than (30),
|
|
partition p3 values less than (MAXVALUE)
|
|
);`)
|
|
tk.MustGetErrCode("alter table cache_partition_range_table cache;", errno.ErrOptOnCacheTable)
|
|
defer tk.MustExec("drop table if exists cache_partition_range_table;")
|
|
tk.MustExec("drop table if exists partition_list_table;")
|
|
tk.MustExec("set @@session.tidb_enable_list_partition = ON")
|
|
tk.MustExec(`create table cache_partition_list_table (id int) partition by list (id) (
|
|
partition p0 values in (1,2),
|
|
partition p1 values in (3,4),
|
|
partition p3 values in (5,null)
|
|
);`)
|
|
tk.MustGetErrCode("alter table cache_partition_list_table cache", errno.ErrOptOnCacheTable)
|
|
tk.MustExec("drop table if exists cache_partition_list_table;")
|
|
}
|
|
|
|
func TestAlterViewTableCache(t *testing.T) {
|
|
t.Parallel()
|
|
store, clean := testkit.CreateMockStore(t)
|
|
defer clean()
|
|
|
|
tk := testkit.NewTestKit(t, store)
|
|
tk.MustExec("use test;")
|
|
tk.MustExec("drop table if exists cache_view_t")
|
|
tk.MustExec("create table cache_view_t (id int);")
|
|
tk.MustExec("create view v as select * from cache_view_t")
|
|
tk.MustGetErrCode("alter table v cache", errno.ErrWrongObject)
|
|
}
|
|
|
|
func TestAlterTableNoCache(t *testing.T) {
|
|
t.Parallel()
|
|
store, clean := testkit.CreateMockStore(t)
|
|
defer clean()
|
|
|
|
tk := testkit.NewTestKit(t, store)
|
|
tk.MustExec("use test")
|
|
tk.MustExec("drop table if exists nocache_t1")
|
|
/* Test of cache table */
|
|
tk.MustExec("create table nocache_t1 ( n int auto_increment primary key)")
|
|
tk.MustExec("alter table nocache_t1 cache")
|
|
checkTableCacheStatus(t, tk.Session(), "test", "nocache_t1", model.TableCacheStatusEnable)
|
|
tk.MustExec("alter table nocache_t1 nocache")
|
|
checkTableCacheStatus(t, tk.Session(), "test", "nocache_t1", model.TableCacheStatusDisable)
|
|
tk.MustExec("drop table if exists t1")
|
|
// Test if a table is not exists
|
|
tk.MustExec("drop table if exists nocache_t")
|
|
tk.MustGetErrCode("alter table nocache_t cache", errno.ErrNoSuchTable)
|
|
tk.MustExec("create table nocache_t (a int)")
|
|
tk.MustExec("alter table nocache_t nocache")
|
|
// Multiple no alter cache is okay
|
|
tk.MustExec("alter table nocache_t nocache")
|
|
tk.MustExec("alter table nocache_t nocache")
|
|
}
|
|
|
|
func TestIndexOnCacheTable(t *testing.T) {
|
|
t.Parallel()
|
|
store, clean := testkit.CreateMockStore(t)
|
|
defer clean()
|
|
|
|
tk := testkit.NewTestKit(t, store)
|
|
tk.MustExec("use test;")
|
|
/*Test cache table can't add/drop/rename index */
|
|
tk.MustExec("drop table if exists cache_index")
|
|
tk.MustExec("create table cache_index (c1 int primary key, c2 int, c3 int, index ok2(c2))")
|
|
defer tk.MustExec("drop table if exists cache_index")
|
|
tk.MustExec("alter table cache_index cache")
|
|
tk.MustGetErrCode("create index cache_c2 on cache_index(c2)", errno.ErrOptOnCacheTable)
|
|
tk.MustGetErrCode("alter table cache_index add index k2(c2)", errno.ErrOptOnCacheTable)
|
|
tk.MustGetErrCode("alter table cache_index drop index ok2", errno.ErrOptOnCacheTable)
|
|
/*Test rename index*/
|
|
tk.MustGetErrCode("alter table cache_index rename index ok2 to ok", errno.ErrOptOnCacheTable)
|
|
/*Test drop different indexes*/
|
|
tk.MustExec("drop table if exists cache_index_1")
|
|
tk.MustExec("create table cache_index_1 (id int, c1 int, c2 int, primary key(id), key i1(c1), key i2(c2));")
|
|
tk.MustExec("alter table cache_index_1 cache")
|
|
tk.MustGetErrCode("alter table cache_index_1 drop index i1, drop index i2;", errno.ErrOptOnCacheTable)
|
|
}
|