You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

168 lines
4.0 KiB

package storage
import (
"log"
"math/rand"
"os"
"runtime"
"testing"
)
var testIndexFilename string = "../../test/sample.idx"
func TestCdbMap0Convert(t *testing.T) {
indexFile, err := os.Open(testIndexFilename)
if err != nil {
t.Fatalf("cannot open %s: %s", testIndexFilename, err)
}
defer indexFile.Close()
cdbFn := testIndexFilename + ".cdb"
t.Logf("converting %s to %s", cdbFn, cdbFn)
if err = ConvertIndexToCdb(cdbFn, indexFile); err != nil {
t.Fatalf("error while converting: %s", err)
}
}
func TestCdbMap1Mem(t *testing.T) {
var nm NeedleMapper
i := 0
visit := func(nv NeedleValue) error {
i++
return nil
}
a := getMemStats()
t.Logf("opening %s.cdb", testIndexFilename)
nm, err := OpenCdbMap(testIndexFilename + ".cdb")
if err != nil {
t.Fatalf("error opening cdb: %s", err)
}
b := getMemStats()
log.Printf("opening cdb consumed %d bytes", b-a)
defer nm.Close()
a = getMemStats()
if err = nm.Visit(visit); err != nil {
t.Fatalf("error visiting %s: %s", nm, err)
}
b = getMemStats()
log.Printf("visit cdb %d consumed %d bytes", i, b-a)
nm.Close()
indexFile, err := os.Open(testIndexFilename)
if err != nil {
t.Fatalf("error opening idx: %s", err)
}
a = getMemStats()
nm, err = LoadNeedleMap(indexFile)
if err != nil {
t.Fatalf("error loading idx: %s", err)
}
defer nm.Close()
b = getMemStats()
log.Printf("opening idx consumed %d bytes", b-a)
i = 0
a = getMemStats()
if err = nm.Visit(visit); err != nil {
t.Fatalf("error visiting %s: %s", nm, err)
}
b = getMemStats()
log.Printf("visit idx %d consumed %d bytes", i, b-a)
}
func BenchmarkCdbMap9List(t *testing.B) {
t.StopTimer()
indexFile, err := os.Open(testIndexFilename)
if err != nil {
t.Fatalf("cannot open %s: %s", testIndexFilename, err)
}
defer indexFile.Close()
a := getMemStats()
t.Logf("opening %s", indexFile)
idx, err := LoadNeedleMap(indexFile)
if err != nil {
t.Fatalf("cannot load %s: %s", indexFile, err)
}
defer idx.Close()
b := getMemStats()
log.Printf("LoadNeedleMap consumed %d bytes", b-a)
cdbFn := testIndexFilename + ".cdb"
a = getMemStats()
t.Logf("opening %s", cdbFn)
m, err := OpenCdbMap(cdbFn)
if err != nil {
t.Fatalf("error opening %s: %s", cdbFn, err)
}
defer m.Close()
b = getMemStats()
log.Printf("OpenCdbMap consumed %d bytes", b-a)
i := 0
log.Printf("checking whether the cdb contains every key")
t.StartTimer()
err = idx.Visit(func(nv NeedleValue) error {
if i > t.N || rand.Intn(10) < 9 {
return nil
}
i++
if i%1000 == 0 {
log.Printf("%d. %s", i, nv)
}
if nv2, ok := m.Get(uint64(nv.Key)); !ok || nv2 == nil {
t.Errorf("%s in index, not in cdb", nv.Key)
} else if nv2.Key != nv.Key {
t.Errorf("requested key %d from cdb, got %d", nv.Key, nv2.Key)
} else if nv2.Offset != nv.Offset {
t.Errorf("offset is %d in index, %d in cdb", nv.Offset, nv2.Offset)
} else if nv2.Size != nv.Size {
t.Errorf("size is %d in index, %d in cdb", nv.Size, nv2.Size)
}
t.SetBytes(int64(nv.Size))
return nil
})
t.StopTimer()
if err != nil {
t.Errorf("error visiting index: %s", err)
}
i = 0
log.Printf("checking wheter the cdb contains no stray keys")
t.StartTimer()
err = m.Visit(func(nv NeedleValue) error {
if i > t.N || rand.Intn(10) < 9 {
return nil
}
if nv2, ok := m.Get(uint64(nv.Key)); !ok || nv2 == nil {
t.Errorf("%s in cdb, not in index", nv.Key)
} else if nv2.Key != nv.Key {
t.Errorf("requested key %d from index, got %d", nv.Key, nv2.Key)
} else if nv2.Offset != nv.Offset {
t.Errorf("offset is %d in cdb, %d in index", nv.Offset, nv2.Offset)
} else if nv2.Size != nv.Size {
t.Errorf("size is %d in cdb, %d in index", nv.Size, nv2.Size)
}
i++
if i%1000 == 0 {
log.Printf("%d. %s", i, nv)
}
t.SetBytes(int64(nv.Size))
return nil
})
t.StopTimer()
if err != nil {
t.Errorf("error visiting index: %s", err)
}
}
var mem = new(runtime.MemStats)
// returns MemStats.Alloc after a GC
func getMemStats() int64 {
runtime.GC()
runtime.ReadMemStats(mem)
return int64(mem.Alloc)
}