diff options
author | Taylor Gerring <taylor.gerring@gmail.com> | 2014-11-12 03:37:18 +0800 |
---|---|---|
committer | Taylor Gerring <taylor.gerring@gmail.com> | 2014-11-12 03:37:18 +0800 |
commit | 1d866b5e579e06d00ab63cf8899a47e08b95b232 (patch) | |
tree | 022955dec7ef6527a6f30d3adb82ce4671e111a2 /state | |
parent | f59a3b67f69b26f969084e0de165435e80bd8e12 (diff) | |
parent | 5c5df21e3d8768481c2bc1b6e9475099590e10be (diff) | |
download | go-tangerine-1d866b5e579e06d00ab63cf8899a47e08b95b232.tar go-tangerine-1d866b5e579e06d00ab63cf8899a47e08b95b232.tar.gz go-tangerine-1d866b5e579e06d00ab63cf8899a47e08b95b232.tar.bz2 go-tangerine-1d866b5e579e06d00ab63cf8899a47e08b95b232.tar.lz go-tangerine-1d866b5e579e06d00ab63cf8899a47e08b95b232.tar.xz go-tangerine-1d866b5e579e06d00ab63cf8899a47e08b95b232.tar.zst go-tangerine-1d866b5e579e06d00ab63cf8899a47e08b95b232.zip |
Merge pull request #1 from tgerring/tests
Initial tests based on check framework
Diffstat (limited to 'state')
-rw-r--r-- | state/state_test.go | 59 |
1 files changed, 40 insertions, 19 deletions
diff --git a/state/state_test.go b/state/state_test.go index 737815e90..9dd965e95 100644 --- a/state/state_test.go +++ b/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,49 @@ import ( "github.com/ethereum/go-ethereum/trie" ) -var ZeroHash256 = make([]byte, 32) +func Test(t *testing.T) { TestingT(t) } -func TestSnapshot(t *testing.T) { - db, _ := ethdb.NewMemDatabase() - ethutil.ReadConfig(".ethtest", "/tmp/ethtest", "") - ethutil.Config.Db = db - - state := New(trie.New(db, "")) - - stateObject := state.GetOrNewStateObject([]byte("aa")) +type StateSuite struct { + state *State +} - stateObject.SetStorage(ethutil.Big("0"), ethutil.NewValue(42)) +var _ = Suite(&StateSuite{}) - snapshot := state.Copy() +const expectedasbytes = "Expected % x Got % x" - stateObject = state.GetStateObject([]byte("aa")) - stateObject.SetStorage(ethutil.Big("0"), ethutil.NewValue(43)) +// var ZeroHash256 = make([]byte, 32) - state.Set(snapshot) +func (s *StateSuite) SetUpTest(c *C) { + db, _ := ethdb.NewMemDatabase() + ethutil.ReadConfig(".ethtest", "/tmp/ethtest", "") + ethutil.Config.Db = db + s.state = New(trie.New(db, "")) +} - 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) - } +func (s *StateSuite) TestSnapshot(c *C) { + stateobjaddr := []byte("aa") + storageaddr := ethutil.Big("0") + data1 := ethutil.NewValue(42) + data2 := ethutil.NewValue(43) + + // get state object + stateObject := s.state.GetOrNewStateObject(stateobjaddr) + // set inital state object value + stateObject.SetStorage(storageaddr, data1) + // get snapshot of current state + snapshot := s.state.Copy() + + // get state object. is this strictly necessary? + stateObject = s.state.GetStateObject(stateobjaddr) + // set new state object value + stateObject.SetStorage(storageaddr, data2) + // restore snapshot + s.state.Set(snapshot) + + // get state object + stateObject = s.state.GetStateObject(stateobjaddr) + // get state storage value + res := stateObject.GetStorage(storageaddr) + + c.Assert(data1, DeepEquals, res, Commentf(expectedasbytes, data1, res)) } |