aboutsummaryrefslogtreecommitdiffstats
path: root/merkle_test.go
blob: f3a070e4aec88158c329f344b23d1b811267b513 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
package main

import (
	"bytes"
	"fmt"
	"math/rand"
	"testing"
)

func testMerkle(mtype string) bool {
	m := NewMerkle(mtype, 5, "test.db")
	root := m.Build()
	id := m.Size() / 2
	proof := m.Proof(id)
	v := verify(id, proof)
	if !bytes.Equal(v, root) {
		return false
	}

	id = m.Size()/2 + 1
	proof = m.Proof(id)
	v = verify(id, proof)
	if !bytes.Equal(v, root) {
		return false
	}
	return true
}

func TestMerkle(t *testing.T) {
	tests := []string{"bfs", "post"}
	for _, test := range tests {
		fmt.Println("Testing", test)
		if !testMerkle(test) {
			t.Error(test)
		}
	}
}

func BenchmarkBFSMerkle(b *testing.B) {
	m := NewBFSMerkle(25, "/mnt/data/bfs.db")
	root := make([]byte, hashSize)
	m.Read(root, 0)
	var id int64
	var proof [][]byte
	for i := 0; i < b.N; i++ {
		id = rand.Int63n(m.Size()/2) + m.Size()/2
		proof = m.Proof(id)
		if len(proof) != int(m.height) {
			fmt.Println("error")
		}
	}
}

func BenchmarkPostMerkle(b *testing.B) {
	m := NewPostMerkle(25, "/mnt/data/post.db")
	root := make([]byte, hashSize)
	m.Read(root, 0)
	var id int64
	var proof [][]byte
	for i := 0; i < b.N; i++ {
		id = rand.Int63n(m.Size()/2) + m.Size()/2
		proof = m.Proof(id)
		if len(proof) != int(m.height) {
			fmt.Println("error")
		}
	}
}