1 Star 0 Fork 0

websocket2024/gws

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
session_storage_test.go 3.67 KB
一键复制 编辑 原始数据 按行查看 历史
lxzan 提交于 1年前 . Add NewMap Method
package gws
import (
"testing"
"github.com/dolthub/maphash"
"github.com/lxzan/gws/internal"
"github.com/stretchr/testify/assert"
)
func TestMap(t *testing.T) {
var as = assert.New(t)
var m1 = make(map[string]any)
var m2 = newSmap()
var count = internal.AlphabetNumeric.Intn(1000)
for i := 0; i < count; i++ {
var key = string(internal.AlphabetNumeric.Generate(10))
var val = internal.AlphabetNumeric.Uint32()
m1[key] = val
m2.Store(key, val)
}
var keys = make([]string, 0)
for k, _ := range m1 {
keys = append(keys, k)
}
for i := 0; i < len(keys)/2; i++ {
delete(m1, keys[i])
m2.Delete(keys[i])
}
for k, v := range m1 {
v1, ok := m2.Load(k)
as.Equal(true, ok)
as.Equal(v, v1)
}
as.Equal(len(m1), m2.Len())
}
func TestSliceMap(t *testing.T) {
var as = assert.New(t)
var m = newSmap()
m.Store("hong", 1)
m.Store("mei", 2)
m.Store("ming", 3)
{
v, _ := m.Load("hong")
as.Equal(1, v)
}
{
m.Delete("hong")
v, ok := m.Load("hong")
as.Equal(false, ok)
as.Nil(v)
m.Store("hong", 4)
v, _ = m.Load("hong")
as.Equal(4, v)
}
}
func TestMap_Range(t *testing.T) {
var as = assert.New(t)
var m1 = make(map[any]any)
var m2 = newSmap()
var count = 1000
for i := 0; i < count; i++ {
var key = string(internal.AlphabetNumeric.Generate(10))
var val = internal.AlphabetNumeric.Uint32()
m1[key] = val
m2.Store(key, val)
}
{
var keys []any
m2.Range(func(key string, value any) bool {
v, ok := m1[key]
as.Equal(true, ok)
as.Equal(v, value)
keys = append(keys, key)
return len(keys) < 100
})
as.Equal(100, len(keys))
}
{
var keys []any
m2.Range(func(key string, value any) bool {
v, ok := m1[key]
as.Equal(true, ok)
as.Equal(v, value)
keys = append(keys, key)
return true
})
as.Equal(1000, len(keys))
}
}
func TestConcurrentMap(t *testing.T) {
var as = assert.New(t)
var m1 = make(map[string]any)
var m2 = NewConcurrentMap[string, uint32]()
as.Equal(m2.num, uint64(16))
var count = internal.AlphabetNumeric.Intn(1000)
for i := 0; i < count; i++ {
var key = string(internal.AlphabetNumeric.Generate(10))
var val = internal.AlphabetNumeric.Uint32()
m1[key] = val
m2.Store(key, val)
}
var keys = make([]string, 0)
for k, _ := range m1 {
keys = append(keys, k)
}
for i := 0; i < len(keys)/2; i++ {
delete(m1, keys[i])
m2.Delete(keys[i])
}
for k, v := range m1 {
v1, ok := m2.Load(k)
as.Equal(true, ok)
as.Equal(v, v1)
}
as.Equal(len(m1), m2.Len())
t.Run("", func(t *testing.T) {
var sum = 0
var cm = NewConcurrentMap[string, int](8, 8)
for _, item := range cm.shardings {
sum += len(item.m)
}
assert.Equal(t, sum, 0)
})
}
func TestConcurrentMap_Range(t *testing.T) {
var as = assert.New(t)
var m1 = make(map[any]any)
var m2 = NewConcurrentMap[string, uint32](13)
var count = 1000
for i := 0; i < count; i++ {
var key = string(internal.AlphabetNumeric.Generate(10))
var val = internal.AlphabetNumeric.Uint32()
m1[key] = val
m2.Store(key, val)
}
{
var keys []any
m2.Range(func(key string, value uint32) bool {
v, ok := m1[key]
as.Equal(true, ok)
as.Equal(v, value)
keys = append(keys, key)
return len(keys) < 100
})
as.Equal(100, len(keys))
}
{
var keys []any
m2.Range(func(key string, value uint32) bool {
v, ok := m1[key]
as.Equal(true, ok)
as.Equal(v, value)
keys = append(keys, key)
return true
})
as.Equal(1000, len(keys))
}
}
func TestHash(t *testing.T) {
var h = maphash.NewHasher[string]()
for i := 0; i < 1000; i++ {
var a = string(internal.AlphabetNumeric.Generate(16))
var b = string(internal.AlphabetNumeric.Generate(16))
assert.Equal(t, h.Hash(a), h.Hash(a))
assert.NotEqual(t, h.Hash(a), h.Hash(b))
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/websocket2024/gws.git
git@gitee.com:websocket2024/gws.git
websocket2024
gws
gws
dev

搜索帮助