You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
72 lines
1.7 KiB
72 lines
1.7 KiB
package services
|
|
|
|
import (
|
|
"reflect"
|
|
"testing"
|
|
|
|
"github.com/coinbase/rosetta-sdk-go/types"
|
|
ethcommon "github.com/ethereum/go-ethereum/common"
|
|
"github.com/ethereum/go-ethereum/crypto"
|
|
|
|
internalCommon "github.com/woop-chain/woop/internal/common"
|
|
)
|
|
|
|
func TestNewAccountIdentifier(t *testing.T) {
|
|
key, err := crypto.GenerateKey()
|
|
if err != nil {
|
|
t.Fatalf(err.Error())
|
|
}
|
|
addr := crypto.PubkeyToAddress(key.PublicKey)
|
|
b32Addr, err := internalCommon.AddressToBech32(addr)
|
|
if err != nil {
|
|
t.Fatalf(err.Error())
|
|
}
|
|
metadata, err := types.MarshalMap(AccountMetadata{Address: addr.String()})
|
|
if err != nil {
|
|
t.Fatalf(err.Error())
|
|
}
|
|
|
|
referenceAccID := &types.AccountIdentifier{
|
|
Address: b32Addr,
|
|
Metadata: metadata,
|
|
}
|
|
testAccID, rosettaError := newAccountIdentifier(addr)
|
|
if rosettaError != nil {
|
|
t.Fatalf("unexpected rosetta error: %v", rosettaError)
|
|
}
|
|
if !reflect.DeepEqual(referenceAccID, testAccID) {
|
|
t.Errorf("reference ID %v != testID %v", referenceAccID, testAccID)
|
|
}
|
|
}
|
|
|
|
func TestGetAddress(t *testing.T) {
|
|
key, err := crypto.GenerateKey()
|
|
if err != nil {
|
|
t.Fatalf(err.Error())
|
|
}
|
|
addr := crypto.PubkeyToAddress(key.PublicKey)
|
|
b32Addr, err := internalCommon.AddressToBech32(addr)
|
|
if err != nil {
|
|
t.Fatalf(err.Error())
|
|
}
|
|
testAccID := &types.AccountIdentifier{
|
|
Address: b32Addr,
|
|
}
|
|
|
|
testAddr, err := getAddress(testAccID)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if testAddr != addr {
|
|
t.Errorf("expected %v to be %v", testAddr.String(), addr.String())
|
|
}
|
|
|
|
defaultAddr := ethcommon.Address{}
|
|
testAddr, err = getAddress(nil)
|
|
if err == nil {
|
|
t.Error("expected err for nil identifier")
|
|
}
|
|
if testAddr != defaultAddr {
|
|
t.Errorf("expected errored addres to be %v not %v", defaultAddr.String(), testAddr.String())
|
|
}
|
|
}
|
|
|