mirror of
https://github.com/Llewellynvdm/fzf.git
synced 2024-11-29 16:23:57 +00:00
37dc273148
- Make structs smaller - Introduce Result struct and use it to represent matched items instead of reusing Item struct for that purpose - Avoid unnecessary memory allocation - Avoid growing slice from the initial capacity - Code cleanup
41 lines
917 B
Go
41 lines
917 B
Go
package fzf
|
|
|
|
import "testing"
|
|
|
|
func TestChunkCache(t *testing.T) {
|
|
cache := NewChunkCache()
|
|
chunk2 := make(Chunk, chunkSize)
|
|
chunk1p := &Chunk{}
|
|
chunk2p := &chunk2
|
|
items1 := []*Result{&Result{}}
|
|
items2 := []*Result{&Result{}, &Result{}}
|
|
cache.Add(chunk1p, "foo", items1)
|
|
cache.Add(chunk2p, "foo", items1)
|
|
cache.Add(chunk2p, "bar", items2)
|
|
|
|
{ // chunk1 is not full
|
|
cached, found := cache.Find(chunk1p, "foo")
|
|
if found {
|
|
t.Error("Cached disabled for non-empty chunks", found, cached)
|
|
}
|
|
}
|
|
{
|
|
cached, found := cache.Find(chunk2p, "foo")
|
|
if !found || len(cached) != 1 {
|
|
t.Error("Expected 1 item cached", found, cached)
|
|
}
|
|
}
|
|
{
|
|
cached, found := cache.Find(chunk2p, "bar")
|
|
if !found || len(cached) != 2 {
|
|
t.Error("Expected 2 items cached", found, cached)
|
|
}
|
|
}
|
|
{
|
|
cached, found := cache.Find(chunk1p, "foobar")
|
|
if found {
|
|
t.Error("Expected 0 item cached", found, cached)
|
|
}
|
|
}
|
|
}
|