chore: move from tools/dsa
All checks were successful
CI / lint (pull_request) Successful in 51s
CI / unit-test (pull_request) Successful in 25s
CI / mutation-test (pull_request) Successful in 2m44s
CI / fuzz-test (pull_request) Successful in 1m2s

Moved the implementation of this hash table from `tools/dsa` #1.
This commit is contained in:
2026-03-16 21:10:08 -04:00
parent 553117cb30
commit b762417b80
18 changed files with 1022 additions and 0 deletions

30
cuckoo_internal_test.go Normal file
View File

@@ -0,0 +1,30 @@
package cuckoo
import (
"math"
"testing"
"github.com/stretchr/testify/assert"
)
func TestMaxEvictions(t *testing.T) {
assert := assert.New(t)
for i := 16; i < 116; i++ {
table := NewTable[int, bool](Capacity(i / 2))
expectedEvictions := 3 * math.Floor(math.Log2(float64(i)))
assert.Equal(table.maxEvictions(), int(expectedEvictions))
}
}
func TestLoad(t *testing.T) {
assert := assert.New(t)
table := NewTable[int, bool](Capacity(8))
for i := range 16 {
err := table.Put(i, true)
assert.NoError(err)
assert.Equal(float64(table.Size())/float64(table.Capacity()), table.load())
}
}