forked from cerc-io/ipld-eth-server
8111f4ec5e
- Tool to facilitate parsing diffs from Geth patch that emits hashed versions of storage keys
98 lines
4.3 KiB
Go
98 lines
4.3 KiB
Go
package storage_test
|
|
|
|
import (
|
|
"github.com/ethereum/go-ethereum/common"
|
|
. "github.com/onsi/ginkgo"
|
|
. "github.com/onsi/gomega"
|
|
"github.com/vulcanize/vulcanizedb/libraries/shared/storage"
|
|
"github.com/vulcanize/vulcanizedb/libraries/shared/storage/utils"
|
|
)
|
|
|
|
var _ = Describe("Mappings", func() {
|
|
Describe("AddHashedKeys", func() {
|
|
It("returns a copy of the map with an additional slot for the hashed version of every key", func() {
|
|
fakeMap := map[common.Hash]utils.StorageValueMetadata{}
|
|
fakeStorageKey := common.HexToHash("72c72de6b203d67cb6cd54fc93300109fcc6fd6eac88e390271a3d548794d800")
|
|
var fakeMappingKey utils.Key = "fakeKey"
|
|
fakeMetadata := utils.StorageValueMetadata{
|
|
Name: "fakeName",
|
|
Keys: map[utils.Key]string{fakeMappingKey: "fakeValue"},
|
|
Type: utils.Uint48,
|
|
}
|
|
fakeMap[fakeStorageKey] = fakeMetadata
|
|
|
|
result := storage.AddHashedKeys(fakeMap)
|
|
|
|
Expect(len(result)).To(Equal(2))
|
|
expectedHashedStorageKey := common.HexToHash("2165edb4e1c37b99b60fa510d84f939dd35d5cd1d1c8f299d6456ea09df65a76")
|
|
Expect(fakeMap[fakeStorageKey]).To(Equal(fakeMetadata))
|
|
Expect(fakeMap[expectedHashedStorageKey]).To(Equal(fakeMetadata))
|
|
})
|
|
})
|
|
|
|
Describe("GetMapping", func() {
|
|
It("returns the storage key for a mapping when passed the mapping's index on the contract and the desired value's key", func() {
|
|
// ex. solidity:
|
|
// mapping (bytes32 => uint) public amounts
|
|
// to access amounts, pass in the index of the mapping on the contract + the bytes32 key for the uint val being looked up
|
|
indexOfMappingOnContract := storage.IndexZero
|
|
keyForDesiredValueInMapping := "1234567890abcdef"
|
|
|
|
storageKey := storage.GetMapping(indexOfMappingOnContract, keyForDesiredValueInMapping)
|
|
|
|
expectedStorageKey := common.HexToHash("0xee0c1b59a3856bafbfb8730e7694c4badc271eb5f01ce4a8d7a53d8a6499676f")
|
|
Expect(storageKey).To(Equal(expectedStorageKey))
|
|
})
|
|
|
|
It("returns same result if value includes hex prefix", func() {
|
|
indexOfMappingOnContract := storage.IndexZero
|
|
keyForDesiredValueInMapping := "0x1234567890abcdef"
|
|
|
|
storageKey := storage.GetMapping(indexOfMappingOnContract, keyForDesiredValueInMapping)
|
|
|
|
expectedStorageKey := common.HexToHash("0xee0c1b59a3856bafbfb8730e7694c4badc271eb5f01ce4a8d7a53d8a6499676f")
|
|
Expect(storageKey).To(Equal(expectedStorageKey))
|
|
})
|
|
})
|
|
|
|
Describe("GetNestedMapping", func() {
|
|
It("returns the storage key for a nested mapping when passed the mapping's index on the contract and the desired value's keys", func() {
|
|
// ex. solidity:
|
|
// mapping (bytes32 => uint) public amounts
|
|
// mapping (address => mapping (uint => bytes32)) public addressNames
|
|
// to access addressNames, pass in the index of the mapping on the contract + the address and uint keys for the bytes32 val being looked up
|
|
indexOfMappingOnContract := storage.IndexOne
|
|
keyForOuterMapping := "1234567890abcdef"
|
|
keyForInnerMapping := "123"
|
|
|
|
storageKey := storage.GetNestedMapping(indexOfMappingOnContract, keyForOuterMapping, keyForInnerMapping)
|
|
|
|
expectedStorageKey := common.HexToHash("0x82113529f6cd61061d1a6f0de53f2bdd067a1addd3d2b46be50a99abfcdb1661")
|
|
Expect(storageKey).To(Equal(expectedStorageKey))
|
|
})
|
|
})
|
|
|
|
Describe("GetIncrementedKey", func() {
|
|
It("returns the storage key for later values sharing an index on the contract with other earlier values", func() {
|
|
// ex. solidity:
|
|
// mapping (bytes32 => uint) public amounts
|
|
// mapping (address => mapping (uint => bytes32)) public addressNames
|
|
// struct Data {
|
|
// uint256 quantity;
|
|
// uint256 quality;
|
|
// }
|
|
// mapping (bytes32 => Data) public itemData;
|
|
// to access quality from itemData, pass in the storage key for the zero-indexed value (quantity) + the number of increments required.
|
|
// (For "quality", we must increment the storage key for the corresponding "quantity" by 1).
|
|
indexOfMappingOnContract := storage.IndexTwo
|
|
keyForDesiredValueInMapping := "1234567890abcdef"
|
|
storageKeyForFirstPropertyOnStruct := storage.GetMapping(indexOfMappingOnContract, keyForDesiredValueInMapping)
|
|
|
|
storageKey := storage.GetIncrementedKey(storageKeyForFirstPropertyOnStruct, 1)
|
|
|
|
expectedStorageKey := common.HexToHash("0x69b38749f0a8ed5d505c8474f7fb62c7828aad8a7627f1c67e07af1d2368cad4")
|
|
Expect(storageKey).To(Equal(expectedStorageKey))
|
|
})
|
|
})
|
|
})
|