2021-11-16 03:47:10 +00:00
|
|
|
// licensed to the lf ai & data foundation under one
|
2021-10-25 11:46:28 +00:00
|
|
|
// or more contributor license agreements. See the NOTICE file
|
|
|
|
// distributed with this work for additional information
|
|
|
|
// regarding copyright ownership. The ASF licenses this file
|
|
|
|
// to you 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.
|
|
|
|
|
2021-08-20 09:50:12 +00:00
|
|
|
package datacoord
|
|
|
|
|
|
|
|
import (
|
2021-11-16 03:47:10 +00:00
|
|
|
"context"
|
2021-08-20 09:50:12 +00:00
|
|
|
"errors"
|
|
|
|
"testing"
|
2021-11-16 03:47:10 +00:00
|
|
|
"time"
|
2021-08-20 09:50:12 +00:00
|
|
|
|
2022-09-16 08:56:49 +00:00
|
|
|
"github.com/milvus-io/milvus/api/commonpb"
|
2021-08-20 09:50:12 +00:00
|
|
|
"github.com/milvus-io/milvus/internal/proto/rootcoordpb"
|
2021-11-16 03:47:10 +00:00
|
|
|
"github.com/milvus-io/milvus/internal/util/tsoutil"
|
2022-09-16 03:32:48 +00:00
|
|
|
"github.com/stretchr/testify/suite"
|
2021-08-20 09:50:12 +00:00
|
|
|
)
|
|
|
|
|
2022-09-16 03:32:48 +00:00
|
|
|
type UtilSuite struct {
|
|
|
|
suite.Suite
|
|
|
|
}
|
|
|
|
|
|
|
|
func (suite *UtilSuite) TestVerifyResponse() {
|
2021-08-20 09:50:12 +00:00
|
|
|
type testCase struct {
|
|
|
|
resp interface{}
|
|
|
|
err error
|
|
|
|
expected error
|
|
|
|
equalValue bool
|
|
|
|
}
|
|
|
|
cases := []testCase{
|
|
|
|
{
|
|
|
|
resp: nil,
|
|
|
|
err: errors.New("boom"),
|
|
|
|
expected: errors.New("boom"),
|
|
|
|
equalValue: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
resp: nil,
|
|
|
|
err: nil,
|
|
|
|
expected: errNilResponse,
|
|
|
|
equalValue: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
resp: &commonpb.Status{ErrorCode: commonpb.ErrorCode_Success},
|
|
|
|
err: nil,
|
|
|
|
expected: nil,
|
|
|
|
equalValue: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
resp: &commonpb.Status{ErrorCode: commonpb.ErrorCode_UnexpectedError, Reason: "r1"},
|
|
|
|
err: nil,
|
|
|
|
expected: errors.New("r1"),
|
|
|
|
equalValue: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
resp: (*commonpb.Status)(nil),
|
|
|
|
err: nil,
|
|
|
|
expected: errNilResponse,
|
|
|
|
equalValue: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
resp: &rootcoordpb.AllocIDResponse{
|
|
|
|
Status: &commonpb.Status{ErrorCode: commonpb.ErrorCode_Success},
|
|
|
|
},
|
|
|
|
err: nil,
|
|
|
|
expected: nil,
|
|
|
|
equalValue: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
resp: &rootcoordpb.AllocIDResponse{
|
|
|
|
Status: &commonpb.Status{ErrorCode: commonpb.ErrorCode_UnexpectedError, Reason: "r2"},
|
|
|
|
},
|
|
|
|
err: nil,
|
|
|
|
expected: errors.New("r2"),
|
|
|
|
equalValue: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
resp: &rootcoordpb.AllocIDResponse{},
|
|
|
|
err: nil,
|
|
|
|
expected: errNilStatusResponse,
|
|
|
|
equalValue: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
resp: (*rootcoordpb.AllocIDResponse)(nil),
|
|
|
|
err: nil,
|
|
|
|
expected: errNilStatusResponse,
|
|
|
|
equalValue: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
resp: struct{}{},
|
|
|
|
err: nil,
|
|
|
|
expected: errUnknownResponseType,
|
|
|
|
equalValue: false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, c := range cases {
|
|
|
|
r := VerifyResponse(c.resp, c.err)
|
|
|
|
if c.equalValue {
|
2022-09-16 03:32:48 +00:00
|
|
|
suite.EqualValues(c.expected, r)
|
2021-08-20 09:50:12 +00:00
|
|
|
} else {
|
2022-09-16 03:32:48 +00:00
|
|
|
suite.Equal(c.expected, r)
|
2021-08-20 09:50:12 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-11-16 03:47:10 +00:00
|
|
|
|
2022-09-16 03:32:48 +00:00
|
|
|
func (suite *UtilSuite) TestGetCompactTime() {
|
2021-11-16 03:47:10 +00:00
|
|
|
Params.Init()
|
2022-01-10 11:03:35 +00:00
|
|
|
Params.CommonCfg.RetentionDuration = 43200 // 5 days
|
2021-11-16 03:47:10 +00:00
|
|
|
|
|
|
|
tFixed := time.Date(2021, 11, 15, 0, 0, 0, 0, time.Local)
|
2022-01-10 11:03:35 +00:00
|
|
|
tBefore := tFixed.Add(-time.Duration(Params.CommonCfg.RetentionDuration) * time.Second)
|
2021-11-16 03:47:10 +00:00
|
|
|
|
|
|
|
type args struct {
|
|
|
|
allocator allocator
|
|
|
|
}
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
args args
|
2022-06-15 15:14:10 +00:00
|
|
|
want *compactTime
|
2021-11-16 03:47:10 +00:00
|
|
|
wantErr bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
"test get timetravel",
|
|
|
|
args{&fixedTSOAllocator{fixedTime: tFixed}},
|
2022-06-15 15:14:10 +00:00
|
|
|
&compactTime{tsoutil.ComposeTS(tBefore.UnixNano()/int64(time.Millisecond), 0), 0},
|
2021-11-16 03:47:10 +00:00
|
|
|
false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
2022-09-16 03:32:48 +00:00
|
|
|
suite.Run(tt.name, func() {
|
|
|
|
got, err := GetCompactTime(context.TODO(), tt.args.allocator)
|
|
|
|
suite.Equal(tt.wantErr, err != nil)
|
|
|
|
suite.EqualValues(tt.want, got)
|
2021-11-16 03:47:10 +00:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-09-16 03:32:48 +00:00
|
|
|
func TestUtil(t *testing.T) {
|
|
|
|
suite.Run(t, new(UtilSuite))
|
|
|
|
}
|
|
|
|
|
2021-11-16 03:47:10 +00:00
|
|
|
type fixedTSOAllocator struct {
|
|
|
|
fixedTime time.Time
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f *fixedTSOAllocator) allocTimestamp(_ context.Context) (Timestamp, error) {
|
|
|
|
return tsoutil.ComposeTS(f.fixedTime.UnixNano()/int64(time.Millisecond), 0), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f *fixedTSOAllocator) allocID(_ context.Context) (UniqueID, error) {
|
|
|
|
panic("not implemented") // TODO: Implement
|
|
|
|
}
|
2022-09-20 12:54:50 +00:00
|
|
|
|
|
|
|
func (suite *UtilSuite) TestGetZeroTime() {
|
|
|
|
n := 10
|
|
|
|
for i := 0; i < n; i++ {
|
|
|
|
timeGot := getZeroTime()
|
|
|
|
suite.True(timeGot.IsZero())
|
|
|
|
}
|
|
|
|
}
|