From 61e25eb2edf1530d196f9cbbbeced3b5814aabde Mon Sep 17 00:00:00 2001 From: Yilun Date: Sat, 18 May 2024 23:54:00 -0700 Subject: [PATCH] fix MarshalJSON undefined for non-pointer Uint160 Signed-off-by: Yilun --- common/uint160.go | 2 +- common/uint160_test.go | 12 +++++++++++- 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/common/uint160.go b/common/uint160.go index b73963088..fe816c524 100644 --- a/common/uint160.go +++ b/common/uint160.go @@ -89,7 +89,7 @@ func IsValidHexAddr(s []byte) bool { return false } -func (f *Uint160) MarshalJSON() ([]byte, error) { +func (f Uint160) MarshalJSON() ([]byte, error) { str, err := f.ToAddress() return []byte("\"" + str + "\""), err } diff --git a/common/uint160_test.go b/common/uint160_test.go index cb54012dc..ed8f0d319 100644 --- a/common/uint160_test.go +++ b/common/uint160_test.go @@ -2,6 +2,7 @@ package common import ( "encoding/hex" + "encoding/json" "testing" ) @@ -23,7 +24,16 @@ func TestMarshalJSON(t *testing.T) { // Expected value after Marshalling expected := []byte(NKNADDRESS) - bytes, err := f.MarshalJSON() + bytes, err := json.Marshal(f) + if err != nil { + t.Fatalf("Unexpected error: %v", err) + } + + if !bytesEqual(bytes, expected) { + t.Fatalf("Expected %v, got %v", expected, bytes) + } + + bytes, err = json.Marshal(*f) if err != nil { t.Fatalf("Unexpected error: %v", err) }