2021-11-24 07:43:15 +00:00
|
|
|
// Copyright (C) 2019-2020 Zilliz. All rights reserved.
|
|
|
|
//
|
|
|
|
// 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 metricsinfo
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
2024-11-12 09:44:29 +00:00
|
|
|
"time"
|
2021-11-24 07:43:15 +00:00
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
2024-11-12 09:44:29 +00:00
|
|
|
|
|
|
|
"github.com/milvus-io/milvus-proto/go-api/v2/commonpb"
|
|
|
|
"github.com/milvus-io/milvus-proto/go-api/v2/milvuspb"
|
2021-11-24 07:43:15 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestFillDeployMetricsWithEnv(t *testing.T) {
|
|
|
|
var m DeployMetrics
|
|
|
|
|
|
|
|
commit := "commit"
|
2022-10-11 10:43:23 +00:00
|
|
|
t.Setenv(GitCommitEnvKey, commit)
|
2021-11-24 07:43:15 +00:00
|
|
|
|
|
|
|
deploy := "deploy"
|
2022-10-11 10:43:23 +00:00
|
|
|
t.Setenv(DeployModeEnvKey, deploy)
|
2021-11-24 07:43:15 +00:00
|
|
|
|
|
|
|
version := "version"
|
2022-10-11 10:43:23 +00:00
|
|
|
t.Setenv(GitBuildTagsEnvKey, version)
|
2021-11-24 07:43:15 +00:00
|
|
|
|
|
|
|
goVersion := "go"
|
2022-10-11 10:43:23 +00:00
|
|
|
t.Setenv(MilvusUsedGoVersion, goVersion)
|
2021-11-24 07:43:15 +00:00
|
|
|
|
|
|
|
buildTime := "build"
|
2022-10-11 10:43:23 +00:00
|
|
|
t.Setenv(MilvusBuildTimeEnvKey, buildTime)
|
2021-11-24 07:43:15 +00:00
|
|
|
|
|
|
|
FillDeployMetricsWithEnv(&m)
|
|
|
|
assert.NotNil(t, m)
|
|
|
|
assert.Equal(t, commit, m.SystemVersion)
|
|
|
|
assert.Equal(t, deploy, m.DeployMode)
|
|
|
|
assert.Equal(t, version, m.BuildVersion)
|
|
|
|
assert.Equal(t, goVersion, m.UsedGoVersion)
|
|
|
|
assert.Equal(t, buildTime, m.BuildTime)
|
|
|
|
}
|
2024-11-12 09:44:29 +00:00
|
|
|
|
|
|
|
func TestNewSlowQueryWithSearchRequest(t *testing.T) {
|
|
|
|
request := &milvuspb.SearchRequest{
|
|
|
|
DbName: "test_db",
|
|
|
|
CollectionName: "test_collection",
|
|
|
|
PartitionNames: []string{"partition1", "partition2"},
|
|
|
|
ConsistencyLevel: commonpb.ConsistencyLevel_Bounded,
|
|
|
|
UseDefaultConsistency: true,
|
|
|
|
GuaranteeTimestamp: 123456789,
|
|
|
|
SearchParams: []*commonpb.KeyValuePair{{Key: "param1", Value: "value1"}},
|
|
|
|
SubReqs: []*milvuspb.SubSearchRequest{{Dsl: "dsl1", SearchParams: []*commonpb.KeyValuePair{{Key: "param2", Value: "value2"}}, Nq: 10}},
|
|
|
|
Dsl: "dsl2",
|
|
|
|
Nq: 20,
|
|
|
|
OutputFields: []string{"field1", "field2"},
|
|
|
|
}
|
|
|
|
user := "test_user"
|
|
|
|
cost := time.Duration(100) * time.Millisecond
|
|
|
|
|
|
|
|
slowQuery := NewSlowQueryWithSearchRequest(request, user, cost, "")
|
|
|
|
|
|
|
|
assert.NotNil(t, slowQuery)
|
|
|
|
assert.Equal(t, "proxy", slowQuery.Role)
|
|
|
|
assert.Equal(t, "test_db", slowQuery.Database)
|
|
|
|
assert.Equal(t, "test_collection", slowQuery.Collection)
|
|
|
|
assert.Equal(t, "partition1,partition2", slowQuery.Partitions)
|
|
|
|
assert.Equal(t, "Bounded", slowQuery.ConsistencyLevel)
|
|
|
|
assert.True(t, slowQuery.UseDefaultConsistency)
|
|
|
|
assert.Equal(t, uint64(123456789), slowQuery.GuaranteeTimestamp)
|
|
|
|
assert.Equal(t, "100ms", slowQuery.Duration)
|
|
|
|
assert.Equal(t, user, slowQuery.User)
|
|
|
|
assert.Equal(t, "HybridSearch", slowQuery.Type)
|
|
|
|
assert.NotNil(t, slowQuery.QueryParams)
|
|
|
|
assert.Equal(t, "dsl2", slowQuery.QueryParams.Expr)
|
|
|
|
assert.Equal(t, "field1,field2", slowQuery.QueryParams.OutputFields)
|
|
|
|
assert.Len(t, slowQuery.QueryParams.SearchParams, 1)
|
|
|
|
assert.Equal(t, []string{"dsl1"}, slowQuery.QueryParams.SearchParams[0].DSL)
|
|
|
|
assert.Equal(t, []string{"param2=value2"}, slowQuery.QueryParams.SearchParams[0].SearchParams)
|
|
|
|
assert.Equal(t, []int64{10}, slowQuery.QueryParams.SearchParams[0].NQ)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewSlowQueryWithQueryRequest(t *testing.T) {
|
|
|
|
request := &milvuspb.QueryRequest{
|
|
|
|
DbName: "test_db",
|
|
|
|
CollectionName: "test_collection",
|
|
|
|
PartitionNames: []string{"partition1", "partition2"},
|
|
|
|
ConsistencyLevel: commonpb.ConsistencyLevel_Bounded,
|
|
|
|
UseDefaultConsistency: true,
|
|
|
|
GuaranteeTimestamp: 123456789,
|
|
|
|
Expr: "expr1",
|
|
|
|
OutputFields: []string{"field1", "field2"},
|
|
|
|
}
|
|
|
|
user := "test_user"
|
|
|
|
cost := time.Duration(100) * time.Millisecond
|
|
|
|
|
|
|
|
slowQuery := NewSlowQueryWithQueryRequest(request, user, cost, "")
|
|
|
|
|
|
|
|
assert.NotNil(t, slowQuery)
|
|
|
|
assert.Equal(t, "proxy", slowQuery.Role)
|
|
|
|
assert.Equal(t, "test_db", slowQuery.Database)
|
|
|
|
assert.Equal(t, "test_collection", slowQuery.Collection)
|
|
|
|
assert.Equal(t, "partition1,partition2", slowQuery.Partitions)
|
|
|
|
assert.Equal(t, "Bounded", slowQuery.ConsistencyLevel)
|
|
|
|
assert.True(t, slowQuery.UseDefaultConsistency)
|
|
|
|
assert.Equal(t, uint64(123456789), slowQuery.GuaranteeTimestamp)
|
|
|
|
assert.Equal(t, "100ms", slowQuery.Duration)
|
|
|
|
assert.Equal(t, user, slowQuery.User)
|
|
|
|
assert.Equal(t, "Query", slowQuery.Type)
|
|
|
|
assert.NotNil(t, slowQuery.QueryParams)
|
|
|
|
assert.Equal(t, "expr1", slowQuery.QueryParams.Expr)
|
|
|
|
assert.Equal(t, "field1,field2", slowQuery.QueryParams.OutputFields)
|
|
|
|
}
|