diff --git a/libraries/shared/storage/mappings.go b/libraries/shared/storage/mappings.go index dcb2e3ea7..188786839 100644 --- a/libraries/shared/storage/mappings.go +++ b/libraries/shared/storage/mappings.go @@ -47,7 +47,7 @@ const ( ) func GetMapping(indexOnContract, key string) common.Hash { - keyBytes := common.FromHex("0x" + key + indexOnContract) + keyBytes := common.FromHex(key + indexOnContract) encoded := crypto.Keccak256(keyBytes) return common.BytesToHash(encoded) } diff --git a/libraries/shared/storage/mappings_test.go b/libraries/shared/storage/mappings_test.go index f696add6f..7114a39bf 100644 --- a/libraries/shared/storage/mappings_test.go +++ b/libraries/shared/storage/mappings_test.go @@ -21,6 +21,16 @@ var _ = Describe("Mappings", func() { 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() {