aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPéter Szilágyi <peterke@gmail.com>2017-11-29 08:21:41 +0800
committerPéter Szilágyi <peterke@gmail.com>2017-11-29 08:25:32 +0800
commitb33a5294eaf06a3e952efe1ce4ef810af37d1062 (patch)
treeefb7b8e936fe001180067703fcb226c90779023a
parentbe12392fbad9f4a861130a347e6bcf07a5c34974 (diff)
downloadgo-tangerine-b33a5294eaf06a3e952efe1ce4ef810af37d1062.tar
go-tangerine-b33a5294eaf06a3e952efe1ce4ef810af37d1062.tar.gz
go-tangerine-b33a5294eaf06a3e952efe1ce4ef810af37d1062.tar.bz2
go-tangerine-b33a5294eaf06a3e952efe1ce4ef810af37d1062.tar.lz
go-tangerine-b33a5294eaf06a3e952efe1ce4ef810af37d1062.tar.xz
go-tangerine-b33a5294eaf06a3e952efe1ce4ef810af37d1062.tar.zst
go-tangerine-b33a5294eaf06a3e952efe1ce4ef810af37d1062.zip
common: fix hex utils to handle 1 byte address conversions
-rw-r--r--common/bytes.go9
-rw-r--r--common/bytes_test.go13
2 files changed, 15 insertions, 7 deletions
diff --git a/common/bytes.go b/common/bytes.go
index 66577bbfd..bb40ac1d7 100644
--- a/common/bytes.go
+++ b/common/bytes.go
@@ -35,12 +35,11 @@ func FromHex(s string) []byte {
if s[0:2] == "0x" || s[0:2] == "0X" {
s = s[2:]
}
- if len(s)%2 == 1 {
- s = "0" + s
- }
- return Hex2Bytes(s)
}
- return nil
+ if len(s)%2 == 1 {
+ s = "0" + s
+ }
+ return Hex2Bytes(s)
}
// Copy bytes
diff --git a/common/bytes_test.go b/common/bytes_test.go
index fc164b13d..71631e6dd 100644
--- a/common/bytes_test.go
+++ b/common/bytes_test.go
@@ -74,7 +74,7 @@ func TestFromHex(t *testing.T) {
expected := []byte{1}
result := FromHex(input)
if !bytes.Equal(expected, result) {
- t.Errorf("Expected % x got % x", expected, result)
+ t.Errorf("Expected %x got %x", expected, result)
}
}
@@ -83,6 +83,15 @@ func TestFromHexOddLength(t *testing.T) {
expected := []byte{1}
result := FromHex(input)
if !bytes.Equal(expected, result) {
- t.Errorf("Expected % x got % x", expected, result)
+ t.Errorf("Expected %x got %x", expected, result)
+ }
+}
+
+func TestNoPrefixShortHexOddLength(t *testing.T) {
+ input := "1"
+ expected := []byte{1}
+ result := FromHex(input)
+ if !bytes.Equal(expected, result) {
+ t.Errorf("Expected %x got %x", expected, result)
}
}