1 В избранное 0 Ответвления 0

OSCHINA-MIRROR/OpenSkywalking-go2sky

Присоединиться к Gitlife
Откройте для себя и примите участие в публичных проектах с открытым исходным кодом с участием более 10 миллионов разработчиков. Приватные репозитории также полностью бесплатны :)
Присоединиться бесплатно
Клонировать/Скачать
sampler_test.go 2.5 КБ
Копировать Редактировать Web IDE Исходные данные Просмотреть построчно История
zhang-wei Отправлено 05.01.2022 06:01 0f9874e
//
// Copyright 2022 SkyAPM org
//
// 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 go2sky
import (
"sync"
"testing"
)
func TestConstSampler_IsSampled(t *testing.T) {
sampler := NewConstSampler(true)
operationName := "op"
sampled := sampler.IsSampled(operationName)
if sampled != true {
t.Errorf("const sampler should be sampled")
}
samplerNegative := NewConstSampler(false)
sampledNegative := samplerNegative.IsSampled(operationName)
if sampledNegative != false {
t.Errorf("const sampler should not be sampled")
}
}
func TestRandomSampler_IsSampled(t *testing.T) {
randomSampler := NewRandomSampler(0.5)
t.Run("threshold need transform", func(t *testing.T) {
if randomSampler.threshold != 50 {
t.Errorf("threshold should be 50")
}
})
operationName := "op"
// just for test case
randomSampler.threshold = 100
sampled := randomSampler.IsSampled(operationName)
if sampled != true {
t.Errorf("random sampler should be sampled")
}
randomSampler.threshold = 0
sampled = randomSampler.IsSampled(operationName)
if sampled != false {
t.Errorf("random sampler should not be sampled")
}
}
func TestNewRandomSampler(t *testing.T) {
randomSampler := NewRandomSampler(100)
operationName := "op"
sampled := randomSampler.IsSampled(operationName)
if sampled != true {
t.Errorf("random sampler should be sampled")
}
}
func TestRandomSampler_getRandomizer(t *testing.T) {
t.Run("must not nil", func(t *testing.T) {
sampler := &RandomSampler{
pool: sync.Pool{},
}
if sampler.getRandomizer() == nil {
t.Errorf("randomizer should be nil")
}
})
t.Run("must not nil, if got not a *rand.Rand", func(t *testing.T) {
sampler := &RandomSampler{
pool: sync.Pool{},
}
sampler.pool.Put(&struct{}{})
if sampler.getRandomizer() == nil {
t.Errorf("randomizer should be nil")
}
})
}
func BenchmarkRandomPoolSampler_IsSampled(b *testing.B) {
sampler := NewRandomSampler(0.5)
operationName := "op"
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
sampler.IsSampled(operationName)
}
})
}

Опубликовать ( 0 )

Вы можете оставить комментарий после Вход в систему

1
https://api.gitlife.ru/oschina-mirror/OpenSkywalking-go2sky.git
git@api.gitlife.ru:oschina-mirror/OpenSkywalking-go2sky.git
oschina-mirror
OpenSkywalking-go2sky
OpenSkywalking-go2sky
master