Files
tidb/pkg/executor/stmtsummary_test.go

197 lines
6.8 KiB
Go

// Copyright 2022 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 executor
import (
"context"
"math"
"os"
"testing"
"time"
"github.com/pingcap/tidb/pkg/infoschema"
"github.com/pingcap/tidb/pkg/meta/metadef"
"github.com/pingcap/tidb/pkg/parser/ast"
"github.com/pingcap/tidb/pkg/sessionctx/vardef"
"github.com/pingcap/tidb/pkg/types"
"github.com/pingcap/tidb/pkg/util/mock"
stmtsummaryv2 "github.com/pingcap/tidb/pkg/util/stmtsummary/v2"
"github.com/stretchr/testify/require"
)
func TestStmtSummaryRetriverV2_TableStatementsSummary(t *testing.T) {
data := infoschema.NewData()
schemaCacheSize := vardef.SchemaCacheSize.Load()
infoSchemaBuilder := infoschema.NewBuilder(nil, schemaCacheSize, nil, data, schemaCacheSize > 0)
err := infoSchemaBuilder.InitWithDBInfos(nil, nil, nil, 0)
require.NoError(t, err)
infoSchema := infoSchemaBuilder.Build(math.MaxUint64)
table, err := infoSchema.TableByName(context.Background(), metadef.InformationSchemaName, ast.NewCIStr(infoschema.TableStatementsSummary))
require.NoError(t, err)
columns := table.Meta().Columns
stmtSummary := stmtsummaryv2.NewStmtSummary4Test(1000)
defer stmtSummary.Close()
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest1"))
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest1"))
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest2"))
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest2"))
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest3"))
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest3"))
retriever := stmtSummaryRetrieverV2{
stmtSummary: stmtSummary,
table: table.Meta(),
columns: columns,
}
defer func() {
require.NoError(t, retriever.close())
}()
ctx := context.Background()
sctx := mock.NewContext()
tz, _ := time.LoadLocation("Asia/Shanghai")
sctx.ResetSessionAndStmtTimeZone(tz)
var results [][]types.Datum
for {
rows, err := retriever.retrieve(ctx, sctx)
require.NoError(t, err)
if len(rows) == 0 {
break
}
results = append(results, rows...)
}
require.Len(t, results, 3)
}
func TestStmtSummaryRetriverV2_TableStatementsSummaryEvicted(t *testing.T) {
data := infoschema.NewData()
schemaCacheSize := vardef.SchemaCacheSize.Load()
infoSchemaBuilder := infoschema.NewBuilder(nil, schemaCacheSize, nil, data, schemaCacheSize > 0)
err := infoSchemaBuilder.InitWithDBInfos(nil, nil, nil, 0)
require.NoError(t, err)
infoSchema := infoSchemaBuilder.Build(math.MaxUint64)
table, err := infoSchema.TableByName(context.Background(), metadef.InformationSchemaName, ast.NewCIStr(infoschema.TableStatementsSummaryEvicted))
require.NoError(t, err)
columns := table.Meta().Columns
stmtSummary := stmtsummaryv2.NewStmtSummary4Test(1)
defer stmtSummary.Close()
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest1"))
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest1"))
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest2"))
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest2"))
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest3"))
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest3"))
retriever := stmtSummaryRetrieverV2{
stmtSummary: stmtSummary,
table: table.Meta(),
columns: columns,
}
defer func() {
require.NoError(t, retriever.close())
}()
ctx := context.Background()
sctx := mock.NewContext()
tz, _ := time.LoadLocation("Asia/Shanghai")
sctx.ResetSessionAndStmtTimeZone(tz)
var results [][]types.Datum
for {
rows, err := retriever.retrieve(ctx, sctx)
require.NoError(t, err)
if len(rows) == 0 {
break
}
results = append(results, rows...)
}
require.Len(t, results, 1)
require.Equal(t, int64(2), results[0][2].GetInt64())
}
func TestStmtSummaryRetriverV2_TableStatementsSummaryHistory(t *testing.T) {
filename1 := "tidb-statements-2022-12-27T16-21-20.245.log"
filename2 := "tidb-statements.log"
file, err := os.Create(filename1)
require.NoError(t, err)
defer func() {
require.NoError(t, os.Remove(filename1))
}()
_, err = file.WriteString("{\"begin\":1672128520,\"end\":1672128530,\"digest\":\"digest1\",\"exec_count\":1}\n")
require.NoError(t, err)
_, err = file.WriteString("{\"begin\":1672129270,\"end\":1672129280,\"digest\":\"digest2\",\"exec_count\":2}\n")
require.NoError(t, err)
require.NoError(t, file.Close())
file, err = os.Create(filename2)
require.NoError(t, err)
defer func() {
require.NoError(t, os.Remove(filename2))
}()
_, err = file.WriteString("{\"begin\":1672129270,\"end\":1672129280,\"digest\":\"digest3\",\"exec_count\":3}\n")
require.NoError(t, err)
_, err = file.WriteString("{\"begin\":1672129380,\"end\":1672129390,\"digest\":\"digest4\",\"exec_count\":4}\n")
require.NoError(t, err)
require.NoError(t, file.Close())
stmtSummary := stmtsummaryv2.NewStmtSummary4Test(2)
defer stmtSummary.Close()
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest1"))
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest1"))
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest2"))
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest2"))
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest3"))
stmtSummary.Add(stmtsummaryv2.GenerateStmtExecInfo4Test("digest3"))
data := infoschema.NewData()
schemaCacheSize := vardef.SchemaCacheSize.Load()
infoSchemaBuilder := infoschema.NewBuilder(nil, schemaCacheSize, nil, data, schemaCacheSize > 0)
err = infoSchemaBuilder.InitWithDBInfos(nil, nil, nil, 0)
require.NoError(t, err)
infoSchema := infoSchemaBuilder.Build(math.MaxUint64)
table, err := infoSchema.TableByName(context.Background(), metadef.InformationSchemaName, ast.NewCIStr(infoschema.TableStatementsSummaryHistory))
require.NoError(t, err)
columns := table.Meta().Columns
retriever := stmtSummaryRetrieverV2{
stmtSummary: stmtSummary,
table: table.Meta(),
columns: columns,
}
defer func() {
require.NoError(t, retriever.close())
}()
ctx := context.Background()
sctx := mock.NewContext()
tz, _ := time.LoadLocation("Asia/Shanghai")
sctx.ResetSessionAndStmtTimeZone(tz)
var results [][]types.Datum
for {
rows, err := retriever.retrieve(ctx, sctx)
require.NoError(t, err)
if len(rows) == 0 {
break
}
results = append(results, rows...)
}
require.Len(t, results, 7)
}