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.
253 lines
5.2 KiB
253 lines
5.2 KiB
package explorer
|
|
|
|
import (
|
|
"bytes"
|
|
"reflect"
|
|
"sort"
|
|
"testing"
|
|
"time"
|
|
|
|
goversion "github.com/hashicorp/go-version"
|
|
)
|
|
|
|
var (
|
|
testNormalIndexes = makeTestNormalIndexes(10)
|
|
testStakingIndexes = makeTestStakingIndexes(10)
|
|
)
|
|
|
|
func TestVersion(t *testing.T) {
|
|
tests := []struct {
|
|
hasKey bool
|
|
write string
|
|
is100 bool
|
|
}{
|
|
{
|
|
hasKey: false,
|
|
write: "",
|
|
is100: false,
|
|
},
|
|
{
|
|
hasKey: true,
|
|
write: "0.0.9",
|
|
is100: false,
|
|
},
|
|
{
|
|
hasKey: true,
|
|
write: "1.0.0",
|
|
is100: true,
|
|
},
|
|
{
|
|
hasKey: true,
|
|
write: "1.0.1",
|
|
is100: true,
|
|
},
|
|
}
|
|
for i, test := range tests {
|
|
db := newMemDB()
|
|
if test.hasKey {
|
|
ver, err := goversion.NewVersion(test.write)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if err := writeVersion(db, ver); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
got, err := isVersionV100(db)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if got != test.is100 {
|
|
t.Errorf("Test %v: unexpected %v / %v", i, got, test.is100)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestTxnReadWrite(t *testing.T) {
|
|
db := newMemDB()
|
|
hash := makeTestTxHash(1)
|
|
txRecord := &TxRecord{
|
|
Hash: hash,
|
|
Timestamp: time.Unix(100, 0),
|
|
}
|
|
if err := writeTxn(db, hash, txRecord); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
read, err := readTxnByHash(db, hash)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if !reflect.DeepEqual(read, txRecord) {
|
|
t.Errorf("not deep equal")
|
|
}
|
|
}
|
|
|
|
func TestGetNormalTxnHashesByAccount(t *testing.T) {
|
|
db := newMemDB()
|
|
|
|
txnIndexes := makeTestNormalIndexes(10)
|
|
for _, index := range txnIndexes {
|
|
if err := writeNormalTxnIndex(db, index, txSent); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
// Checking results.
|
|
for i := 0; i != 10; i++ {
|
|
addr := makeOneAddress(i)
|
|
hashes, tts, err := getNormalTxnHashesByAccount(db, addr)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if exp := i; exp != len(hashes) {
|
|
t.Errorf("get normal txn hashes not expected: %v / %v", len(hashes), exp)
|
|
}
|
|
for _, tt := range tts {
|
|
if tt != txSent {
|
|
t.Errorf("unexpected type")
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestNormalTxnIndexPrefix(t *testing.T) {
|
|
index := testNormalIndexes[0]
|
|
key := index.key()
|
|
prefix := normalTxnIndexPrefixByAddr(index.addr)
|
|
|
|
if !bytes.HasPrefix(key, prefix) {
|
|
t.Errorf("does not have prefix")
|
|
}
|
|
}
|
|
|
|
func TestTxHashFromNormalTxnIndexKey(t *testing.T) {
|
|
index := testNormalIndexes[0]
|
|
key := index.key()
|
|
txHash, err := txnHashFromNormalTxnIndexKey(key)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if txHash != index.txnHash {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestStakingTxnIndexPrefix(t *testing.T) {
|
|
index := testStakingIndexes[0]
|
|
key := index.key()
|
|
prefix := stakingTxnIndexPrefixByAddr(index.addr)
|
|
|
|
if !bytes.HasPrefix(key, prefix) {
|
|
t.Errorf("does not have prefix")
|
|
}
|
|
}
|
|
|
|
func TestTxHashFromStakingTxnIndexKey(t *testing.T) {
|
|
index := testStakingIndexes[0]
|
|
key := index.key()
|
|
txHash, err := txnHashFromStakingTxnIndexKey(key)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if txHash != index.txnHash {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestGetStakingTxnHashesByAccount(t *testing.T) {
|
|
db := newMemDB()
|
|
|
|
txnIndexes := makeTestStakingIndexes(10)
|
|
for _, index := range txnIndexes {
|
|
if err := writeStakingTxnIndex(db, index, txSent); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
// Checking results.
|
|
for i := 0; i != 10; i++ {
|
|
addr := makeOneAddress(i)
|
|
hashes, tts, err := getStakingTxnHashesByAccount(db, addr)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if exp := i; exp != len(hashes) {
|
|
t.Errorf("get normal txn hashes not expected: %v / %v", len(hashes), exp)
|
|
}
|
|
if len(hashes) != len(tts) {
|
|
t.Errorf("hash size not equal to TxType size")
|
|
}
|
|
for _, tt := range tts {
|
|
if tt != txSent {
|
|
t.Errorf("unexpected type")
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestGetAllAddresses(t *testing.T) {
|
|
db := newMemDB()
|
|
addrs := makeAddresses(10)
|
|
for _, addr := range addrs {
|
|
if err := writeAddressEntry(db, addr); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
gotAddrs, err := getAllAddresses(db)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if len(gotAddrs) != len(addrs) {
|
|
t.Fatalf("unexpected size %v / %v", len(gotAddrs), len(addrs))
|
|
}
|
|
sort.SliceStable(addrs, func(i, j int) bool {
|
|
return bytes.Compare([]byte(addrs[i]), []byte(addrs[j])) < 0
|
|
})
|
|
// got addresses are expected to be sorted as addrs
|
|
for i := range gotAddrs {
|
|
got := gotAddrs[i]
|
|
exp := addrs[i]
|
|
if got != exp {
|
|
t.Errorf("unexpected address: %v / %v", got, exp)
|
|
}
|
|
}
|
|
}
|
|
|
|
func makeAddresses(size int) []oneAddress {
|
|
var addrs []oneAddress
|
|
for i := 0; i != size; i++ {
|
|
addrs = append(addrs, makeOneAddress(i))
|
|
}
|
|
return addrs
|
|
}
|
|
|
|
func makeTestNormalIndexes(addrNum int) []normalTxnIndex {
|
|
num := addrNum * (addrNum + 1) / 2
|
|
indexes := make([]normalTxnIndex, 0, num)
|
|
for i := 0; i != addrNum; i++ {
|
|
for j := 0; j != i; j++ {
|
|
indexes = append(indexes, normalTxnIndex{
|
|
addr: makeOneAddress(i),
|
|
blockNumber: uint64(j),
|
|
txnIndex: 0,
|
|
txnHash: makeTestTxHash(j),
|
|
})
|
|
}
|
|
}
|
|
return indexes
|
|
}
|
|
|
|
func makeTestStakingIndexes(addrNum int) []stakingTxnIndex {
|
|
num := addrNum * (addrNum + 1) / 2
|
|
indexes := make([]stakingTxnIndex, 0, num)
|
|
for i := 0; i != addrNum; i++ {
|
|
for j := 0; j != i; j++ {
|
|
indexes = append(indexes, stakingTxnIndex{
|
|
addr: makeOneAddress(i),
|
|
blockNumber: uint64(j),
|
|
txnIndex: 0,
|
|
txnHash: makeTestTxHash(j + 999999),
|
|
})
|
|
}
|
|
}
|
|
return indexes
|
|
}
|
|
|