65 lines
1.3 KiB
Go
65 lines
1.3 KiB
Go
// Copyright 2020-2024 guonaihong, antlabs. All rights reserved.
|
||
//
|
||
// mit license
|
||
|
||
package timer
|
||
|
||
import (
|
||
"container/heap"
|
||
"testing"
|
||
"time"
|
||
)
|
||
|
||
func Test_NodeSizeof(t *testing.T) {
|
||
t.Run("输出最小堆node的sizeof", func(t *testing.T) {
|
||
// t.Logf("minHeapNode size: %d, %d\n", unsafe.Sizeof(minHeapNode{}), unsafe.Sizeof(time.Timer{}))
|
||
})
|
||
}
|
||
func Test_MinHeap(t *testing.T) {
|
||
t.Run("", func(t *testing.T) {
|
||
var mh minHeaps
|
||
now := time.Now()
|
||
n1 := minHeapNode{
|
||
absExpire: now.Add(time.Second),
|
||
userExpire: 1 * time.Second,
|
||
}
|
||
|
||
n2 := minHeapNode{
|
||
absExpire: now.Add(2 * time.Second),
|
||
userExpire: 2 * time.Second,
|
||
}
|
||
|
||
n3 := minHeapNode{
|
||
absExpire: now.Add(3 * time.Second),
|
||
userExpire: 3 * time.Second,
|
||
}
|
||
|
||
n6 := minHeapNode{
|
||
absExpire: now.Add(6 * time.Second),
|
||
userExpire: 6 * time.Second,
|
||
}
|
||
n5 := minHeapNode{
|
||
absExpire: now.Add(5 * time.Second),
|
||
userExpire: 5 * time.Second,
|
||
}
|
||
n4 := minHeapNode{
|
||
absExpire: now.Add(4 * time.Second),
|
||
userExpire: 4 * time.Second,
|
||
}
|
||
mh.Push(&n1)
|
||
mh.Push(&n2)
|
||
mh.Push(&n3)
|
||
mh.Push(&n6)
|
||
mh.Push(&n5)
|
||
mh.Push(&n4)
|
||
|
||
for i := 1; len(mh) > 0; i++ {
|
||
v := heap.Pop(&mh).(*minHeapNode)
|
||
|
||
if v.userExpire != time.Duration(i)*time.Second {
|
||
t.Errorf("index(%d) v.userExpire(%v) != %v", i, v.userExpire, time.Duration(i)*time.Second)
|
||
}
|
||
}
|
||
})
|
||
}
|