github.com/iotexproject/iotex-core@v1.14.1-rc1/ioctl/newcmd/account/accountupdate_test.go (about) 1 // Copyright (c) 2019 IoTeX Foundation 2 // This source code is provided 'as is' and no warranties are given as to title or non-infringement, merchantability 3 // or fitness for purpose and, to the extent permitted by law, all liability for your use of the code is disclaimed. 4 // This source code is governed by Apache License 2.0 that can be found in the LICENSE file. 5 6 package account 7 8 import ( 9 "fmt" 10 "testing" 11 12 "github.com/ethereum/go-ethereum/accounts/keystore" 13 "github.com/golang/mock/gomock" 14 "github.com/iotexproject/go-pkgs/crypto" 15 "github.com/iotexproject/iotex-address/address" 16 "github.com/stretchr/testify/require" 17 18 "github.com/iotexproject/iotex-core/ioctl/config" 19 "github.com/iotexproject/iotex-core/ioctl/util" 20 "github.com/iotexproject/iotex-core/test/mock/mock_ioctlclient" 21 ) 22 23 func TestNewAccountUpdate_FindKeystore(t *testing.T) { 24 require := require.New(t) 25 ctrl := gomock.NewController(t) 26 client := mock_ioctlclient.NewMockClient(ctrl) 27 client.EXPECT().SelectTranslation(gomock.Any()).Return("mockTranslationString", config.English).AnyTimes() 28 29 testAccountFolder := t.TempDir() 30 ks := keystore.NewKeyStore(testAccountFolder, veryLightScryptN, veryLightScryptP) 31 client.EXPECT().NewKeyStore().Return(ks).AnyTimes() 32 const pwd = "test" 33 acc, err := ks.NewAccount(pwd) 34 require.NoError(err) 35 accAddr, err := address.FromBytes(acc.Address.Bytes()) 36 require.NoError(err) 37 client.EXPECT().IsCryptoSm2().Return(false).Times(3) 38 39 t.Run("invalid_current_password", func(t *testing.T) { 40 client.EXPECT().AddressWithDefaultIfNotExist(gomock.Any()).Return(accAddr.String(), nil).Times(1) 41 client.EXPECT().ReadSecret().Return("1234", nil).Times(1) 42 cmd := NewAccountUpdate(client) 43 _, err := util.ExecuteCmd(cmd) 44 require.Equal("error occurs when checking current password: could not decrypt key with given password", err.Error()) 45 }) 46 47 t.Run("new_password_not_match", func(t *testing.T) { 48 client.EXPECT().AddressWithDefaultIfNotExist(gomock.Any()).Return(accAddr.String(), nil).Times(1) 49 client.EXPECT().ReadSecret().Return(pwd, nil).Times(1) 50 client.EXPECT().ReadSecret().Return("1234", nil).Times(1) 51 client.EXPECT().ReadSecret().Return("12345", nil).Times(1) 52 cmd := NewAccountUpdate(client) 53 _, err := util.ExecuteCmd(cmd) 54 require.Equal(ErrPasswdNotMatch, err) 55 }) 56 57 t.Run("success", func(t *testing.T) { 58 client.EXPECT().AddressWithDefaultIfNotExist(gomock.Any()).Return(accAddr.String(), nil).Times(1) 59 client.EXPECT().ReadSecret().Return(pwd, nil).Times(1) 60 client.EXPECT().ReadSecret().Return("1234", nil).Times(1) 61 client.EXPECT().ReadSecret().Return("1234", nil).Times(1) 62 cmd := NewAccountUpdate(client) 63 result, err := util.ExecuteCmd(cmd) 64 require.NoError(err) 65 require.Contains(result, fmt.Sprintf("Account #%s has been updated.", accAddr.String())) 66 }) 67 } 68 69 func TestNewAccountUpdate_FindPemFile(t *testing.T) { 70 require := require.New(t) 71 ctrl := gomock.NewController(t) 72 client := mock_ioctlclient.NewMockClient(ctrl) 73 client.EXPECT().SelectTranslation(gomock.Any()).Return("mockTranslationString", config.English).AnyTimes() 74 75 testAccountFolder := t.TempDir() 76 ks := keystore.NewKeyStore(testAccountFolder, veryLightScryptN, veryLightScryptP) 77 client.EXPECT().NewKeyStore().Return(ks).AnyTimes() 78 const pwd = "test" 79 acc, err := ks.NewAccount(pwd) 80 require.NoError(err) 81 accAddr, err := address.FromBytes(acc.Address.Bytes()) 82 require.NoError(err) 83 84 client.EXPECT().Config().Return(config.Config{Wallet: testAccountFolder}).Times(4) 85 skPemPath := sm2KeyPath(client, accAddr) 86 sk, err := crypto.GenerateKeySm2() 87 require.NoError(err) 88 k, ok := sk.EcdsaPrivateKey().(*crypto.P256sm2PrvKey) 89 require.True(ok) 90 require.NoError(crypto.WritePrivateKeyToPem(skPemPath, k, pwd)) 91 client.EXPECT().IsCryptoSm2().Return(true).Times(3) 92 93 t.Run("invalid_current_password", func(t *testing.T) { 94 client.EXPECT().AddressWithDefaultIfNotExist(gomock.Any()).Return(accAddr.String(), nil).Times(1) 95 client.EXPECT().ReadSecret().Return("1234", nil).Times(1) 96 cmd := NewAccountUpdate(client) 97 _, err := util.ExecuteCmd(cmd) 98 require.Equal("error occurs when checking current password: pkcs8: incorrect password", err.Error()) 99 }) 100 101 t.Run("new_password_not_match", func(t *testing.T) { 102 client.EXPECT().AddressWithDefaultIfNotExist(gomock.Any()).Return(accAddr.String(), nil).Times(1) 103 client.EXPECT().ReadSecret().Return(pwd, nil).Times(1) 104 client.EXPECT().ReadSecret().Return("1234", nil).Times(1) 105 client.EXPECT().ReadSecret().Return("12345", nil).Times(1) 106 cmd := NewAccountUpdate(client) 107 _, err := util.ExecuteCmd(cmd) 108 require.Equal(ErrPasswdNotMatch, err) 109 }) 110 111 t.Run("success", func(t *testing.T) { 112 client.EXPECT().AddressWithDefaultIfNotExist(gomock.Any()).Return(accAddr.String(), nil).Times(1) 113 client.EXPECT().ReadSecret().Return(pwd, nil).Times(1) 114 client.EXPECT().ReadSecret().Return("1234", nil).Times(1) 115 client.EXPECT().ReadSecret().Return("1234", nil).Times(1) 116 cmd := NewAccountUpdate(client) 117 result, err := util.ExecuteCmd(cmd) 118 require.NoError(err) 119 require.Contains(result, fmt.Sprintf("Account #%s has been updated.", accAddr.String())) 120 }) 121 }