Files
EdgeNode/internal/caches/list_file_sqlite_test.go

448 lines
7.7 KiB
Go
Raw Normal View History

2024-05-17 18:30:33 +08:00
// Copyright 2021 GoEdge goedge.cdn@gmail.com. All rights reserved.
2021-05-19 12:07:35 +08:00
2022-03-15 18:32:39 +08:00
package caches_test
2021-05-19 12:07:35 +08:00
import (
2022-03-15 18:32:39 +08:00
"github.com/TeaOSLab/EdgeNode/internal/caches"
2024-05-11 09:23:54 +08:00
"github.com/TeaOSLab/EdgeNode/internal/utils/goman"
2023-06-07 21:49:42 +08:00
"github.com/TeaOSLab/EdgeNode/internal/utils/testutils"
2021-05-19 12:07:35 +08:00
"github.com/iwind/TeaGo/Tea"
2021-06-13 17:37:57 +08:00
"github.com/iwind/TeaGo/rands"
"github.com/iwind/TeaGo/types"
2021-05-19 12:07:35 +08:00
stringutil "github.com/iwind/TeaGo/utils/string"
"strconv"
2021-06-13 17:37:57 +08:00
"sync"
2021-05-19 12:07:35 +08:00
"testing"
"time"
)
func TestFileList_Init(t *testing.T) {
2024-01-21 11:13:30 +08:00
if !testutils.IsSingleTesting() {
return
}
var list = caches.NewSQLiteFileList(Tea.Root + "/data/cache-index/p1")
2023-06-07 21:49:42 +08:00
defer func() {
_ = list.Close()
}()
2021-05-19 12:07:35 +08:00
err := list.Init()
if err != nil {
t.Fatal(err)
}
2022-03-15 18:32:39 +08:00
defer func() {
_ = list.Close()
}()
2021-05-19 12:07:35 +08:00
t.Log("ok")
}
func TestFileList_Add(t *testing.T) {
2024-01-21 11:13:30 +08:00
if !testutils.IsSingleTesting() {
return
}
var list = caches.NewSQLiteFileList(Tea.Root + "/data/cache-index/p1").(*caches.SQLiteFileList)
2023-06-07 21:49:42 +08:00
defer func() {
_ = list.Close()
}()
2021-05-19 12:07:35 +08:00
err := list.Init()
if err != nil {
t.Fatal(err)
}
2022-03-15 18:32:39 +08:00
defer func() {
_ = list.Close()
}()
var hash = stringutil.Md5("123456")
t.Log("db index:", list.GetDBIndex(hash))
err = list.Add(hash, &caches.Item{
2021-05-19 12:07:35 +08:00
Key: "123456",
2024-03-22 08:23:22 +08:00
ExpiresAt: time.Now().Unix() + 1,
2021-05-19 12:07:35 +08:00
HeaderSize: 1,
MetaSize: 2,
BodySize: 3,
2021-06-13 17:37:57 +08:00
Host: "teaos.cn",
ServerId: 1,
2021-05-19 12:07:35 +08:00
})
if err != nil {
t.Fatal(err)
}
2022-03-15 18:32:39 +08:00
2022-03-16 16:20:53 +08:00
t.Log(list.Exist(hash))
2021-05-19 12:07:35 +08:00
t.Log("ok")
}
func TestFileList_Add_Many(t *testing.T) {
2023-06-07 21:49:42 +08:00
if !testutils.IsSingleTesting() {
return
2021-05-19 12:07:35 +08:00
}
2022-03-15 18:32:39 +08:00
var list = caches.NewSQLiteFileList(Tea.Root + "/data/cache-index/p1")
2023-06-07 21:49:42 +08:00
2022-03-15 18:32:39 +08:00
defer func() {
_ = list.Close()
}()
2023-06-07 21:49:42 +08:00
err := list.Init()
if err != nil {
t.Fatal(err)
}
var before = time.Now()
2024-03-19 21:08:00 +08:00
const offset = 0
const count = 1_000_000
for i := offset; i < offset+count; i++ {
u := "https://edge.teaos.cn/123456" + strconv.Itoa(i)
2022-03-15 18:32:39 +08:00
_ = list.Add(stringutil.Md5(u), &caches.Item{
2021-05-19 12:07:35 +08:00
Key: u,
2024-03-22 08:23:22 +08:00
ExpiresAt: time.Now().Unix() + 3600,
2021-05-19 12:07:35 +08:00
HeaderSize: 1,
MetaSize: 2,
BodySize: 3,
})
if err != nil {
t.Fatal(err)
}
2021-06-13 17:37:57 +08:00
if i > 0 && i%10_000 == 0 {
t.Log(i, int(10000/time.Since(before).Seconds()), "qps")
before = time.Now()
}
2021-05-19 12:07:35 +08:00
}
t.Log("ok")
}
func TestFileList_Exist(t *testing.T) {
2024-01-21 11:13:30 +08:00
if !testutils.IsSingleTesting() {
return
}
var list = caches.NewSQLiteFileList(Tea.Root + "/data/cache-index/p1").(*caches.SQLiteFileList)
2023-06-07 21:49:42 +08:00
defer func() {
_ = list.Close()
}()
2021-05-19 12:07:35 +08:00
err := list.Init()
if err != nil {
t.Fatal(err)
}
2022-03-15 18:32:39 +08:00
total, _ := list.Count()
t.Log("total:", total)
var before = time.Now()
2021-06-13 17:37:57 +08:00
defer func() {
t.Log(time.Since(before).Seconds()*1000, "ms")
}()
2021-05-19 12:07:35 +08:00
{
2022-03-15 18:32:39 +08:00
var hash = stringutil.Md5("123456")
2024-04-04 08:28:14 +08:00
exists, _, err := list.Exist(hash)
2021-05-19 12:07:35 +08:00
if err != nil {
t.Fatal(err)
}
2022-03-15 18:32:39 +08:00
t.Log(hash, "exists:", exists)
2021-05-19 12:07:35 +08:00
}
{
2022-03-15 18:32:39 +08:00
var hash = stringutil.Md5("http://edge.teaos.cn/1234561")
2024-04-04 08:28:14 +08:00
exists, _, err := list.Exist(hash)
2021-05-19 12:07:35 +08:00
if err != nil {
t.Fatal(err)
}
2022-03-15 18:32:39 +08:00
t.Log(hash, "exists:", exists)
2021-05-19 12:07:35 +08:00
}
}
2021-06-13 17:37:57 +08:00
func TestFileList_Exist_Many_DB(t *testing.T) {
2024-01-21 11:13:30 +08:00
if !testutils.IsSingleTesting() {
return
}
2021-06-13 17:37:57 +08:00
// 测试在多个数据库下的性能
2022-03-15 18:32:39 +08:00
var listSlice = []caches.ListInterface{}
2021-06-13 17:37:57 +08:00
for i := 1; i <= 10; i++ {
var list = caches.NewSQLiteFileList(Tea.Root + "/data/data" + strconv.Itoa(i))
2021-06-13 17:37:57 +08:00
err := list.Init()
if err != nil {
t.Fatal(err)
}
listSlice = append(listSlice, list)
}
2023-06-07 21:49:42 +08:00
defer func() {
for _, list := range listSlice {
_ = list.Close()
}
}()
2021-06-13 17:37:57 +08:00
var wg = sync.WaitGroup{}
var threads = 8
wg.Add(threads)
var count = 200_000
var countLocker sync.Mutex
var tasks = make(chan int, count)
for i := 0; i < count; i++ {
tasks <- i
}
var hash = stringutil.Md5("http://edge.teaos.cn/1234561")
before := time.Now()
defer func() {
t.Log(time.Since(before).Seconds()*1000, "ms")
}()
for i := 0; i < threads; i++ {
goman.New(func() {
2021-06-13 17:37:57 +08:00
defer wg.Done()
for {
select {
case <-tasks:
countLocker.Lock()
count--
countLocker.Unlock()
var list = listSlice[rands.Int(0, len(listSlice)-1)]
2024-04-04 08:28:14 +08:00
_, _, _ = list.Exist(hash)
2021-06-13 17:37:57 +08:00
default:
return
}
}
})
2021-06-13 17:37:57 +08:00
}
wg.Wait()
t.Log("left:", count)
}
func TestFileList_CleanPrefix(t *testing.T) {
2024-01-21 11:13:30 +08:00
if !testutils.IsSingleTesting() {
return
}
var list = caches.NewSQLiteFileList(Tea.Root + "/data/cache-index/p1")
2022-03-15 18:32:39 +08:00
defer func() {
_ = list.Close()
}()
2023-06-07 21:49:42 +08:00
err := list.Init()
if err != nil {
t.Fatal(err)
}
2021-05-19 12:07:35 +08:00
before := time.Now()
2022-03-15 18:32:39 +08:00
err = list.CleanPrefix("123")
2021-05-19 12:07:35 +08:00
if err != nil {
t.Fatal(err)
}
t.Log(time.Since(before).Seconds()*1000, "ms")
}
func TestFileList_Remove(t *testing.T) {
2024-01-21 11:13:30 +08:00
if !testutils.IsSingleTesting() {
return
}
var list = caches.NewSQLiteFileList(Tea.Root + "/data/cache-index/p1").(*caches.SQLiteFileList)
2023-06-07 21:49:42 +08:00
defer func() {
_ = list.Close()
}()
2021-05-19 12:07:35 +08:00
err := list.Init()
if err != nil {
t.Fatal(err)
}
2022-03-15 18:32:39 +08:00
list.OnRemove(func(item *caches.Item) {
2021-05-19 12:07:35 +08:00
t.Logf("remove %#v", item)
})
err = list.Remove(stringutil.Md5("123456"))
if err != nil {
t.Fatal(err)
}
t.Log("ok")
2022-03-15 18:32:39 +08:00
t.Log("===count===")
t.Log(list.Count())
2021-05-19 12:07:35 +08:00
}
func TestFileList_Purge(t *testing.T) {
2024-01-21 11:13:30 +08:00
if !testutils.IsSingleTesting() {
return
}
var list = caches.NewSQLiteFileList(Tea.Root + "/data/cache-index/p1")
2023-06-07 21:49:42 +08:00
defer func() {
_ = list.Close()
}()
2021-05-19 12:07:35 +08:00
err := list.Init()
if err != nil {
t.Fatal(err)
}
2022-03-15 18:32:39 +08:00
var count = 0
_, err = list.Purge(caches.CountFileDB*2, func(hash string) error {
2021-05-19 12:07:35 +08:00
t.Log(hash)
2022-03-15 18:32:39 +08:00
count++
2021-05-19 12:07:35 +08:00
return nil
})
if err != nil {
t.Fatal(err)
}
2022-03-15 18:32:39 +08:00
t.Log("ok, purged", count, "items")
}
func TestFileList_PurgeLFU(t *testing.T) {
2024-01-21 11:13:30 +08:00
if !testutils.IsSingleTesting() {
return
}
var list = caches.NewSQLiteFileList(Tea.Root + "/data/cache-index/p1")
2023-06-07 21:49:42 +08:00
defer func() {
_ = list.Close()
}()
2022-03-15 18:32:39 +08:00
err := list.Init()
if err != nil {
t.Fatal(err)
}
var count = 0
err = list.PurgeLFU(caches.CountFileDB*2, func(hash string) error {
t.Log(hash)
count++
return nil
})
if err != nil {
t.Fatal(err)
}
t.Log("ok, purged", count, "items")
2021-05-19 12:07:35 +08:00
}
func TestFileList_Stat(t *testing.T) {
2024-01-21 11:13:30 +08:00
if !testutils.IsSingleTesting() {
return
}
var list = caches.NewSQLiteFileList(Tea.Root + "/data/cache-index/p1")
2022-03-15 18:32:39 +08:00
defer func() {
_ = list.Close()
}()
2023-06-07 21:49:42 +08:00
err := list.Init()
if err != nil {
t.Fatal(err)
}
2021-05-19 12:07:35 +08:00
stat, err := list.Stat(nil)
if err != nil {
t.Fatal(err)
}
t.Log("count:", stat.Count, "size:", stat.Size, "valueSize:", stat.ValueSize)
}
func TestFileList_Count(t *testing.T) {
2024-01-21 11:13:30 +08:00
if !testutils.IsSingleTesting() {
return
}
var list = caches.NewSQLiteFileList(Tea.Root + "/data")
2023-06-07 21:49:42 +08:00
defer func() {
_ = list.Close()
}()
2021-05-19 12:07:35 +08:00
err := list.Init()
if err != nil {
t.Fatal(err)
}
var before = time.Now()
2021-05-19 12:07:35 +08:00
count, err := list.Count()
if err != nil {
t.Fatal(err)
}
t.Log("count:", count)
t.Log(time.Since(before).Seconds()*1000, "ms")
}
func TestFileList_CleanAll(t *testing.T) {
2024-01-21 11:13:30 +08:00
if !testutils.IsSingleTesting() {
return
}
var list = caches.NewSQLiteFileList(Tea.Root + "/data")
2023-06-07 21:49:42 +08:00
defer func() {
_ = list.Close()
}()
2021-05-19 12:07:35 +08:00
err := list.Init()
if err != nil {
t.Fatal(err)
}
err = list.CleanAll()
if err != nil {
t.Fatal(err)
}
t.Log("ok")
t.Log(list.Count())
}
2021-06-13 17:37:57 +08:00
2022-03-15 18:32:39 +08:00
func TestFileList_UpgradeV3(t *testing.T) {
2024-01-21 11:13:30 +08:00
if !testutils.IsSingleTesting() {
return
}
var list = caches.NewSQLiteFileList(Tea.Root + "/data/cache-index/p43").(*caches.SQLiteFileList)
2023-06-07 21:49:42 +08:00
defer func() {
_ = list.Close()
}()
err := list.Init()
if err != nil {
t.Fatal(err)
}
2022-03-15 18:32:39 +08:00
defer func() {
2022-03-15 18:32:39 +08:00
_ = list.Close()
}()
2022-03-15 18:32:39 +08:00
err = list.UpgradeV3("/Users/WorkSpace/EdgeProject/EdgeCache/p43", false)
if err != nil {
2022-03-15 18:32:39 +08:00
t.Log(err)
return
}
t.Log("ok")
}
2021-06-13 17:37:57 +08:00
func BenchmarkFileList_Exist(b *testing.B) {
2024-01-21 11:13:30 +08:00
if !testutils.IsSingleTesting() {
return
}
var list = caches.NewSQLiteFileList(Tea.Root + "/data/cache-index/p1")
2023-06-07 21:49:42 +08:00
defer func() {
_ = list.Close()
}()
2021-06-13 17:37:57 +08:00
err := list.Init()
if err != nil {
b.Fatal(err)
}
b.ResetTimer()
2021-06-13 17:37:57 +08:00
for i := 0; i < b.N; i++ {
2024-04-04 08:28:14 +08:00
_, _, _ = list.Exist("f0eb5b87e0b0041f3917002c0707475f" + types.String(i))
2021-06-13 17:37:57 +08:00
}
}