You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
naza/pkg/ratelimit/leakybucket_test.go

67 lines
2.0 KiB
Go

// Copyright 2020, Chef. All rights reserved.
// https://github.com/q191201771/naza
//
// Use of this source code is governed by a MIT-style license
// that can be found in the License file.
//
// Author: Chef (191201771@qq.com)
package ratelimit_test
import (
"testing"
"time"
"github.com/q191201771/naza/pkg/nazalog"
"github.com/q191201771/naza/pkg/assert"
"github.com/q191201771/naza/pkg/ratelimit"
)
func TestNewLeakyBucket(t *testing.T) {
lb := ratelimit.NewLeakyBucket(10)
nazalog.Debugf("MaybeAvailableIntervalMSec=%d", lb.MaybeAvailableIntervalMSec())
}
func TestLeakyBucket_TryAquire(t *testing.T) {
var (
lb *ratelimit.LeakyBucket
err error
)
lb = ratelimit.NewLeakyBucket(1)
time.Sleep(10 * time.Millisecond)
err = lb.TryAquire()
nazalog.Debugf("MaybeAvailableIntervalMSec=%d", lb.MaybeAvailableIntervalMSec())
assert.Equal(t, nil, err)
time.Sleep(10 * time.Millisecond)
err = lb.TryAquire()
assert.Equal(t, nil, err)
nazalog.Debugf("MaybeAvailableIntervalMSec=%d", lb.MaybeAvailableIntervalMSec())
lb = ratelimit.NewLeakyBucket(100)
err = lb.TryAquire()
assert.Equal(t, ratelimit.ErrResourceNotAvailable, err)
nazalog.Debugf("MaybeAvailableIntervalMSec=%d", lb.MaybeAvailableIntervalMSec())
err = lb.TryAquire()
assert.Equal(t, ratelimit.ErrResourceNotAvailable, err)
nazalog.Debugf("MaybeAvailableIntervalMSec=%d", lb.MaybeAvailableIntervalMSec())
}
func TestLeakyBucket_WaitUntilAquire(t *testing.T) {
var lb *ratelimit.LeakyBucket
lb = ratelimit.NewLeakyBucket(1)
lb.WaitUntilAquire()
nazalog.Debugf("MaybeAvailableIntervalMSec=%d", lb.MaybeAvailableIntervalMSec())
time.Sleep(100 * time.Millisecond)
lb.WaitUntilAquire()
nazalog.Debugf("MaybeAvailableIntervalMSec=%d", lb.MaybeAvailableIntervalMSec())
lb = ratelimit.NewLeakyBucket(200)
lb.WaitUntilAquire()
nazalog.Debugf("MaybeAvailableIntervalMSec=%d", lb.MaybeAvailableIntervalMSec())
lb.WaitUntilAquire()
nazalog.Debugf("MaybeAvailableIntervalMSec=%d", lb.MaybeAvailableIntervalMSec())
}