2018-05-03 12:36:56 +02:00
|
|
|
package status
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"crypto/ecdsa"
|
|
|
|
"errors"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/accounts"
|
|
|
|
"github.com/ethereum/go-ethereum/accounts/keystore"
|
|
|
|
"github.com/golang/mock/gomock"
|
2019-01-18 10:01:14 +01:00
|
|
|
"github.com/status-im/status-go/account"
|
2018-05-03 12:36:56 +02:00
|
|
|
"github.com/stretchr/testify/suite"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestStatusSuite(t *testing.T) {
|
|
|
|
suite.Run(t, new(StatusSuite))
|
|
|
|
}
|
|
|
|
|
|
|
|
type StatusSuite struct {
|
|
|
|
suite.Suite
|
|
|
|
am *MockAccountManager
|
2018-05-07 10:22:38 +02:00
|
|
|
w *MockWhisperService
|
2018-05-03 12:36:56 +02:00
|
|
|
api *PublicAPI
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *StatusSuite) SetupTest() {
|
|
|
|
ctrl := gomock.NewController(s.T())
|
|
|
|
s.am = NewMockAccountManager(ctrl)
|
2018-05-07 10:22:38 +02:00
|
|
|
s.w = NewMockWhisperService(ctrl)
|
2018-05-03 12:36:56 +02:00
|
|
|
service := New(s.w)
|
|
|
|
service.SetAccountManager(s.am)
|
|
|
|
|
|
|
|
s.api = NewAPI(service)
|
|
|
|
}
|
|
|
|
|
|
|
|
var logintests = []struct {
|
|
|
|
name string
|
|
|
|
expectedAddressKey string
|
|
|
|
expectedError error
|
|
|
|
prepareExpectations func(*StatusSuite)
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "success login",
|
|
|
|
expectedAddressKey: "addressKey",
|
|
|
|
expectedError: nil,
|
|
|
|
prepareExpectations: func(s *StatusSuite) {
|
|
|
|
key := keystore.Key{
|
|
|
|
PrivateKey: &ecdsa.PrivateKey{},
|
|
|
|
}
|
|
|
|
s.am.EXPECT().AddressToDecryptedAccount("address...", "password").Return(accounts.Account{}, &key, nil)
|
|
|
|
s.w.EXPECT().AddKeyPair(key.PrivateKey).Return("addressKey", nil)
|
2019-01-18 10:01:14 +01:00
|
|
|
s.am.EXPECT().SelectAccount("address...", "address...", "password").Return(nil)
|
2018-05-03 12:36:56 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "error when decrypting account from address",
|
|
|
|
expectedAddressKey: "",
|
|
|
|
expectedError: errors.New("foo"),
|
|
|
|
prepareExpectations: func(s *StatusSuite) {
|
|
|
|
key := keystore.Key{
|
|
|
|
PrivateKey: &ecdsa.PrivateKey{},
|
|
|
|
}
|
|
|
|
s.am.EXPECT().AddressToDecryptedAccount("address...", "password").Return(accounts.Account{}, &key, errors.New("foo"))
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "error when adding key pair to whisper",
|
|
|
|
expectedAddressKey: "",
|
|
|
|
expectedError: errors.New("foo"),
|
|
|
|
prepareExpectations: func(s *StatusSuite) {
|
|
|
|
key := keystore.Key{
|
|
|
|
PrivateKey: &ecdsa.PrivateKey{},
|
|
|
|
}
|
|
|
|
s.am.EXPECT().AddressToDecryptedAccount("address...", "password").Return(accounts.Account{}, &key, nil)
|
|
|
|
s.w.EXPECT().AddKeyPair(key.PrivateKey).Return("", errors.New("foo"))
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "error when selecting account",
|
|
|
|
expectedAddressKey: "",
|
|
|
|
expectedError: errors.New("foo"),
|
|
|
|
prepareExpectations: func(s *StatusSuite) {
|
|
|
|
key := keystore.Key{
|
|
|
|
PrivateKey: &ecdsa.PrivateKey{},
|
|
|
|
}
|
|
|
|
s.am.EXPECT().AddressToDecryptedAccount("address...", "password").Return(accounts.Account{}, &key, nil)
|
|
|
|
s.w.EXPECT().AddKeyPair(key.PrivateKey).Return("", nil)
|
2019-01-18 10:01:14 +01:00
|
|
|
s.am.EXPECT().SelectAccount("address...", "address...", "password").Return(errors.New("foo"))
|
2018-05-03 12:36:56 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *StatusSuite) TestLogin() {
|
|
|
|
for _, t := range logintests {
|
|
|
|
req := LoginRequest{Addr: "address...", Password: "password"}
|
|
|
|
|
|
|
|
t.prepareExpectations(s)
|
|
|
|
|
|
|
|
var ctx context.Context
|
|
|
|
res, err := s.api.Login(ctx, req)
|
|
|
|
s.Equal(t.expectedAddressKey, res.AddressKeyID, "failed scenario : "+t.name)
|
|
|
|
s.Equal(t.expectedError, err, "failed scenario : "+t.name)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
var signuptests = []struct {
|
|
|
|
name string
|
|
|
|
expectedResponse SignupResponse
|
|
|
|
expectedError error
|
|
|
|
prepareExpectations func(*StatusSuite)
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "success signup",
|
|
|
|
expectedResponse: SignupResponse{
|
2019-01-18 10:01:14 +01:00
|
|
|
WalletAddress: "addr",
|
|
|
|
WalletPubkey: "pubkey",
|
|
|
|
Mnemonic: "mnemonic",
|
2018-05-03 12:36:56 +02:00
|
|
|
},
|
|
|
|
expectedError: nil,
|
|
|
|
prepareExpectations: func(s *StatusSuite) {
|
2019-01-18 10:01:14 +01:00
|
|
|
accountInfo := account.Info{
|
|
|
|
WalletAddress: "addr",
|
|
|
|
WalletPubKey: "pubkey",
|
|
|
|
ChatAddress: "addr",
|
|
|
|
ChatPubKey: "pubkey",
|
|
|
|
}
|
|
|
|
s.am.EXPECT().CreateAccount("password").Return(accountInfo, "mnemonic", nil)
|
2018-05-03 12:36:56 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "success signup",
|
|
|
|
expectedResponse: SignupResponse{
|
2019-01-18 10:01:14 +01:00
|
|
|
WalletAddress: "",
|
|
|
|
WalletPubkey: "",
|
|
|
|
Mnemonic: "",
|
2018-05-03 12:36:56 +02:00
|
|
|
},
|
|
|
|
expectedError: errors.New("could not create the specified account : foo"),
|
|
|
|
prepareExpectations: func(s *StatusSuite) {
|
2019-01-18 10:01:14 +01:00
|
|
|
s.am.EXPECT().CreateAccount("password").Return(account.Info{}, "", errors.New("foo"))
|
2018-05-03 12:36:56 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *StatusSuite) TestSignup() {
|
|
|
|
for _, t := range signuptests {
|
|
|
|
t.prepareExpectations(s)
|
|
|
|
|
|
|
|
var ctx context.Context
|
|
|
|
res, err := s.api.Signup(ctx, SignupRequest{Password: "password"})
|
2019-01-18 10:01:14 +01:00
|
|
|
s.Equal(t.expectedResponse.WalletAddress, res.WalletAddress, "failed scenario : "+t.name)
|
|
|
|
s.Equal(t.expectedResponse.WalletPubkey, res.WalletPubkey, "failed scenario : "+t.name)
|
2018-05-03 12:36:56 +02:00
|
|
|
s.Equal(t.expectedResponse.Mnemonic, res.Mnemonic, "failed scenario : "+t.name)
|
|
|
|
s.Equal(t.expectedError, err, "failed scenario : "+t.name)
|
|
|
|
}
|
|
|
|
}
|