mirror of https://github.com/milvus-io/milvus.git
101 lines
2.2 KiB
Go
101 lines
2.2 KiB
Go
package metricsutil
|
|
|
|
import (
|
|
"os"
|
|
"testing"
|
|
|
|
"github.com/cockroachdb/errors"
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/milvus-io/milvus/pkg/v2/util/paramtable"
|
|
)
|
|
|
|
var testLabel = SegmentLabel{
|
|
DatabaseName: "db",
|
|
ResourceGroup: "rg",
|
|
}
|
|
|
|
func TestMain(m *testing.M) {
|
|
paramtable.Init()
|
|
os.Exit(m.Run())
|
|
}
|
|
|
|
func TestBaseRecord(t *testing.T) {
|
|
r := newBaseRecord(testLabel)
|
|
assert.Equal(t, testLabel, r.Label())
|
|
err := errors.New("test")
|
|
r.finish(err)
|
|
assert.Equal(t, err, r.getError())
|
|
assert.NotZero(t, r.getDuration())
|
|
assert.NotZero(t, r.getMilliseconds())
|
|
}
|
|
|
|
func TestSegmentAccessRecorder(t *testing.T) {
|
|
mr := newSegmentAccessRecord(SegmentLabel{
|
|
DatabaseName: "db1",
|
|
ResourceGroup: "rg1",
|
|
})
|
|
assert.Equal(t, mr.Label(), SegmentLabel{
|
|
DatabaseName: "db1",
|
|
ResourceGroup: "rg1",
|
|
})
|
|
assert.False(t, mr.isCacheMiss)
|
|
assert.Zero(t, mr.waitLoadCost)
|
|
assert.Zero(t, mr.getDuration())
|
|
mr.CacheMissing()
|
|
assert.True(t, mr.isCacheMiss)
|
|
assert.NotZero(t, mr.waitLoadCost)
|
|
assert.Zero(t, mr.getDuration())
|
|
mr.finish(nil)
|
|
assert.NotZero(t, mr.getDuration())
|
|
|
|
mr = newSegmentAccessRecord(SegmentLabel{
|
|
DatabaseName: "db1",
|
|
ResourceGroup: "rg1",
|
|
})
|
|
mr.CacheMissing()
|
|
assert.True(t, mr.isCacheMiss)
|
|
assert.NotZero(t, mr.waitLoadCost)
|
|
assert.Zero(t, mr.getDuration())
|
|
mr.finish(nil)
|
|
assert.NotZero(t, mr.getDuration())
|
|
|
|
mr = newSegmentAccessRecord(SegmentLabel{
|
|
DatabaseName: "db1",
|
|
ResourceGroup: "rg1",
|
|
})
|
|
mr.finish(nil)
|
|
assert.False(t, mr.isCacheMiss)
|
|
assert.Zero(t, mr.waitLoadCost)
|
|
assert.NotZero(t, mr.getDuration())
|
|
}
|
|
|
|
func TestSearchSegmentAccessMetric(t *testing.T) {
|
|
m := NewSearchSegmentAccessRecord(SegmentLabel{
|
|
DatabaseName: "db1",
|
|
ResourceGroup: "rg1",
|
|
})
|
|
m.CacheMissing()
|
|
m.Finish(nil)
|
|
assert.NotZero(t, m.getDuration())
|
|
}
|
|
|
|
func TestQuerySegmentAccessMetric(t *testing.T) {
|
|
m := NewQuerySegmentAccessRecord(SegmentLabel{
|
|
DatabaseName: "db1",
|
|
ResourceGroup: "rg1",
|
|
})
|
|
m.CacheMissing()
|
|
m.Finish(nil)
|
|
assert.NotZero(t, m.getDuration())
|
|
}
|
|
|
|
func TestCacheRecord(t *testing.T) {
|
|
r1 := NewCacheLoadRecord(testLabel)
|
|
r1.WithBytes(1)
|
|
assert.Equal(t, float64(1), r1.getBytes())
|
|
r1.Finish(nil)
|
|
r2 := NewCacheEvictRecord(testLabel)
|
|
r2.Finish(nil)
|
|
}
|