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.
62 lines
1.2 KiB
Go
62 lines
1.2 KiB
Go
package nlog
|
|
|
|
import (
|
|
"sync/atomic"
|
|
"testing"
|
|
"time"
|
|
|
|
"git.noahlan.cn/noahlan/ntool/ntest/assert"
|
|
)
|
|
|
|
func TestLimitedExecutor_logOrDiscard(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
threshold time.Duration
|
|
lastTime time.Duration
|
|
discarded uint32
|
|
executed bool
|
|
}{
|
|
{
|
|
name: "nil executor",
|
|
executed: true,
|
|
},
|
|
{
|
|
name: "regular",
|
|
threshold: time.Hour,
|
|
lastTime: time.Since(time.Now().AddDate(-1, -1, -1)),
|
|
discarded: 10,
|
|
executed: false,
|
|
},
|
|
{
|
|
name: "slow",
|
|
threshold: time.Duration(1),
|
|
lastTime: -1000,
|
|
discarded: 10,
|
|
executed: true,
|
|
},
|
|
}
|
|
|
|
for _, test := range tests {
|
|
test := test
|
|
t.Run(test.name, func(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
executor := newLimitedExecutor(0)
|
|
executor.threshold = test.threshold
|
|
executor.discarded = test.discarded
|
|
executor.lastTime.Set(test.lastTime)
|
|
|
|
var run int32
|
|
executor.logOrDiscard(func() {
|
|
atomic.AddInt32(&run, 1)
|
|
})
|
|
if test.executed {
|
|
assert.Equal(t, int32(1), atomic.LoadInt32(&run))
|
|
} else {
|
|
assert.Equal(t, int32(0), atomic.LoadInt32(&run))
|
|
assert.Equal(t, test.discarded+1, atomic.LoadUint32(&executor.discarded))
|
|
}
|
|
})
|
|
}
|
|
}
|