mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2024-12-24 20:47:16 +00:00
6372b6ef5a
* Make stage7 and stage8 idempotent * Fix formatting * fix * Fix formatting
86 lines
1.6 KiB
Go
86 lines
1.6 KiB
Go
package dbutils
|
|
|
|
import (
|
|
"reflect"
|
|
"testing"
|
|
)
|
|
|
|
func TestHistoryIndex_Search1(t *testing.T) {
|
|
index := NewHistoryIndex().Append(3, false).Append(5, false).Append(8, false)
|
|
v, _, _ := index.Search(1)
|
|
if v != 3 {
|
|
t.Fatal("must be 3 but", v)
|
|
}
|
|
v, _, _ = index.Search(3)
|
|
if v != 3 {
|
|
t.Fatal("must be 3")
|
|
}
|
|
|
|
v, _, _ = index.Search(4)
|
|
if v != 5 {
|
|
t.Fatal("must be 5")
|
|
}
|
|
|
|
v, _, _ = index.Search(5)
|
|
if v != 5 {
|
|
t.Fatal("must be 5")
|
|
}
|
|
v, _, _ = index.Search(7)
|
|
if v != 8 {
|
|
t.Fatal("must be 8")
|
|
}
|
|
v, _, _ = index.Search(8)
|
|
if v != 8 {
|
|
t.Fatal("must be 8")
|
|
}
|
|
_, _, b := index.Search(9)
|
|
if b {
|
|
t.Fatal("must be not found")
|
|
}
|
|
}
|
|
|
|
func TestHistoryIndex_Search_EmptyIndex(t *testing.T) {
|
|
index := NewHistoryIndex()
|
|
_, _, b := index.Search(1)
|
|
if b {
|
|
t.FailNow()
|
|
}
|
|
}
|
|
|
|
func TestHistoryIndex_Append(t *testing.T) {
|
|
index := NewHistoryIndex()
|
|
for i := uint64(1); i < 10; i++ {
|
|
index = index.Append(i, false)
|
|
}
|
|
|
|
res, _, err := index.Decode()
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if !reflect.DeepEqual(res, []uint64{1, 2, 3, 4, 5, 6, 7, 8, 9}) {
|
|
t.Fatal("Not equal")
|
|
}
|
|
|
|
if index.Len() != 9 {
|
|
t.Fatal()
|
|
}
|
|
}
|
|
|
|
func TestHistoryIndex_Idempotent(t *testing.T) {
|
|
index := NewHistoryIndex()
|
|
for i := uint64(1); i < 10; i++ {
|
|
index = index.Append(i, false)
|
|
}
|
|
oldLen := len(index)
|
|
for i := uint64(1); i < 10; i++ {
|
|
index = index.Append(i, false)
|
|
if len(index) != oldLen {
|
|
t.Errorf("index is not idempotent, managed to append %d", i)
|
|
}
|
|
}
|
|
index = index.Append(11, false)
|
|
if len(index) != oldLen+3 {
|
|
t.Errorf("appending after the last element should still work: %d != %d", len(index), oldLen+3)
|
|
}
|
|
}
|