milvus/internal/datanode/writebuffer/sync_policy_test.go

81 lines
2.3 KiB
Go

package writebuffer
import (
"testing"
"time"
"github.com/stretchr/testify/mock"
"github.com/stretchr/testify/suite"
"github.com/milvus-io/milvus-proto/go-api/v2/commonpb"
"github.com/milvus-io/milvus-proto/go-api/v2/msgpb"
"github.com/milvus-io/milvus-proto/go-api/v2/schemapb"
"github.com/milvus-io/milvus/internal/datanode/metacache"
"github.com/milvus-io/milvus/pkg/common"
"github.com/milvus-io/milvus/pkg/util/paramtable"
"github.com/milvus-io/milvus/pkg/util/tsoutil"
)
type SyncPolicySuite struct {
suite.Suite
collSchema *schemapb.CollectionSchema
}
func (s *SyncPolicySuite) SetupSuite() {
paramtable.Get().Init(paramtable.NewBaseTable())
s.collSchema = &schemapb.CollectionSchema{
Name: "wb_base_collection",
Fields: []*schemapb.FieldSchema{
{FieldID: 100, DataType: schemapb.DataType_Int64, IsPrimaryKey: true, Name: "pk"},
{FieldID: 101, DataType: schemapb.DataType_FloatVector, TypeParams: []*commonpb.KeyValuePair{
{Key: common.DimKey, Value: "128"},
}},
},
}
}
func (s *SyncPolicySuite) TestSyncFullBuffer() {
buffer, err := newSegmentBuffer(100, s.collSchema)
s.Require().NoError(err)
ids := SyncFullBuffer([]*segmentBuffer{buffer}, 0)
s.Equal(0, len(ids), "empty buffer shall not be synced")
buffer.insertBuffer.size = buffer.insertBuffer.sizeLimit + 1
ids = SyncFullBuffer([]*segmentBuffer{buffer}, 0)
s.ElementsMatch([]int64{100}, ids)
}
func (s *SyncPolicySuite) TestSyncStalePolicy() {
policy := GetSyncStaleBufferPolicy(time.Minute)
buffer, err := newSegmentBuffer(100, s.collSchema)
s.Require().NoError(err)
ids := policy([]*segmentBuffer{buffer}, tsoutil.ComposeTSByTime(time.Now(), 0))
s.Equal(0, len(ids), "empty buffer shall not be synced")
buffer.insertBuffer.startPos = &msgpb.MsgPosition{
Timestamp: tsoutil.ComposeTSByTime(time.Now().Add(-time.Minute*2), 0),
}
ids = policy([]*segmentBuffer{buffer}, tsoutil.ComposeTSByTime(time.Now(), 0))
s.ElementsMatch([]int64{100}, ids)
}
func (s *SyncPolicySuite) TestFlushingSegmentsPolicy() {
metacache := metacache.NewMockMetaCache(s.T())
policy := GetFlushingSegmentsPolicy(metacache)
ids := []int64{1, 2, 3}
metacache.EXPECT().GetSegmentIDsBy(mock.Anything).Return(ids)
result := policy([]*segmentBuffer{}, tsoutil.ComposeTSByTime(time.Now(), 0))
s.ElementsMatch(ids, result)
}
func TestSyncPolicy(t *testing.T) {
suite.Run(t, new(SyncPolicySuite))
}