change: Updated benchmarks to only use reads

This commit is contained in:
Nicholas Novak 2023-12-05 14:42:57 -08:00
parent a4620b99ce
commit 93c7564c43

View File

@ -1,6 +1,7 @@
package main
import (
"errors"
"testing"
"git.nicholasnovak.io/nnovak/spatial-db/storage"
@ -13,14 +14,17 @@ func init() {
server.SetStorageRoot("skygrid-save")
}
// insertPointTemplate inserts a configurable variety of points into the server
func insertPointTemplate(testDir string, b *testing.B, pointSpread int) {
func readBlockTemplate(rootDir string, b *testing.B, pointSpread int) {
b.ResetTimer()
for i := 0; i < b.N; i++ {
pos := world.RandomBlockPosWithRange(float64(pointSpread))
if err := server.ChangeBlock(pos, world.Generic); err != nil {
b.Error(err)
if _, err := server.ReadBlockAt(pos); err != nil {
if errors.Is(err, storage.ChunkNotFoundError) {
continue
} else {
b.Error(err)
}
}
}
}
@ -38,10 +42,10 @@ func fetchChunkTemplate(testDir string, b *testing.B) {
// Insert blocks
func BenchmarkInsertClusteredPoints(b *testing.B) {
insertPointTemplate("imperial-test", b, 128)
func BenchmarkReadClusteredPoints(b *testing.B) {
readBlockTemplate("skygrid-test", b, 128)
}
func BenchmarkInsertSparserPoints(b *testing.B) {
insertPointTemplate("imperial-test", b, 2048)
func BenchmarkReadSparserPoints(b *testing.B) {
readBlockTemplate("skygrid-test", b, 2048)
}