erigon-pulse/common/debug/hack/cs_test.go

54 lines
1.2 KiB
Go
Raw Normal View History

package hack
import (
"bytes"
"fmt"
"testing"
"github.com/ledgerwatch/turbo-geth/common"
"github.com/ledgerwatch/turbo-geth/common/changeset"
"github.com/ledgerwatch/turbo-geth/common/dbutils"
"github.com/ledgerwatch/turbo-geth/ethdb"
)
func TestDecodeNewStorageDebug(t *testing.T) {
t.Skip("debug test")
pathToDB := ""
db := ethdb.MustOpen(pathToDB)
data, err := db.Get(dbutils.StorageChangeSetBucket, dbutils.EncodeTimestamp(116526))
if err != nil {
t.Fatal(err)
}
cs, err := changeset.DecodeStorage(data)
if err != nil {
t.Fatal(err)
}
newData, err := changeset.EncodeStorage(cs)
if err != nil {
t.Fatal(err)
}
for _, v := range cs.Changes {
fmt.Println(common.Bytes2Hex(v.Key), " - ", common.Bytes2Hex(v.Value))
}
j := 0
fmt.Println()
err = changeset.StorageChangeSetBytes(newData).Walk(func(kk, vv []byte) error {
fmt.Println(common.Bytes2Hex(kk), " - ", common.Bytes2Hex(vv))
if !bytes.Equal(kk, cs.Changes[j].Key) {
t.Errorf("incorrect order. element: %v", j)
}
if !bytes.Equal(vv, cs.Changes[j].Value) {
t.Errorf("incorrect value. key:%v", common.Bytes2Hex(cs.Changes[j].Key))
}
j++
return nil
})
if err != nil {
t.Fatal(err)
}
}