Files
EdgeNode/internal/utils/linkedlist/list_test.go

149 lines
3.1 KiB
Go
Raw Permalink Normal View History

2024-05-17 18:30:33 +08:00
// Copyright 2022 GoEdge goedge.cdn@gmail.com. All rights reserved.
2022-01-12 21:09:00 +08:00
package linkedlist_test
import (
"runtime"
2023-10-03 21:41:03 +08:00
"strconv"
2022-01-12 21:09:00 +08:00
"testing"
2024-07-27 15:42:50 +08:00
"github.com/TeaOSLab/EdgeNode/internal/utils/linkedlist"
"github.com/iwind/TeaGo/types"
2022-01-12 21:09:00 +08:00
)
func TestNewList_Memory(t *testing.T) {
var stat1 = &runtime.MemStats{}
runtime.ReadMemStats(stat1)
2023-10-03 21:38:45 +08:00
var list = linkedlist.NewList[int]()
2022-01-12 21:09:00 +08:00
for i := 0; i < 1_000_000; i++ {
2023-10-03 21:38:45 +08:00
var item = &linkedlist.Item[int]{}
2022-01-12 21:09:00 +08:00
list.Push(item)
}
2023-10-03 21:38:45 +08:00
runtime.GC()
2022-01-12 21:09:00 +08:00
var stat2 = &runtime.MemStats{}
runtime.ReadMemStats(stat2)
2023-10-03 21:38:45 +08:00
t.Log((stat2.HeapInuse-stat1.HeapInuse)>>20, "MB")
2022-01-12 21:09:00 +08:00
t.Log(list.Len())
var count = 0
2023-10-03 21:38:45 +08:00
list.Range(func(item *linkedlist.Item[int]) (goNext bool) {
2022-01-12 21:09:00 +08:00
count++
return true
})
t.Log(count)
}
2023-10-03 21:41:03 +08:00
func TestNewList_Memory_String(t *testing.T) {
var stat1 = &runtime.MemStats{}
runtime.ReadMemStats(stat1)
var list = linkedlist.NewList[string]()
for i := 0; i < 1_000_000; i++ {
var item = &linkedlist.Item[string]{}
item.Value = strconv.Itoa(i)
list.Push(item)
}
runtime.GC()
var stat2 = &runtime.MemStats{}
runtime.ReadMemStats(stat2)
t.Log((stat2.HeapInuse-stat1.HeapInuse)>>20, "MB")
t.Log(list.Len())
}
2022-01-12 21:09:00 +08:00
func TestList_Push(t *testing.T) {
2023-10-03 21:38:45 +08:00
var list = linkedlist.NewList[int]()
2022-01-12 21:09:00 +08:00
list.Push(linkedlist.NewItem(1))
list.Push(linkedlist.NewItem(2))
var item3 = linkedlist.NewItem(3)
list.Push(item3)
var item4 = linkedlist.NewItem(4)
list.Push(item4)
2023-10-03 21:38:45 +08:00
list.Range(func(item *linkedlist.Item[int]) (goNext bool) {
2022-01-12 21:09:00 +08:00
t.Log(item.Value)
return true
})
2023-10-03 21:38:45 +08:00
t.Log("=== after push 3 ===")
2022-01-12 21:09:00 +08:00
list.Push(item3)
2023-10-03 21:38:45 +08:00
list.Range(func(item *linkedlist.Item[int]) (goNext bool) {
2022-01-12 21:09:00 +08:00
t.Log(item.Value)
return true
})
2023-10-03 21:38:45 +08:00
t.Log("=== after push 4 ===")
2022-01-12 21:09:00 +08:00
list.Push(item4)
list.Push(item3)
list.Push(item3)
list.Push(item3)
list.Push(item4)
list.Push(item4)
2023-10-03 21:38:45 +08:00
list.Range(func(item *linkedlist.Item[int]) (goNext bool) {
2022-01-12 21:09:00 +08:00
t.Log(item.Value)
return true
})
2023-10-03 21:38:45 +08:00
t.Log("=== after remove 3 ===")
2022-01-12 21:09:00 +08:00
list.Remove(item3)
2023-10-03 21:38:45 +08:00
list.Range(func(item *linkedlist.Item[int]) (goNext bool) {
2022-01-12 21:09:00 +08:00
t.Log(item.Value)
return true
})
}
2023-12-03 11:27:47 +08:00
func TestList_Shift(t *testing.T) {
var list = linkedlist.NewList[int]()
list.Push(linkedlist.NewItem(1))
list.Push(linkedlist.NewItem(2))
list.Push(linkedlist.NewItem(3))
list.Push(linkedlist.NewItem(4))
for i := 0; i < 10; i++ {
t.Log("=== before shift " + types.String(i) + " ===")
list.Range(func(item *linkedlist.Item[int]) (goNext bool) {
t.Log(item.Value)
return true
})
t.Logf("shift: %+v", list.Shift())
t.Log("=== after shift " + types.String(i) + " ===")
list.Range(func(item *linkedlist.Item[int]) (goNext bool) {
t.Log(item.Value)
return true
})
}
}
func TestList_RangeReverse(t *testing.T) {
var list = linkedlist.NewList[int]()
list.Push(linkedlist.NewItem(1))
list.Push(linkedlist.NewItem(2))
var item3 = linkedlist.NewItem(3)
list.Push(item3)
list.Push(linkedlist.NewItem(4))
//list.Push(item3)
//list.Remove(item3)
list.RangeReverse(func(item *linkedlist.Item[int]) (goNext bool) {
t.Log(item.Value)
return true
})
}
2022-01-12 21:09:00 +08:00
func BenchmarkList_Add(b *testing.B) {
2023-10-03 21:38:45 +08:00
var list = linkedlist.NewList[int]()
2022-01-12 21:09:00 +08:00
for i := 0; i < b.N; i++ {
2023-10-03 21:38:45 +08:00
var item = &linkedlist.Item[int]{}
2022-01-12 21:09:00 +08:00
list.Push(item)
}
}