Skip to content

Commit

Permalink
Added more tests
Browse files Browse the repository at this point in the history
  • Loading branch information
mrz1836 committed Sep 30, 2020
1 parent 17615fe commit 97c1807
Show file tree
Hide file tree
Showing 2 changed files with 125 additions and 6 deletions.
17 changes: 11 additions & 6 deletions address.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ package bitcoin
import (
"bytes"
"errors"
"fmt"

"crypto/sha256"

Expand Down Expand Up @@ -73,21 +74,25 @@ func (a *A25) ComputeChecksum() (c [4]byte) {

// AddressFromPrivateKey takes a private key string and returns a Bitcoin address
func AddressFromPrivateKey(privateKey string) (string, error) {
pubKey, err := PrivateKeyFromString(privateKey)
rawKey, err := PrivateKeyFromString(privateKey)
if err != nil {
return "", err
}
var address *bsvutil.LegacyAddressPubKeyHash
if address, err = Address(pubKey.PubKey()); err != nil {
if address, err = AddressFromPubKey(rawKey.PubKey()); err != nil {
return "", err
}
return address.EncodeAddress(), nil
}

// Address gets a bsvutil.LegacyAddressPubKeyHash
func Address(publicKey *bsvec.PublicKey) (*bsvutil.LegacyAddressPubKeyHash, error) {
publicKeyHash := bsvutil.Hash160(publicKey.SerializeCompressed())
return bsvutil.NewLegacyAddressPubKeyHash(publicKeyHash, &chaincfg.MainNetParams)
// AddressFromPubKey gets a bsvutil.LegacyAddressPubKeyHash from a bsvec.PublicKey
func AddressFromPubKey(publicKey *bsvec.PublicKey) (*bsvutil.LegacyAddressPubKeyHash, error) {
if publicKey == nil {
return nil, fmt.Errorf("publicKey cannot be nil")
} else if publicKey.X == nil {
return nil, fmt.Errorf("publicKey.X cannot be nil")
}
return bsvutil.NewLegacyAddressPubKeyHash(bsvutil.Hash160(publicKey.SerializeCompressed()), &chaincfg.MainNetParams)
}

// ValidA58 validates a base58 encoded bitcoin address. An address is valid
Expand Down
114 changes: 114 additions & 0 deletions address_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@ package bitcoin
import (
"fmt"
"testing"

"github.com/bitcoinsv/bsvd/bsvec"
)

// TestValidA58 will test the method ValidA58()
Expand Down Expand Up @@ -58,3 +60,115 @@ func BenchmarkValidA58(b *testing.B) {
_, _ = ValidA58([]byte("1KCEAmVS6FFggtc7W9as7sEENvjt7DqMi2"))
}
}

// TestAddressFromPrivateKey will test the method AddressFromPrivateKey()
func TestAddressFromPrivateKey(t *testing.T) {
t.Parallel()

// Create the list of tests
var tests = []struct {
input string
expectedAddress string
expectedError bool
}{
{"0", "", true},
{"00000", "", true},
{"12345678", "1BHxe5Yw72oYoV8tFjySYrV9Y2JwMpAZEy", false},
{"54035dd4c7dda99ac473905a3d82", "1L5GmmuGeS3HwoEDv7zkWcheayXrRsurUm", false},
{"54035dd4c7dda99ac473905a3d82f7864322b49bab1ff441cc457183b9", "13dnka5SaugRchayN84EED7a2E8dCNMLXQ", false},
{"54035dd4c7dda99ac473905a3d82f7864322b49bab1ff441cc457183b9bd8abd", "1DfGxKmgL3ETwUdNnXLBueEvNpjcDGcKgK", false},
}

// Run tests
for _, test := range tests {
if address, err := AddressFromPrivateKey(test.input); err != nil && !test.expectedError {
t.Errorf("%s Failed: [%s] inputted and error not expected but got: %s", t.Name(), test.input, err.Error())
} else if err == nil && test.expectedError {
t.Errorf("%s Failed: [%s] inputted and error was expected", t.Name(), test.input)
} else if address != test.expectedAddress {
t.Errorf("%s Failed: [%s] inputted and [%s] expected, but got: %s", t.Name(), test.input, test.expectedAddress, address)
}
}
}

// ExampleAddressFromPrivateKey example using AddressFromPrivateKey()
func ExampleAddressFromPrivateKey() {
address, err := AddressFromPrivateKey("54035dd4c7dda99ac473905a3d82f7864322b49bab1ff441cc457183b9bd8abd")
if err != nil {
fmt.Printf("error occurred: %s", err.Error())
return
}
fmt.Printf("address found: %s", address)
// Output:address found: 1DfGxKmgL3ETwUdNnXLBueEvNpjcDGcKgK
}

// BenchmarkAddressFromPrivateKey benchmarks the method AddressFromPrivateKey()
func BenchmarkAddressFromPrivateKey(b *testing.B) {
key, _ := CreatePrivateKeyString()
for i := 0; i < b.N; i++ {
_, _ = AddressFromPrivateKey(key)
}
}

// testGetPublicKeyFromPrivateKey is a helper method for tests
func testGetPublicKeyFromPrivateKey(privateKey string) *bsvec.PublicKey {
rawKey, err := PrivateKeyFromString(privateKey)
if err != nil {
return nil
}
return rawKey.PubKey()
}

// TestAddressFromPubKey will test the method AddressFromPubKey()
func TestAddressFromPubKey(t *testing.T) {
t.Parallel()

// Create the list of tests
var tests = []struct {
input *bsvec.PublicKey
expectedAddress string
expectedNil bool
expectedError bool
}{
{&bsvec.PublicKey{}, "", true, true},
{testGetPublicKeyFromPrivateKey("54035dd4c7dda99ac473905a3d82f7864322b49bab1ff441cc457183b9bd8abd"), "1DfGxKmgL3ETwUdNnXLBueEvNpjcDGcKgK", false, false},
{testGetPublicKeyFromPrivateKey("000000"), "15wJjXvfQzo3SXqoWGbWZmNYND1Si4siqV", false, false},
{testGetPublicKeyFromPrivateKey("0"), "15wJjXvfQzo3SXqoWGbWZmNYND1Si4siqV", true, true},
}

// todo: add more error cases of invalid *bsvec.PublicKey

// Run tests
for _, test := range tests {
if rawKey, err := AddressFromPubKey(test.input); err != nil && !test.expectedError {
t.Errorf("%s Failed: [%v] inputted and error not expected but got: %s", t.Name(), test.input, err.Error())
} else if err == nil && test.expectedError {
t.Errorf("%s Failed: [%v] inputted and error was expected", t.Name(), test.input)
} else if rawKey == nil && !test.expectedNil {
t.Errorf("%s Failed: [%v] inputted and was nil but not expected", t.Name(), test.input)
} else if rawKey != nil && test.expectedNil {
t.Errorf("%s Failed: [%v] inputted and was NOT nil but expected to be nil", t.Name(), test.input)
} else if rawKey != nil && rawKey.EncodeAddress() != test.expectedAddress {
t.Errorf("%s Failed: [%v] inputted [%s] expected but failed comparison of addresses, got: %s", t.Name(), test.input, test.expectedAddress, rawKey.EncodeAddress())
}
}
}

// ExampleAddressFromPubKey example using AddressFromPubKey()
func ExampleAddressFromPubKey() {
rawAddress, err := AddressFromPubKey(testGetPublicKeyFromPrivateKey("54035dd4c7dda99ac473905a3d82f7864322b49bab1ff441cc457183b9bd8abd"))
if err != nil {
fmt.Printf("error occurred: %s", err.Error())
return
}
fmt.Printf("address found: %s", rawAddress.EncodeAddress())
// Output:address found: 1DfGxKmgL3ETwUdNnXLBueEvNpjcDGcKgK
}

// BenchmarkAddressFromPubKey benchmarks the method AddressFromPubKey()
func BenchmarkAddressFromPubKey(b *testing.B) {
pubKey := testGetPublicKeyFromPrivateKey("54035dd4c7dda99ac473905a3d82f7864322b49bab1ff441cc457183b9bd8abd")
for i := 0; i < b.N; i++ {
_, _ = AddressFromPubKey(pubKey)
}
}

0 comments on commit 97c1807

Please sign in to comment.