diff options
author | johnliu-dexon <42129254+johnliu-dexon@users.noreply.github.com> | 2019-01-17 16:37:15 +0800 |
---|---|---|
committer | Wei-Ning Huang <w@dexon.org> | 2019-01-17 16:37:15 +0800 |
commit | cd491a6cb58c8f138d449b24bfecab0e37fa598f (patch) | |
tree | 35fc3341f00b43f44abe9382e179e1e4ba7c3e36 /common | |
parent | a6401d01d43d806f4d5e71cfdf2848001df9e129 (diff) | |
download | dexon-cd491a6cb58c8f138d449b24bfecab0e37fa598f.tar dexon-cd491a6cb58c8f138d449b24bfecab0e37fa598f.tar.gz dexon-cd491a6cb58c8f138d449b24bfecab0e37fa598f.tar.bz2 dexon-cd491a6cb58c8f138d449b24bfecab0e37fa598f.tar.lz dexon-cd491a6cb58c8f138d449b24bfecab0e37fa598f.tar.xz dexon-cd491a6cb58c8f138d449b24bfecab0e37fa598f.tar.zst dexon-cd491a6cb58c8f138d449b24bfecab0e37fa598f.zip |
common: fix big scan from bytes (#157)
We store string of number, not bytes value into database
10 is stored as 0x3130, not 0x0a
Use UnmarshalText instead of SetBytes
Diffstat (limited to 'common')
-rw-r--r-- | common/big.go | 6 | ||||
-rw-r--r-- | common/big_test.go | 2 |
2 files changed, 6 insertions, 2 deletions
diff --git a/common/big.go b/common/big.go index ea3d4aba6..96a83661e 100644 --- a/common/big.go +++ b/common/big.go @@ -45,7 +45,11 @@ func (b *Big) Scan(src interface{}) error { case uint64: *b = Big(*newB.SetUint64(t)) case []byte: - *b = Big(*newB.SetBytes(t)) + err := newB.UnmarshalText(t) + if err != nil { + return err + } + *b = Big(*newB) case string: v, ok := newB.SetString(t, 10) if !ok { diff --git a/common/big_test.go b/common/big_test.go index 0339b4760..5ce9091ec 100644 --- a/common/big_test.go +++ b/common/big_test.go @@ -31,7 +31,7 @@ func TestBig_Scan(t *testing.T) { }, { name: "scan bytes", - args: args{src: []byte{0x0a}}, + args: args{src: []byte{0x31, 0x30}}, value: Big(*big.NewInt(10)), wantErr: false, }, |