Update state tests to use gocheck

pull/182/head
Taylor Gerring 10 years ago
parent 0a3a148ed4
commit 8f3a03c0cc
  1. 45
      state/state_test.go

@ -1,6 +1,7 @@
package state
import (
. "gopkg.in/check.v1"
"testing"
"github.com/ethereum/go-ethereum/ethdb"
@ -8,29 +9,41 @@ import (
"github.com/ethereum/go-ethereum/trie"
)
var ZeroHash256 = make([]byte, 32)
func Test(t *testing.T) { TestingT(t) }
func TestSnapshot(t *testing.T) {
type StateSuite struct {
state *State
}
var _ = Suite(&StateSuite{})
const expectedasbytes = "Expected % x Got % x"
// var ZeroHash256 = make([]byte, 32)
func (s *StateSuite) SetUpTest(c *C) {
db, _ := ethdb.NewMemDatabase()
ethutil.ReadConfig(".ethtest", "/tmp/ethtest", "")
ethutil.Config.Db = db
s.state = New(trie.New(db, ""))
}
state := New(trie.New(db, ""))
stateObject := state.GetOrNewStateObject([]byte("aa"))
stateObject.SetStorage(ethutil.Big("0"), ethutil.NewValue(42))
func (s *StateSuite) TestSnapshot(c *C) {
data1 := ethutil.NewValue(42)
data2 := ethutil.NewValue(43)
storageaddr := ethutil.Big("0")
stateobjaddr := []byte("aa")
snapshot := state.Copy()
stateObject := s.state.GetOrNewStateObject(stateobjaddr)
stateObject.SetStorage(storageaddr, data1)
snapshot := s.state.Copy()
stateObject = state.GetStateObject([]byte("aa"))
stateObject.SetStorage(ethutil.Big("0"), ethutil.NewValue(43))
stateObject = s.state.GetStateObject(stateobjaddr)
stateObject.SetStorage(storageaddr, data2)
s.state.Set(snapshot)
state.Set(snapshot)
stateObject = s.state.GetStateObject(stateobjaddr)
res := stateObject.GetStorage(storageaddr)
stateObject = state.GetStateObject([]byte("aa"))
res := stateObject.GetStorage(ethutil.Big("0"))
if !res.Cmp(ethutil.NewValue(42)) {
t.Error("Expected storage 0 to be 42", res)
}
c.Assert(data1, DeepEquals, res, Commentf(expectedasbytes, data1, res))
}

Loading…
Cancel
Save