Using remote for test cases

This commit is contained in:
obscuren 2014-06-30 13:08:00 +02:00
parent 8151858e70
commit 5a86892ecb
2 changed files with 111 additions and 20 deletions

View File

@ -43,11 +43,11 @@ func NewCache(db Database) *Cache {
return &Cache{db: db, nodes: make(map[string]*Node)} return &Cache{db: db, nodes: make(map[string]*Node)}
} }
func (cache *Cache) Put(v interface{}) interface{} { func (cache *Cache) PutValue(v interface{}, force bool) interface{} {
value := NewValue(v) value := NewValue(v)
enc := value.Encode() enc := value.Encode()
if len(enc) >= 32 { if len(enc) >= 32 || force {
sha := Sha3Bin(enc) sha := Sha3Bin(enc)
cache.nodes[string(sha)] = NewNode(sha, value, true) cache.nodes[string(sha)] = NewNode(sha, value, true)
@ -59,6 +59,10 @@ func (cache *Cache) Put(v interface{}) interface{} {
return v return v
} }
func (cache *Cache) Put(v interface{}) interface{} {
return cache.PutValue(v, false)
}
func (cache *Cache) Get(key []byte) *Value { func (cache *Cache) Get(key []byte) *Value {
// First check if the key is the cache // First check if the key is the cache
if cache.nodes[string(key)] != nil { if cache.nodes[string(key)] != nil {
@ -168,7 +172,12 @@ func (t *Trie) Update(key string, value string) {
k := CompactHexDecode(key) k := CompactHexDecode(key)
t.Root = t.UpdateState(t.Root, k, value) root := t.UpdateState(t.Root, k, value)
if _, ok := root.([]byte); !ok {
t.Root = t.cache.PutValue(root, true)
} else {
t.Root = root
}
} }
func (t *Trie) Get(key string) string { func (t *Trie) Get(key string) string {
@ -527,6 +536,8 @@ func (it *TrieIterator) fetchNode(key []int, node []byte, cb EachCallback) {
} }
func (it *TrieIterator) iterateNode(key []int, currentNode *Value, cb EachCallback) { func (it *TrieIterator) iterateNode(key []int, currentNode *Value, cb EachCallback) {
//fmt.Println("node", currentNode)
if currentNode.Len() == 2 { if currentNode.Len() == 2 {
k := CompactDecode(currentNode.Get(0).Str()) k := CompactDecode(currentNode.Get(0).Str())

View File

@ -1,7 +1,12 @@
package ethutil package ethutil
import ( import (
"bytes"
"encoding/hex"
"encoding/json"
"fmt" "fmt"
"io/ioutil"
"net/http"
"reflect" "reflect"
"testing" "testing"
) )
@ -171,23 +176,98 @@ func TestTriePurge(t *testing.T) {
} }
} }
func TestTrieIt(t *testing.T) { func h(str string) string {
_, trie := New() d, err := hex.DecodeString(str)
if err != nil {
data := [][]string{ panic(err)
{"do", "verb"},
{"ether", "wookiedoo"},
{"horse", "stallion"},
{"shaman", "horse"},
{"doge", "coin"},
{"ether", ""},
{"dog", "puppy"},
{"shaman", ""},
} }
for _, item := range data { return string(d)
trie.Update(item[0], item[1]) }
}
func get(in string) (out string) {
fmt.Printf("root %x", trie.Root) if len(in) > 2 && in[:2] == "0x" {
out = h(in[2:])
} else {
out = in
}
return
}
type Test struct {
Name string
In map[string]string
Root string
}
func CreateTest(name string, data []byte) (Test, error) {
t := Test{Name: name}
err := json.Unmarshal(data, &t)
if err != nil {
return Test{}, fmt.Errorf("%v", err)
}
return t, nil
}
func CreateTests(uri string, cb func(Test)) {
resp, err := http.Get(uri)
if err != nil {
panic(err)
}
defer resp.Body.Close()
data, err := ioutil.ReadAll(resp.Body)
var objmap map[string]*json.RawMessage
err = json.Unmarshal(data, &objmap)
if err != nil {
panic(err)
}
for name, testData := range objmap {
test, err := CreateTest(name, *testData)
if err != nil {
panic(err)
}
cb(test)
}
}
func TestRemote(t *testing.T) {
CreateTests("https://raw.githubusercontent.com/ethereum/tests/develop/trietest.json", func(test Test) {
_, trie := New()
for key, value := range test.In {
trie.Update(get(key), get(value))
}
fmt.Printf("%-15s: %x\n", test.Name, trie.Root)
a := NewValue(h(test.Root)).Bytes()
b := NewValue(trie.Root).Bytes()
if bytes.Compare(a, b) != 0 {
t.Errorf("%-10s: %x %x", test.Name, a, b)
}
})
}
func TestTrieReplay(t *testing.T) {
CreateTests("https://raw.githubusercontent.com/ethereum/tests/develop/trietest.json", func(test Test) {
_, trie := New()
for key, value := range test.In {
trie.Update(get(key), get(value))
}
_, trie2 := New()
trie.NewIterator().Each(func(key string, v *Value) {
trie2.Update(key, string(v.Str()))
})
a := NewValue(trie.Root).Bytes()
b := NewValue(trie2.Root).Bytes()
if bytes.Compare(a, b) != 0 {
t.Errorf("root %x %x\n", trie.Root, trie2.Root)
}
})
} }