github.com/theQRL/go-zond@v0.1.1/trie/stacktrie_test.go (about) 1 // Copyright 2020 The go-ethereum Authors 2 // This file is part of the go-ethereum library. 3 // 4 // The go-ethereum library is free software: you can redistribute it and/or modify 5 // it under the terms of the GNU Lesser General Public License as published by 6 // the Free Software Foundation, either version 3 of the License, or 7 // (at your option) any later version. 8 // 9 // The go-ethereum library is distributed in the hope that it will be useful, 10 // but WITHOUT ANY WARRANTY; without even the implied warranty of 11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 // GNU Lesser General Public License for more details. 13 // 14 // You should have received a copy of the GNU Lesser General Public License 15 // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>. 16 17 package trie 18 19 import ( 20 "bytes" 21 "math/big" 22 "testing" 23 24 "github.com/theQRL/go-zond/common" 25 "github.com/theQRL/go-zond/core/rawdb" 26 "github.com/theQRL/go-zond/crypto" 27 ) 28 29 func TestStackTrieInsertAndHash(t *testing.T) { 30 type KeyValueHash struct { 31 K string // Hex string for key. 32 V string // Value, directly converted to bytes. 33 H string // Expected root hash after insert of (K, V) to an existing trie. 34 } 35 tests := [][]KeyValueHash{ 36 { // {0:0, 7:0, f:0} 37 {"00", "v_______________________0___0", "5cb26357b95bb9af08475be00243ceb68ade0b66b5cd816b0c18a18c612d2d21"}, 38 {"70", "v_______________________0___1", "8ff64309574f7a437a7ad1628e690eb7663cfde10676f8a904a8c8291dbc1603"}, 39 {"f0", "v_______________________0___2", "9e3a01bd8d43efb8e9d4b5506648150b8e3ed1caea596f84ee28e01a72635470"}, 40 }, 41 { // {1:0cc, e:{1:fc, e:fc}} 42 {"10cc", "v_______________________1___0", "233e9b257843f3dfdb1cce6676cdaf9e595ac96ee1b55031434d852bc7ac9185"}, 43 {"e1fc", "v_______________________1___1", "39c5e908ae83d0c78520c7c7bda0b3782daf594700e44546e93def8f049cca95"}, 44 {"eefc", "v_______________________1___2", "d789567559fd76fe5b7d9cc42f3750f942502ac1c7f2a466e2f690ec4b6c2a7c"}, 45 }, 46 { // {b:{a:ac, b:ac}, d:acc} 47 {"baac", "v_______________________2___0", "8be1c86ba7ec4c61e14c1a9b75055e0464c2633ae66a055a24e75450156a5d42"}, 48 {"bbac", "v_______________________2___1", "8495159b9895a7d88d973171d737c0aace6fe6ac02a4769fff1bc43bcccce4cc"}, 49 {"dacc", "v_______________________2___2", "9bcfc5b220a27328deb9dc6ee2e3d46c9ebc9c69e78acda1fa2c7040602c63ca"}, 50 }, 51 { // {0:0cccc, 2:456{0:0, 2:2} 52 {"00cccc", "v_______________________3___0", "e57dc2785b99ce9205080cb41b32ebea7ac3e158952b44c87d186e6d190a6530"}, 53 {"245600", "v_______________________3___1", "0335354adbd360a45c1871a842452287721b64b4234dfe08760b243523c998db"}, 54 {"245622", "v_______________________3___2", "9e6832db0dca2b5cf81c0e0727bfde6afc39d5de33e5720bccacc183c162104e"}, 55 }, 56 { // {1:4567{1:1c, 3:3c}, 3:0cccccc} 57 {"1456711c", "v_______________________4___0", "f2389e78d98fed99f3e63d6d1623c1d4d9e8c91cb1d585de81fbc7c0e60d3529"}, 58 {"1456733c", "v_______________________4___1", "101189b3fab852be97a0120c03d95eefcf984d3ed639f2328527de6def55a9c0"}, 59 {"30cccccc", "v_______________________4___2", "3780ce111f98d15751dfde1eb21080efc7d3914b429e5c84c64db637c55405b3"}, 60 }, 61 { // 8800{1:f, 2:e, 3:d} 62 {"88001f", "v_______________________5___0", "e817db50d84f341d443c6f6593cafda093fc85e773a762421d47daa6ac993bd5"}, 63 {"88002e", "v_______________________5___1", "d6e3e6047bdc110edd296a4d63c030aec451bee9d8075bc5a198eee8cda34f68"}, 64 {"88003d", "v_______________________5___2", "b6bdf8298c703342188e5f7f84921a402042d0e5fb059969dd53a6b6b1fb989e"}, 65 }, 66 { // 0{1:fc, 2:ec, 4:dc} 67 {"01fc", "v_______________________6___0", "693268f2ca80d32b015f61cd2c4dba5a47a6b52a14c34f8e6945fad684e7a0d5"}, 68 {"02ec", "v_______________________6___1", "e24ddd44469310c2b785a2044618874bf486d2f7822603a9b8dce58d6524d5de"}, 69 {"04dc", "v_______________________6___2", "33fc259629187bbe54b92f82f0cd8083b91a12e41a9456b84fc155321e334db7"}, 70 }, 71 { // f{0:fccc, f:ff{0:f, f:f}} 72 {"f0fccc", "v_______________________7___0", "b0966b5aa469a3e292bc5fcfa6c396ae7a657255eef552ea7e12f996de795b90"}, 73 {"ffff0f", "v_______________________7___1", "3b1ca154ec2a3d96d8d77bddef0abfe40a53a64eb03cecf78da9ec43799fa3d0"}, 74 {"ffffff", "v_______________________7___2", "e75463041f1be8252781be0ace579a44ea4387bf5b2739f4607af676f7719678"}, 75 }, 76 { // ff{0:f{0:f, f:f}, f:fcc} 77 {"ff0f0f", "v_______________________8___0", "0928af9b14718ec8262ab89df430f1e5fbf66fac0fed037aff2b6767ae8c8684"}, 78 {"ff0fff", "v_______________________8___1", "d870f4d3ce26b0bf86912810a1960693630c20a48ba56be0ad04bc3e9ddb01e6"}, 79 {"ffffcc", "v_______________________8___2", "4239f10dd9d9915ecf2e047d6a576bdc1733ed77a30830f1bf29deaf7d8e966f"}, 80 }, 81 { 82 {"123d", "x___________________________0", "fc453d88b6f128a77c448669710497380fa4588abbea9f78f4c20c80daa797d0"}, 83 {"123e", "x___________________________1", "5af48f2d8a9a015c1ff7fa8b8c7f6b676233bd320e8fb57fd7933622badd2cec"}, 84 {"123f", "x___________________________2", "1164d7299964e74ac40d761f9189b2a3987fae959800d0f7e29d3aaf3eae9e15"}, 85 }, 86 { 87 {"123d", "x___________________________0", "fc453d88b6f128a77c448669710497380fa4588abbea9f78f4c20c80daa797d0"}, 88 {"123e", "x___________________________1", "5af48f2d8a9a015c1ff7fa8b8c7f6b676233bd320e8fb57fd7933622badd2cec"}, 89 {"124a", "x___________________________2", "661a96a669869d76b7231380da0649d013301425fbea9d5c5fae6405aa31cfce"}, 90 }, 91 { 92 {"123d", "x___________________________0", "fc453d88b6f128a77c448669710497380fa4588abbea9f78f4c20c80daa797d0"}, 93 {"123e", "x___________________________1", "5af48f2d8a9a015c1ff7fa8b8c7f6b676233bd320e8fb57fd7933622badd2cec"}, 94 {"13aa", "x___________________________2", "6590120e1fd3ffd1a90e8de5bb10750b61079bb0776cca4414dd79a24e4d4356"}, 95 }, 96 { 97 {"123d", "x___________________________0", "fc453d88b6f128a77c448669710497380fa4588abbea9f78f4c20c80daa797d0"}, 98 {"123e", "x___________________________1", "5af48f2d8a9a015c1ff7fa8b8c7f6b676233bd320e8fb57fd7933622badd2cec"}, 99 {"2aaa", "x___________________________2", "f869b40e0c55eace1918332ef91563616fbf0755e2b946119679f7ef8e44b514"}, 100 }, 101 { 102 {"1234da", "x___________________________0", "1c4b4462e9f56a80ca0f5d77c0d632c41b0102290930343cf1791e971a045a79"}, 103 {"1234ea", "x___________________________1", "2f502917f3ba7d328c21c8b45ee0f160652e68450332c166d4ad02d1afe31862"}, 104 {"1234fa", "x___________________________2", "4f4e368ab367090d5bc3dbf25f7729f8bd60df84de309b4633a6b69ab66142c0"}, 105 }, 106 { 107 {"1234da", "x___________________________0", "1c4b4462e9f56a80ca0f5d77c0d632c41b0102290930343cf1791e971a045a79"}, 108 {"1234ea", "x___________________________1", "2f502917f3ba7d328c21c8b45ee0f160652e68450332c166d4ad02d1afe31862"}, 109 {"1235aa", "x___________________________2", "21840121d11a91ac8bbad9a5d06af902a5c8d56a47b85600ba813814b7bfcb9b"}, 110 }, 111 { 112 {"1234da", "x___________________________0", "1c4b4462e9f56a80ca0f5d77c0d632c41b0102290930343cf1791e971a045a79"}, 113 {"1234ea", "x___________________________1", "2f502917f3ba7d328c21c8b45ee0f160652e68450332c166d4ad02d1afe31862"}, 114 {"124aaa", "x___________________________2", "ea4040ddf6ae3fbd1524bdec19c0ab1581015996262006632027fa5cf21e441e"}, 115 }, 116 { 117 {"1234da", "x___________________________0", "1c4b4462e9f56a80ca0f5d77c0d632c41b0102290930343cf1791e971a045a79"}, 118 {"1234ea", "x___________________________1", "2f502917f3ba7d328c21c8b45ee0f160652e68450332c166d4ad02d1afe31862"}, 119 {"13aaaa", "x___________________________2", "e4beb66c67e44f2dd8ba36036e45a44ff68f8d52942472b1911a45f886a34507"}, 120 }, 121 { 122 {"1234da", "x___________________________0", "1c4b4462e9f56a80ca0f5d77c0d632c41b0102290930343cf1791e971a045a79"}, 123 {"1234ea", "x___________________________1", "2f502917f3ba7d328c21c8b45ee0f160652e68450332c166d4ad02d1afe31862"}, 124 {"2aaaaa", "x___________________________2", "5f5989b820ff5d76b7d49e77bb64f26602294f6c42a1a3becc669cd9e0dc8ec9"}, 125 }, 126 { 127 {"000000", "x___________________________0", "3b32b7af0bddc7940e7364ee18b5a59702c1825e469452c8483b9c4e0218b55a"}, 128 {"1234da", "x___________________________1", "3ab152a1285dca31945566f872c1cc2f17a770440eda32aeee46a5e91033dde2"}, 129 {"1234ea", "x___________________________2", "0cccc87f96ddef55563c1b3be3c64fff6a644333c3d9cd99852cb53b6412b9b8"}, 130 {"1234fa", "x___________________________3", "65bb3aafea8121111d693ffe34881c14d27b128fd113fa120961f251fe28428d"}, 131 }, 132 { 133 {"000000", "x___________________________0", "3b32b7af0bddc7940e7364ee18b5a59702c1825e469452c8483b9c4e0218b55a"}, 134 {"1234da", "x___________________________1", "3ab152a1285dca31945566f872c1cc2f17a770440eda32aeee46a5e91033dde2"}, 135 {"1234ea", "x___________________________2", "0cccc87f96ddef55563c1b3be3c64fff6a644333c3d9cd99852cb53b6412b9b8"}, 136 {"1235aa", "x___________________________3", "f670e4d2547c533c5f21e0045442e2ecb733f347ad6d29ef36e0f5ba31bb11a8"}, 137 }, 138 { 139 {"000000", "x___________________________0", "3b32b7af0bddc7940e7364ee18b5a59702c1825e469452c8483b9c4e0218b55a"}, 140 {"1234da", "x___________________________1", "3ab152a1285dca31945566f872c1cc2f17a770440eda32aeee46a5e91033dde2"}, 141 {"1234ea", "x___________________________2", "0cccc87f96ddef55563c1b3be3c64fff6a644333c3d9cd99852cb53b6412b9b8"}, 142 {"124aaa", "x___________________________3", "c17464123050a9a6f29b5574bb2f92f6d305c1794976b475b7fb0316b6335598"}, 143 }, 144 { 145 {"000000", "x___________________________0", "3b32b7af0bddc7940e7364ee18b5a59702c1825e469452c8483b9c4e0218b55a"}, 146 {"1234da", "x___________________________1", "3ab152a1285dca31945566f872c1cc2f17a770440eda32aeee46a5e91033dde2"}, 147 {"1234ea", "x___________________________2", "0cccc87f96ddef55563c1b3be3c64fff6a644333c3d9cd99852cb53b6412b9b8"}, 148 {"13aaaa", "x___________________________3", "aa8301be8cb52ea5cd249f5feb79fb4315ee8de2140c604033f4b3fff78f0105"}, 149 }, 150 { 151 {"0000", "x___________________________0", "cb8c09ad07ae882136f602b3f21f8733a9f5a78f1d2525a8d24d1c13258000b2"}, 152 {"123d", "x___________________________1", "8f09663deb02f08958136410dc48565e077f76bb6c9d8c84d35fc8913a657d31"}, 153 {"123e", "x___________________________2", "0d230561e398c579e09a9f7b69ceaf7d3970f5a436fdb28b68b7a37c5bdd6b80"}, 154 {"123f", "x___________________________3", "80f7bad1893ca57e3443bb3305a517723a74d3ba831bcaca22a170645eb7aafb"}, 155 }, 156 { 157 {"0000", "x___________________________0", "cb8c09ad07ae882136f602b3f21f8733a9f5a78f1d2525a8d24d1c13258000b2"}, 158 {"123d", "x___________________________1", "8f09663deb02f08958136410dc48565e077f76bb6c9d8c84d35fc8913a657d31"}, 159 {"123e", "x___________________________2", "0d230561e398c579e09a9f7b69ceaf7d3970f5a436fdb28b68b7a37c5bdd6b80"}, 160 {"124a", "x___________________________3", "383bc1bb4f019e6bc4da3751509ea709b58dd1ac46081670834bae072f3e9557"}, 161 }, 162 { 163 {"0000", "x___________________________0", "cb8c09ad07ae882136f602b3f21f8733a9f5a78f1d2525a8d24d1c13258000b2"}, 164 {"123d", "x___________________________1", "8f09663deb02f08958136410dc48565e077f76bb6c9d8c84d35fc8913a657d31"}, 165 {"123e", "x___________________________2", "0d230561e398c579e09a9f7b69ceaf7d3970f5a436fdb28b68b7a37c5bdd6b80"}, 166 {"13aa", "x___________________________3", "ff0dc70ce2e5db90ee42a4c2ad12139596b890e90eb4e16526ab38fa465b35cf"}, 167 }, 168 { // branch node with short values 169 {"01", "a", "b48605025f5f4b129d40a420e721aa7d504487f015fce85b96e52126365ef7dc"}, 170 {"80", "b", "2dc6b680daf74db067cb7aeaad73265ded93d96fce190fcbf64f498d475672ab"}, 171 {"ee", "c", "017dc705a54ac5328dd263fa1bae68d655310fb3e3f7b7bc57e9a43ddf99c4bf"}, 172 {"ff", "d", "bd5a3584d271d459bd4eb95247b2fc88656b3671b60c1125ffe7bc0b689470d0"}, 173 }, 174 { // ext node with short branch node, then becoming long 175 {"a0", "a", "a83e028cb1e4365935661a9fd36a5c65c30b9ab416eaa877424146ca2a69d088"}, 176 {"a1", "b", "f586a4639b07b01798ca65e05c253b75d51135ebfbf6f8d6e87c0435089e65f0"}, 177 {"a2", "c", "63e297c295c008e09a8d531e18d57f270b6bc403e23179b915429db948cd62e3"}, 178 {"a3", "d", "94a7b721535578e9381f1f4e4b6ec29f8bdc5f0458a30320684c562f5d47b4b5"}, 179 {"a4", "e", "4b7e66d1c81965cdbe8fab8295ef56bc57fefdc5733d4782d2f8baf630f083c6"}, 180 {"a5", "f", "2997e7b502198ce1783b5277faacf52b25844fb55a99b63e88bdbbafac573106"}, 181 {"a6", "g", "bee629dd27a40772b2e1a67ec6db270d26acdf8d3b674dfae27866ad6ae1f48b"}, 182 }, 183 { // branch node with short values, then long ones 184 {"a001", "v1", "b9cc982d995392b51e6787f1915f0b88efd4ad8b30f138da0a3e2242f2323e35"}, 185 {"b002", "v2", "a7b474bc77ef5097096fa0ee6298fdae8928c0bc3724e7311cd0fa9ed1942fc7"}, 186 {"c003", "v___________________________3", "dceb5bb7c92b0e348df988a8d9fc36b101397e38ebd405df55ba6ee5f14a264a"}, 187 {"d004", "v___________________________4", "36e60ecb86b9626165e1c6543c42ecbe4d83bca58e8e1124746961511fce362a"}, 188 }, 189 { // ext node to branch node with short values, then long ones 190 {"8002", "v1", "3258fcb3e9e7d7234ecd3b8d4743999e4ab3a21592565e0a5ca64c141e8620d9"}, 191 {"8004", "v2", "b6cb95b7024a83c17624a3c9bed09b4b5e8ed426f49f54b8ad13c39028b1e75a"}, 192 {"8008", "v___________________________3", "c769d82963abe6f0900bf69754738eeb2f84559777cfa87a44f54e1aab417871"}, 193 {"800d", "v___________________________4", "1cad1fdaab1a6fa95d7b780fd680030e423eb76669971368ba04797a8d9cdfc9"}, 194 }, 195 { // ext node with a child of size 31 (Y) and branch node with a child of size 31 (X) 196 {"000001", "ZZZZZZZZZ", "cef154b87c03c563408520ff9b26923c360cbc3ddb590c079bedeeb25a8c9c77"}, 197 {"000002", "Y", "2130735e600f612f6e657a32bd7be64ddcaec6512c5694844b19de713922895d"}, 198 {"000003", "XXXXXXXXXXXXXXXXXXXXXXXXXXXX", "962c0fffdeef7612a4f7bff1950d67e3e81c878e48b9ae45b3b374253b050bd8"}, 199 }, 200 } 201 st := NewStackTrie(nil) 202 for i, test := range tests { 203 // The StackTrie does not allow Insert(), Hash(), Insert(), ... 204 // so we will create new trie for every sequence length of inserts. 205 for l := 1; l <= len(test); l++ { 206 st.Reset() 207 for j := 0; j < l; j++ { 208 kv := &test[j] 209 if err := st.Update(common.FromHex(kv.K), []byte(kv.V)); err != nil { 210 t.Fatal(err) 211 } 212 } 213 expected := common.HexToHash(test[l-1].H) 214 if h := st.Hash(); h != expected { 215 t.Errorf("%d(%d): root hash mismatch: %x, expected %x", i, l, h, expected) 216 } 217 } 218 } 219 } 220 221 func TestSizeBug(t *testing.T) { 222 st := NewStackTrie(nil) 223 nt := NewEmpty(NewDatabase(rawdb.NewMemoryDatabase(), nil)) 224 225 leaf := common.FromHex("290decd9548b62a8d60345a988386fc84ba6bc95484008f6362f93160ef3e563") 226 value := common.FromHex("94cf40d0d2b44f2b66e07cace1372ca42b73cf21a3") 227 228 nt.Update(leaf, value) 229 st.Update(leaf, value) 230 231 if nt.Hash() != st.Hash() { 232 t.Fatalf("error %x != %x", st.Hash(), nt.Hash()) 233 } 234 } 235 236 func TestEmptyBug(t *testing.T) { 237 st := NewStackTrie(nil) 238 nt := NewEmpty(NewDatabase(rawdb.NewMemoryDatabase(), nil)) 239 240 //leaf := common.FromHex("290decd9548b62a8d60345a988386fc84ba6bc95484008f6362f93160ef3e563") 241 //value := common.FromHex("94cf40d0d2b44f2b66e07cace1372ca42b73cf21a3") 242 kvs := []struct { 243 K string 244 V string 245 }{ 246 {K: "405787fa12a823e0f2b7631cc41b3ba8828b3321ca811111fa75cd3aa3bb5ace", V: "9496f4ec2bf9dab484cac6be589e8417d84781be08"}, 247 {K: "40edb63a35fcf86c08022722aa3287cdd36440d671b4918131b2514795fefa9c", V: "01"}, 248 {K: "b10e2d527612073b26eecdfd717e6a320cf44b4afac2b0732d9fcbe2b7fa0cf6", V: "947a30f7736e48d6599356464ba4c150d8da0302ff"}, 249 {K: "c2575a0e9e593c00f959f8c92f12db2869c3395a3b0502d05e2516446f71f85b", V: "02"}, 250 } 251 252 for _, kv := range kvs { 253 nt.Update(common.FromHex(kv.K), common.FromHex(kv.V)) 254 st.Update(common.FromHex(kv.K), common.FromHex(kv.V)) 255 } 256 257 if nt.Hash() != st.Hash() { 258 t.Fatalf("error %x != %x", st.Hash(), nt.Hash()) 259 } 260 } 261 262 func TestValLength56(t *testing.T) { 263 st := NewStackTrie(nil) 264 nt := NewEmpty(NewDatabase(rawdb.NewMemoryDatabase(), nil)) 265 266 //leaf := common.FromHex("290decd9548b62a8d60345a988386fc84ba6bc95484008f6362f93160ef3e563") 267 //value := common.FromHex("94cf40d0d2b44f2b66e07cace1372ca42b73cf21a3") 268 kvs := []struct { 269 K string 270 V string 271 }{ 272 {K: "405787fa12a823e0f2b7631cc41b3ba8828b3321ca811111fa75cd3aa3bb5ace", V: "1111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111"}, 273 } 274 275 for _, kv := range kvs { 276 nt.Update(common.FromHex(kv.K), common.FromHex(kv.V)) 277 st.Update(common.FromHex(kv.K), common.FromHex(kv.V)) 278 } 279 280 if nt.Hash() != st.Hash() { 281 t.Fatalf("error %x != %x", st.Hash(), nt.Hash()) 282 } 283 } 284 285 // TestUpdateSmallNodes tests a case where the leaves are small (both key and value), 286 // which causes a lot of node-within-node. This case was found via fuzzing. 287 func TestUpdateSmallNodes(t *testing.T) { 288 st := NewStackTrie(nil) 289 nt := NewEmpty(NewDatabase(rawdb.NewMemoryDatabase(), nil)) 290 kvs := []struct { 291 K string 292 V string 293 }{ 294 {"63303030", "3041"}, // stacktrie.Update 295 {"65", "3000"}, // stacktrie.Update 296 } 297 for _, kv := range kvs { 298 nt.Update(common.FromHex(kv.K), common.FromHex(kv.V)) 299 st.Update(common.FromHex(kv.K), common.FromHex(kv.V)) 300 } 301 if nt.Hash() != st.Hash() { 302 t.Fatalf("error %x != %x", st.Hash(), nt.Hash()) 303 } 304 } 305 306 // TestUpdateVariableKeys contains a case which stacktrie fails: when keys of different 307 // sizes are used, and the second one has the same prefix as the first, then the 308 // stacktrie fails, since it's unable to 'expand' on an already added leaf. 309 // For all practical purposes, this is fine, since keys are fixed-size length 310 // in account and storage tries. 311 // 312 // The test is marked as 'skipped', and exists just to have the behaviour documented. 313 // This case was found via fuzzing. 314 func TestUpdateVariableKeys(t *testing.T) { 315 t.SkipNow() 316 st := NewStackTrie(nil) 317 nt := NewEmpty(NewDatabase(rawdb.NewMemoryDatabase(), nil)) 318 kvs := []struct { 319 K string 320 V string 321 }{ 322 {"0x33303534636532393561313031676174", "303030"}, 323 {"0x3330353463653239356131303167617430", "313131"}, 324 } 325 for _, kv := range kvs { 326 nt.Update(common.FromHex(kv.K), common.FromHex(kv.V)) 327 st.Update(common.FromHex(kv.K), common.FromHex(kv.V)) 328 } 329 if nt.Hash() != st.Hash() { 330 t.Fatalf("error %x != %x", st.Hash(), nt.Hash()) 331 } 332 } 333 334 // TestStacktrieNotModifyValues checks that inserting blobs of data into the 335 // stacktrie does not mutate the blobs 336 func TestStacktrieNotModifyValues(t *testing.T) { 337 st := NewStackTrie(nil) 338 { // Test a very small trie 339 // Give it the value as a slice with large backing alloc, 340 // so if the stacktrie tries to append, it won't have to realloc 341 value := make([]byte, 1, 100) 342 value[0] = 0x2 343 want := common.CopyBytes(value) 344 st.Update([]byte{0x01}, value) 345 st.Hash() 346 if have := value; !bytes.Equal(have, want) { 347 t.Fatalf("tiny trie: have %#x want %#x", have, want) 348 } 349 st = NewStackTrie(nil) 350 } 351 // Test with a larger trie 352 keyB := big.NewInt(1) 353 keyDelta := big.NewInt(1) 354 var vals [][]byte 355 getValue := func(i int) []byte { 356 if i%2 == 0 { // large 357 return crypto.Keccak256(big.NewInt(int64(i)).Bytes()) 358 } else { //small 359 return big.NewInt(int64(i)).Bytes() 360 } 361 } 362 for i := 0; i < 1000; i++ { 363 key := common.BigToHash(keyB) 364 value := getValue(i) 365 st.Update(key.Bytes(), value) 366 vals = append(vals, value) 367 keyB = keyB.Add(keyB, keyDelta) 368 keyDelta.Add(keyDelta, common.Big1) 369 } 370 st.Hash() 371 for i := 0; i < 1000; i++ { 372 want := getValue(i) 373 374 have := vals[i] 375 if !bytes.Equal(have, want) { 376 t.Fatalf("item %d, have %#x want %#x", i, have, want) 377 } 378 } 379 } 380 381 // TestStacktrieSerialization tests that the stacktrie works well if we 382 // serialize/unserialize it a lot 383 func TestStacktrieSerialization(t *testing.T) { 384 var ( 385 st = NewStackTrie(nil) 386 nt = NewEmpty(NewDatabase(rawdb.NewMemoryDatabase(), nil)) 387 keyB = big.NewInt(1) 388 keyDelta = big.NewInt(1) 389 vals [][]byte 390 keys [][]byte 391 ) 392 getValue := func(i int) []byte { 393 if i%2 == 0 { // large 394 return crypto.Keccak256(big.NewInt(int64(i)).Bytes()) 395 } else { //small 396 return big.NewInt(int64(i)).Bytes() 397 } 398 } 399 for i := 0; i < 10; i++ { 400 vals = append(vals, getValue(i)) 401 keys = append(keys, common.BigToHash(keyB).Bytes()) 402 keyB = keyB.Add(keyB, keyDelta) 403 keyDelta.Add(keyDelta, common.Big1) 404 } 405 for i, k := range keys { 406 nt.Update(k, common.CopyBytes(vals[i])) 407 } 408 409 for i, k := range keys { 410 blob, err := st.MarshalBinary() 411 if err != nil { 412 t.Fatal(err) 413 } 414 newSt, err := NewFromBinary(blob, nil) 415 if err != nil { 416 t.Fatal(err) 417 } 418 st = newSt 419 st.Update(k, common.CopyBytes(vals[i])) 420 } 421 if have, want := st.Hash(), nt.Hash(); have != want { 422 t.Fatalf("have %#x want %#x", have, want) 423 } 424 }