2021-09-27 11:29:47 +08:00
|
|
|
package lru
|
|
|
|
|
|
|
|
import (
|
2021-10-04 20:32:20 +08:00
|
|
|
"fmt"
|
2021-10-12 21:13:42 +08:00
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2021-10-06 20:38:37 +08:00
|
|
|
"gitee.com/timedb/wheatCache/pkg/proto"
|
2021-09-27 11:29:47 +08:00
|
|
|
"gitee.com/timedb/wheatCache/pkg/structure/stringx"
|
2021-10-04 11:21:55 +08:00
|
|
|
"github.com/stretchr/testify/require"
|
2021-09-27 11:29:47 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestNewLRUCache(t *testing.T) {
|
|
|
|
cache := NewLRUCache()
|
|
|
|
v1 := stringx.NewStringSingle()
|
|
|
|
v2 := stringx.NewStringSingle()
|
|
|
|
v3 := stringx.NewStringSingle()
|
2021-10-06 20:38:37 +08:00
|
|
|
key1 := proto.BaseKey{
|
|
|
|
Key: "1",
|
|
|
|
}
|
|
|
|
key2 := proto.BaseKey{
|
|
|
|
Key: "2",
|
|
|
|
}
|
|
|
|
key3 := proto.BaseKey{
|
|
|
|
Key: "3",
|
|
|
|
}
|
|
|
|
cache.Add(&key1, v1)
|
|
|
|
cache.Add(&key2, v2)
|
|
|
|
cache.Add(&key3, v3)
|
|
|
|
cache.Add(&key1, v1)
|
2021-10-04 20:32:20 +08:00
|
|
|
fmt.Println(cache.nowSize)
|
2021-09-27 11:29:47 +08:00
|
|
|
cache.Del()
|
2021-10-04 20:32:20 +08:00
|
|
|
fmt.Println(cache.nowSize)
|
2021-10-06 20:38:37 +08:00
|
|
|
_, isTrue := cache.Get(&key1)
|
2021-10-04 11:21:55 +08:00
|
|
|
require.Equal(t, isTrue, true)
|
2021-10-06 19:56:32 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewLRUCache2(t *testing.T) {
|
|
|
|
//根据key删除
|
|
|
|
cache := NewLRUCache()
|
|
|
|
v1 := stringx.NewStringSingle()
|
|
|
|
v2 := stringx.NewStringSingle()
|
|
|
|
v3 := stringx.NewStringSingle()
|
2021-10-06 20:38:37 +08:00
|
|
|
key1 := proto.BaseKey{
|
|
|
|
Key: "1",
|
|
|
|
}
|
|
|
|
key2 := proto.BaseKey{
|
|
|
|
Key: "2",
|
|
|
|
}
|
|
|
|
key3 := proto.BaseKey{
|
|
|
|
Key: "3",
|
|
|
|
}
|
|
|
|
cache.Add(&key1, v1)
|
|
|
|
cache.Add(&key2, v2)
|
|
|
|
cache.Add(&key3, v3)
|
|
|
|
cache.DelByKey(&key1)
|
|
|
|
_, ok := cache.Get(&key1)
|
2021-10-06 19:56:32 +08:00
|
|
|
require.Equal(t, ok, false)
|
2021-10-06 20:38:37 +08:00
|
|
|
require.Error(t, cache.DelByKey(&key1))
|
2021-10-12 21:13:42 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestLruProcess(t *testing.T) {
|
|
|
|
lru := NewLRUCache()
|
|
|
|
lru.clearSize = 1000
|
|
|
|
|
|
|
|
for i := 100; i < 200; i++ {
|
|
|
|
lru.Add(&proto.BaseKey{
|
|
|
|
Key: fmt.Sprint(i),
|
|
|
|
Ttl: 20 << 2,
|
|
|
|
}, stringx.NewStringSingle())
|
|
|
|
}
|
|
|
|
|
|
|
|
// mock LruKey
|
|
|
|
for i := 0; i < 100; i++ {
|
|
|
|
lru.Add(&proto.BaseKey{
|
|
|
|
Key: fmt.Sprint(i),
|
|
|
|
Ttl: 4,
|
|
|
|
}, stringx.NewStringSingle())
|
|
|
|
}
|
|
|
|
|
|
|
|
require.Equal(t, lru.nowSize, int64(200*8))
|
|
|
|
|
|
|
|
// 自动清理测试
|
|
|
|
time.Sleep(3 * time.Second)
|
|
|
|
fmt.Println(lru.nowSize)
|
|
|
|
require.Less(t, lru.nowSize, lru.clearSize+1)
|
|
|
|
|
|
|
|
// TTL 测试
|
|
|
|
time.Sleep(2 * time.Second)
|
|
|
|
require.Equal(t, lru.li.Len(), 25)
|
|
|
|
|
|
|
|
// 过期全部的 Key
|
|
|
|
for i := 100; i < 200; i++ {
|
|
|
|
lru.UpdateTTl(&proto.BaseKey{
|
|
|
|
Key: fmt.Sprint(i),
|
|
|
|
Ttl: -1,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
time.Sleep(2 * time.Second)
|
|
|
|
require.Equal(t, lru.nowSize, int64(0))
|
|
|
|
}
|