diff options
author | Jeffrey Wilcke <jeffrey@ethereum.org> | 2015-02-20 20:00:10 +0800 |
---|---|---|
committer | Jeffrey Wilcke <jeffrey@ethereum.org> | 2015-02-20 20:00:10 +0800 |
commit | 63031f571a3ad4bfd7ef60577a588d63ec18b0b4 (patch) | |
tree | d78aea141c4a67198e075ab40a30278d2ec30913 /state | |
parent | 982f73fa6d6f12874729faacd0db14fc78d518dd (diff) | |
parent | 3b12a9293c35fd336122d9387ab6bc9b67d2803a (diff) | |
download | dexon-63031f571a3ad4bfd7ef60577a588d63ec18b0b4.tar dexon-63031f571a3ad4bfd7ef60577a588d63ec18b0b4.tar.gz dexon-63031f571a3ad4bfd7ef60577a588d63ec18b0b4.tar.bz2 dexon-63031f571a3ad4bfd7ef60577a588d63ec18b0b4.tar.lz dexon-63031f571a3ad4bfd7ef60577a588d63ec18b0b4.tar.xz dexon-63031f571a3ad4bfd7ef60577a588d63ec18b0b4.tar.zst dexon-63031f571a3ad4bfd7ef60577a588d63ec18b0b4.zip |
Merge pull request #355 from fjl/test-fixes
Fix failing tests and speed up Travis builds
Diffstat (limited to 'state')
-rw-r--r-- | state/state_test.go | 43 |
1 files changed, 38 insertions, 5 deletions
diff --git a/state/state_test.go b/state/state_test.go index 7c54cedc0..ee1cf9286 100644 --- a/state/state_test.go +++ b/state/state_test.go @@ -1,6 +1,8 @@ package state import ( + "math/big" + checker "gopkg.in/check.v1" "github.com/ethereum/go-ethereum/ethdb" @@ -16,11 +18,42 @@ var _ = checker.Suite(&StateSuite{}) // var ZeroHash256 = make([]byte, 32) func (s *StateSuite) TestDump(c *checker.C) { - key := []byte{0x01} - value := []byte("foo") - s.state.trie.Update(key, value) - dump := s.state.Dump() - c.Assert(dump, checker.NotNil) + // generate a few entries + obj1 := s.state.GetOrNewStateObject([]byte{0x01}) + obj1.AddBalance(big.NewInt(22)) + obj2 := s.state.GetOrNewStateObject([]byte{0x01, 0x02}) + obj2.SetCode([]byte{3, 3, 3, 3, 3, 3, 3}) + obj3 := s.state.GetOrNewStateObject([]byte{0x02}) + obj3.SetBalance(big.NewInt(44)) + + // write some of them to the trie + s.state.UpdateStateObject(obj1) + s.state.UpdateStateObject(obj2) + + // check that dump contains the state objects that are in trie + got := string(s.state.Dump()) + want := `{ + "root": "4e3a59299745ba6752247c8b91d0f716dac9ec235861c91f5ac1894a361d87ba", + "accounts": { + "0000000000000000000000000000000000000001": { + "balance": "22", + "nonce": 0, + "root": "56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421", + "codeHash": "c5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470", + "storage": {} + }, + "0000000000000000000000000000000000000102": { + "balance": "0", + "nonce": 0, + "root": "56e81f171bcc55a6ff8345e692c0f86e5b48e01b996cadc001622fb5e363b421", + "codeHash": "87874902497a5bb968da31a2998d8f22e949d1ef6214bcdedd8bae24cca4b9e3", + "storage": {} + } + } +}` + if got != want { + c.Errorf("dump mismatch:\ngot: %s\nwant: %s\n", got, want) + } } func (s *StateSuite) SetUpTest(c *checker.C) { |