Files
tidb/br/pkg/stream/stream_misc_test.go
2023-04-12 23:23:01 +08:00

80 lines
2.5 KiB
Go

// Copyright 2022 PingCAP, Inc. Licensed under Apache-2.0.
package stream_test
import (
"context"
"testing"
backuppb "github.com/pingcap/kvproto/pkg/brpb"
"github.com/pingcap/tidb/br/pkg/storage"
"github.com/pingcap/tidb/br/pkg/stream"
"github.com/pingcap/tidb/br/pkg/streamhelper"
"github.com/stretchr/testify/require"
)
func TestGetCheckpointOfTask(t *testing.T) {
task := stream.TaskStatus{
Info: backuppb.StreamBackupTaskInfo{
StartTs: 8,
},
Checkpoints: []streamhelper.Checkpoint{
{
ID: 1,
TS: 10,
},
{
ID: 2,
TS: 8,
},
{
ID: 6,
TS: 12,
},
},
}
require.Equal(t, task.GetMinStoreCheckpoint().TS, uint64(8), "progress = %v", task.Checkpoints)
task.Checkpoints[1].TS = 18
require.Equal(t, task.GetMinStoreCheckpoint().TS, uint64(10))
task.Checkpoints[0].TS = 14
require.Equal(t, task.GetMinStoreCheckpoint().TS, uint64(12), "progress = %v", task.Checkpoints)
}
func TestMetadataHelperReadFile(t *testing.T) {
ctx := context.Background()
tmpdir := t.TempDir()
s, err := storage.NewLocalStorage(tmpdir)
require.Nil(t, err)
helper := stream.NewMetadataHelper()
filename1 := "full_data"
filename2 := "misc_data"
data1 := []byte("Test MetadataHelper. The data contains bare data (or maybe compressed data).")
// data2 is the compressed content from data1
data2 := []byte{0x28, 0xb5, 0x2f, 0xfd, 0x0, 0x58, 0x15, 0x2, 0x0, 0x52, 0x44, 0xe, 0x14, 0xb0, 0x37, 0x1, 0xe7,
0xa4, 0x1c, 0xd9, 0x3d, 0xc7, 0xee, 0xe7, 0x3e, 0x15, 0x14, 0x80, 0xdc, 0x25, 0x14, 0xc, 0x60, 0x24, 0x70,
0xda, 0x6a, 0x47, 0xfc, 0x2d, 0xa4, 0x4e, 0x6f, 0xe, 0xa3, 0x9e, 0x2, 0xce, 0xa6, 0x98, 0xa, 0x67, 0x52,
0xa7, 0x4e, 0x5b, 0x4f, 0x94, 0x92, 0xfb, 0x32, 0x2e, 0x38, 0x6d, 0xce, 0xf, 0x4d, 0x7c, 0x9, 0x1, 0x0,
0xb2, 0x6c, 0x96, 0x1}
// write data at first
err = s.WriteFile(ctx, filename1, data1)
require.NoError(t, err)
err = s.WriteFile(ctx, filename2, append(append([]byte{}, data1...), data2...))
require.NoError(t, err)
helper.InitCacheEntry(filename2, 2)
get_data, err := helper.ReadFile(ctx, filename1, 0, 0, backuppb.CompressionType_UNKNOWN, s)
require.NoError(t, err)
require.Equal(t, data1, get_data)
get_data, err = helper.ReadFile(ctx, filename2, 0, uint64(len(data1)), backuppb.CompressionType_UNKNOWN, s)
require.NoError(t, err)
require.Equal(t, data1, get_data)
get_data, err = helper.ReadFile(ctx, filename2, uint64(len(data1)), uint64(len(data2)),
backuppb.CompressionType_ZSTD, s)
require.NoError(t, err)
require.Equal(t, data1, get_data)
}