Merge pull request #2484 from pcasaretto/address-test-coverage
Improve Address test coverage
This commit is contained in:
		@@ -167,7 +167,7 @@ func (a Address) MarshalJSON() ([]byte, error) {
 | 
				
			|||||||
// Parse address from raw json data
 | 
					// Parse address from raw json data
 | 
				
			||||||
func (a *Address) UnmarshalJSON(data []byte) error {
 | 
					func (a *Address) UnmarshalJSON(data []byte) error {
 | 
				
			||||||
	if len(data) > 2 && data[0] == '"' && data[len(data)-1] == '"' {
 | 
						if len(data) > 2 && data[0] == '"' && data[len(data)-1] == '"' {
 | 
				
			||||||
		data = data[:len(data)-1][1:]
 | 
							data = data[1 : len(data)-1]
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if len(data) > 2 && data[0] == '0' && data[1] == 'x' {
 | 
						if len(data) > 2 && data[0] == '0' && data[1] == 'x' {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -16,7 +16,10 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
package common
 | 
					package common
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import "testing"
 | 
					import (
 | 
				
			||||||
 | 
						"math/big"
 | 
				
			||||||
 | 
						"testing"
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func TestBytesConversion(t *testing.T) {
 | 
					func TestBytesConversion(t *testing.T) {
 | 
				
			||||||
	bytes := []byte{5}
 | 
						bytes := []byte{5}
 | 
				
			||||||
@@ -47,7 +50,38 @@ func TestHashJsonValidation(t *testing.T) {
 | 
				
			|||||||
	}
 | 
						}
 | 
				
			||||||
	for i, test := range tests {
 | 
						for i, test := range tests {
 | 
				
			||||||
		if err := h.UnmarshalJSON(append([]byte(test.Prefix), make([]byte, test.Size)...)); err != test.Error {
 | 
							if err := h.UnmarshalJSON(append([]byte(test.Prefix), make([]byte, test.Size)...)); err != test.Error {
 | 
				
			||||||
			t.Error(i, "expected", test.Error, "got", err)
 | 
								t.Errorf("test #%d: error mismatch: have %v, want %v", i, err, test.Error)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func TestAddressUnmarshalJSON(t *testing.T) {
 | 
				
			||||||
 | 
						var a Address
 | 
				
			||||||
 | 
						var tests = []struct {
 | 
				
			||||||
 | 
							Input     string
 | 
				
			||||||
 | 
							ShouldErr bool
 | 
				
			||||||
 | 
							Output    *big.Int
 | 
				
			||||||
 | 
						}{
 | 
				
			||||||
 | 
							{"", true, nil},
 | 
				
			||||||
 | 
							{`""`, true, nil},
 | 
				
			||||||
 | 
							{`"0x"`, true, nil},
 | 
				
			||||||
 | 
							{`"0x00"`, true, nil},
 | 
				
			||||||
 | 
							{`"0xG000000000000000000000000000000000000000"`, true, nil},
 | 
				
			||||||
 | 
							{`"0x0000000000000000000000000000000000000000"`, false, big.NewInt(0)},
 | 
				
			||||||
 | 
							{`"0x0000000000000000000000000000000000000010"`, false, big.NewInt(16)},
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						for i, test := range tests {
 | 
				
			||||||
 | 
							err := a.UnmarshalJSON([]byte(test.Input))
 | 
				
			||||||
 | 
							if err != nil && !test.ShouldErr {
 | 
				
			||||||
 | 
								t.Errorf("test #%d: unexpected error: %v", i, err)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
							if err == nil {
 | 
				
			||||||
 | 
								if test.ShouldErr {
 | 
				
			||||||
 | 
									t.Errorf("test #%d: expected error, got none", i)
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								if a.Big().Cmp(test.Output) != 0 {
 | 
				
			||||||
 | 
									t.Errorf("test #%d: address mismatch: have %v, want %v", i, a.Big(), test.Output)
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user